-
Notifications
You must be signed in to change notification settings - Fork 143
/
service_requests_controller.rb
74 lines (65 loc) · 2.55 KB
/
service_requests_controller.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
module Api
class ServiceRequestsController < BaseController
include Subcollections::RequestTasks
include Api::Mixins::Pictures
include Api::Mixins::ResourceCancel
alias fetch_service_requests_picture fetch_picture
def approve_resource(type, id, data)
raise "Must specify a reason for approving a service request" unless data["reason"].present?
api_action(type, id) do |klass|
provreq = resource_search(id, type, klass)
provreq.approve(User.current_user.userid, data['reason'])
action_result(true, "Service request #{id} approved")
end
rescue => err
action_result(false, err.to_s)
end
def deny_resource(type, id, data)
raise "Must specify a reason for denying a service request" unless data["reason"].present?
api_action(type, id) do |klass|
provreq = resource_search(id, type, klass)
provreq.deny(User.current_user.userid, data['reason'])
action_result(true, "Service request #{id} denied")
end
rescue => err
action_result(false, err.to_s)
end
def edit_resource(type, id, data)
request = resource_search(id, type, collection_class(:service_requests))
RequestEditor.edit(request, data)
request
end
def find_service_requests(id)
klass = collection_class(:service_requests)
return klass.find(id) if User.current_user.admin_user?
klass.find_by!(:requester => User.current_user, :id => id)
end
def service_requests_search_conditions
return {} if User.current_user.admin_user?
{:requester => User.current_user}
end
def get_user(data)
user_id = data['user_id'] || parse_id(data['user'], :users)
raise 'Must specify a valid user_id or user' unless user_id
User.find(user_id)
end
def add_approver_resource(type, id, data)
user = get_user(data)
miq_approval = MiqApproval.create(:approver => user)
resource_search(id, type, collection_class(:service_requests)).tap do |service_request|
service_request.miq_approvals << miq_approval
end
rescue => err
raise BadRequestError, "Cannot add approver - #{err}"
end
def remove_approver_resource(type, id, data)
user = get_user(data)
resource_search(id, type, collection_class(:service_requests)).tap do |service_request|
miq_approval = service_request.miq_approvals.find_by(:approver_name => user.name)
miq_approval.destroy if miq_approval
end
rescue => err
raise BadRequestError, "Cannot remove approver - #{err}"
end
end
end