Module: Legion::Extensions::ServiceNow::AccessControl::Runners::AccessControl

Includes:
Helpers::Lex, Helpers::Client
Included in:
Client
Defined in:
lib/legion/extensions/service_now/access_control/runners/access_control.rb

Instance Method Summary collapse

Methods included from Helpers::Client

#connection, #fetch_oauth2_token, #handle_response

Instance Method Details

#create_acl(name:, type:, operation:, active: true, script: nil, condition: nil) ⇒ Object



24
25
26
27
28
29
30
31
# File 'lib/legion/extensions/service_now/access_control/runners/access_control.rb', line 24

def create_acl(name:, type:, operation:, active: true,
               script: nil, condition: nil, **)
  body = { name: name, type: type, operation: operation, active: active }
  body[:script]    = script if script
  body[:condition] = condition if condition
  resp = connection(**).post('/api/now/table/sys_security_acl', body)
  { acl: resp.body['result'] }
end

#delete_acl(sys_id:) ⇒ Object



42
43
44
45
# File 'lib/legion/extensions/service_now/access_control/runners/access_control.rb', line 42

def delete_acl(sys_id:, **)
  resp = connection(**).delete("/api/now/table/sys_security_acl/#{sys_id}")
  { deleted: resp.status == 204, sys_id: sys_id }
end

#get_acl(sys_id:) ⇒ Object



19
20
21
22
# File 'lib/legion/extensions/service_now/access_control/runners/access_control.rb', line 19

def get_acl(sys_id:, **)
  resp = connection(**).get("/api/now/table/sys_security_acl/#{sys_id}")
  { acl: resp.body['result'] }
end

#list_acls(sysparm_limit: 100, sysparm_offset: 0, sysparm_query: nil) ⇒ Object



11
12
13
14
15
16
17
# File 'lib/legion/extensions/service_now/access_control/runners/access_control.rb', line 11

def list_acls(sysparm_limit: 100, sysparm_offset: 0,
              sysparm_query: nil, **)
  params = { sysparm_limit: sysparm_limit, sysparm_offset: sysparm_offset }
  params[:sysparm_query] = sysparm_query if sysparm_query
  resp = connection(**).get('/api/now/table/sys_security_acl', params)
  { acls: resp.body['result'] }
end

#update_acl(sys_id:, active: nil, script: nil, condition: nil) ⇒ Object



33
34
35
36
37
38
39
40
# File 'lib/legion/extensions/service_now/access_control/runners/access_control.rb', line 33

def update_acl(sys_id:, active: nil, script: nil, condition: nil, **)
  body = {}
  body[:active]    = active unless active.nil?
  body[:script]    = script if script
  body[:condition] = condition if condition
  resp = connection(**).patch("/api/now/table/sys_security_acl/#{sys_id}", body)
  { acl: resp.body['result'] }
end