Module: Legion::Extensions::ServiceNow::SecurityIncident::Runners::SecurityIncident

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

Instance Method Summary collapse

Methods included from Helpers::Client

#connection, #fetch_oauth2_token, #handle_response

Instance Method Details

#close_security_incident(sys_id:, close_notes:) ⇒ Object



45
46
47
48
49
# File 'lib/legion/extensions/service_now/security_incident/runners/security_incident.rb', line 45

def close_security_incident(sys_id:, close_notes:, **)
  body = { state: 'closed', close_notes: close_notes }
  resp = connection(**).patch("/api/now/table/sn_si_incident/#{sys_id}", body)
  { security_incident: resp.body['result'] }
end

#create_security_incident(short_description:, severity: '3', category: nil, subcategory: nil, assignment_group: nil) ⇒ Object



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

def create_security_incident(short_description:, severity: '3',
                             category: nil, subcategory: nil,
                             assignment_group: nil, **)
  body = { short_description: short_description, severity: severity }
  body[:category]         = category if category
  body[:subcategory]      = subcategory if subcategory
  body[:assignment_group] = assignment_group if assignment_group
  resp = connection(**).post('/api/now/table/sn_si_incident', body)
  { security_incident: resp.body['result'] }
end

#get_security_incident(sys_id:) ⇒ Object



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

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

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



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

def list_security_incidents(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/sn_si_incident', params)
  { security_incidents: resp.body['result'] }
end

#update_security_incident(sys_id:, state: nil, severity: nil, assigned_to: nil) ⇒ Object



35
36
37
38
39
40
41
42
43
# File 'lib/legion/extensions/service_now/security_incident/runners/security_incident.rb', line 35

def update_security_incident(sys_id:, state: nil, severity: nil,
                             assigned_to: nil, **)
  body = {}
  body[:state]       = state if state
  body[:severity]    = severity if severity
  body[:assigned_to] = assigned_to if assigned_to
  resp = connection(**).patch("/api/now/table/sn_si_incident/#{sys_id}", body)
  { security_incident: resp.body['result'] }
end