Class: Emasser::Poams
- Inherits:
-
SubCommandBase
- Object
- Thor
- SubCommandBase
- Emasser::Poams
- Defined in:
- lib/emasser/get.rb,
lib/emasser/put.rb,
lib/emasser/post.rb,
lib/emasser/delete.rb
Overview
Remove one or more POA&M from a system
Endpoint:
/api/systems/{systemId}/poams - Remove one or many poa&m items in a system
Class Method Summary collapse
Instance Method Summary collapse
-
#add ⇒ Object
rubocop:disable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity, Metrics/AbcSize.
- #byPoamId ⇒ Object
- #forSystem ⇒ Object
- #remove ⇒ Object
-
#update ⇒ Object
rubocop:disable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity, Metrics/AbcSize.
Methods inherited from SubCommandBase
Methods included from OutputConverters
#change_to_datetime, #to_output_hash
Methods included from InputConverters
Methods included from OptionsParser
#optional_options, #required_options
Class Method Details
.exit_on_failure? ⇒ Boolean
288 289 290 |
# File 'lib/emasser/get.rb', line 288 def self.exit_on_failure? true end |
Instance Method Details
#add ⇒ Object
rubocop:disable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity, Metrics/AbcSize
204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 |
# File 'lib/emasser/post.rb', line 204 def add # Check if business logic is satisfied process_business_logic # Required fields require_fields = EmassClient::PoamRequiredFields.new require_fields.status = [:status] require_fields.vulnerability_description = [:vulnerabilityDescription] require_fields. = [:sourceIdentifyingVulnerability] require_fields.poc_organization = [:pocOrganization] require_fields.resources = [:resources] # Required for VA, optional for Army and USCG. - defaults to false require_fields.identified_in_cfo_audit_or_other_review = [:identifiedInCFOAuditOrOtherReview] if [:identifiedInCFOAuditOrOtherReview] # Add conditional fields conditional_fields = EmassClient::PoamConditionalFields.new conditional_fields.poc_first_name = [:pocFirstName] if [:pocFirstName] conditional_fields.poc_last_name = [:pocLastName] if [:pocLastName] conditional_fields.poc_email = [:pocEmail] if [:pocEmail] conditional_fields.poc_phone_number = [:pocPhoneNumber] if [:pocPhoneNumber] conditional_fields.severity = [:severity] if [:severity] conditional_fields.scheduled_completion_date = [:scheduledCompletionDate] if [:scheduledCompletionDate] conditional_fields.completion_date = [:completionDate] if [:completionDate] conditional_fields.comments = [:comments] if [:comments] conditional_fields.personnel_resources_funded_base_hours = [:personnelResourcesFundedBaseHours] if [:personnelResourcesFundedBaseHours] conditional_fields.personnel_resources_cost_code = [:personnelResourcesCostCode] if [:personnelResourcesCostCode] conditional_fields.personnel_resources_unfunded_base_hours = [:personnelResourcesUnfundedBaseHours] if [:personnelResourcesUnfundedBaseHours] conditional_fields.personnel_resources_nonfunding_obstacle = [:personnelResourcesNonfundingObstacle] if [:personnelResourcesNonfundingObstacle] conditional_fields.personnel_resources_nonfunding_obstacle_other_reason = [:personnelResourcesNonfundingObstacleOtherReason] if [:personnelResourcesNonfundingObstacleOtherReason] conditional_fields.non_personnel_resources_funded_amount = [:nonPersonnelResourcesFundedAmount] if [:nonPersonnelResourcesFundedAmount] conditional_fields.non_personnel_resources_cost_code = [:nonPersonnelResourcesCostCode] if [:nonPersonnelResourcesCostCode] conditional_fields.non_personnel_resources_unfunded_amount = [:nonPersonnelResourcesUnfundedAmount] if [:nonPersonnelResourcesUnfundedAmount] conditional_fields.non_personnel_resources_nonfunding_obstacle = [:nonPersonnelResourcesNonfundingObstacle] if [:nonPersonnelResourcesNonfundingObstacle] conditional_fields.non_personnel_resources_nonfunding_obstacle_other_reason = [:nonPersonnelResourcesNonfundingObstacleOtherReason] if [:nonPersonnelResourcesNonfundingObstacleOtherReason] # Add optional fields optional_fields = EmassClient::PoamOptionalFields.new optional_fields.external_uid = [:externalUid] if [:externalUid] optional_fields.control_acronym = [:controlAcronym] if [:controlAcronym] optional_fields.assessment_procedure = [:assessmentProcedure] if [:assessmentProcedure] optional_fields.security_checks = [:securityChecks] if [:securityChecks] optional_fields.raw_severity = [:rawSeverity] if [:rawSeverity] optional_fields.relevance_of_threat = [:relevanceOfThreat] if [:relevanceOfThreat] optional_fields.likelihood = [:likelihood] if [:likelihood] optional_fields.impact = [:impact] if [:impact] optional_fields.impact_description = [:impactDescription] if [:impactDescription] optional_fields.residual_risk_level = [:residualRiskLevel] if [:residualRiskLevel] optional_fields.recommendations = [:recommendations] if [:recommendations] optional_fields.mitigations = [:mitigations] if [:mitigations] optional_fields.resulting_residual_risk_level_after_proposed_mitigations = [:resultingResidualRiskLevelAfterProposedMitigations] if [:resultingResidualRiskLevelAfterProposedMitigations] optional_fields.predisposing_conditions = [:predisposingConditions] if [:predisposingConditions] optional_fields.threat_description = [:threatDescription] if [:threatDescription] optional_fields.devices_affected = [:devicesAffected] if [:devicesAffected] # Build the milestones object array milestone = {} milestone['description'] = [:milestone]['description'] if [:milestone]['description'] milestone['scheduledCompletionDate'] = [:milestone]['scheduledCompletionDate'].to_f if [:milestone]['scheduledCompletionDate'] milestone_array = Array.new(1, milestone) # Build the request body body = {} body = body.merge(require_fields) body = body.merge(optional_fields) body = body.merge(conditional_fields) body = body.merge({ milestones: milestone_array }) body_array = Array.new(1, body) begin result = EmassClient::POAMApi.new.add_poam_by_system_id([:systemId], body_array) puts to_output_hash(result).green rescue EmassClient::ApiError => e puts 'Exception when calling POAMApi->add_poam_by_system_id'.red puts to_output_hash(e) end end |
#byPoamId ⇒ Object
329 330 331 332 333 334 335 |
# File 'lib/emasser/get.rb', line 329 def byPoamId result = EmassClient::POAMApi.new.get_system_poams_by_poam_id([:systemId], [:poamId]) puts to_output_hash(result).green rescue EmassClient::ApiError => e puts 'Exception when calling POAMApi->get_system_poams_by_poam_id'.red puts to_output_hash(e) end |
#forSystem ⇒ Object
308 309 310 311 312 313 314 315 316 317 318 319 |
# File 'lib/emasser/get.rb', line 308 def forSystem = (@_initializer).keys = to_input_hash(, ) begin result = EmassClient::POAMApi.new.get_system_poams([:systemId], ) puts to_output_hash(result).green rescue EmassClient::ApiError => e puts 'Exception when calling POAMApi->get_system_poams'.red puts to_output_hash(e) end end |
#remove ⇒ Object
57 58 59 60 61 62 63 64 65 66 67 |
# File 'lib/emasser/delete.rb', line 57 def remove body = EmassClient::PoamRequestDeleteBodyInner.new body.poam_id = [:poamId] body_array = Array.new(1, body) result = EmassClient::POAMApi.new.delete_poam([:systemId], body_array) puts to_output_hash(result).green rescue EmassClient::ApiError => e puts 'Exception when calling POAMApi->delete_poam'.red puts to_output_hash(e) end |
#update ⇒ Object
rubocop:disable Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity, Metrics/AbcSize
327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 |
# File 'lib/emasser/put.rb', line 327 def update # Check if business logic is satisfied process_business_logic # Required fields require_id_fields = EmassClient::PoamIds.new require_id_fields.poam_id = [:poamId] # API spec states that the displayPoamId is a required field, by backend does not require it require_id_fields.display_poam_id = [:displayPoamId] if [:displayPoamId] require_fields = EmassClient::PoamRequiredFields.new require_fields.status = [:status] require_fields.vulnerability_description = [:vulnerabilityDescription] require_fields. = [:sourceIdentifyingVulnerability] require_fields.poc_organization = [:pocOrganization] require_fields.resources = [:resources] # Required for VA, optional for Army and USCG. - defaults to false require_fields.identified_in_cfo_audit_or_other_review = [:identifiedInCFOAuditOrOtherReview] if [:identifiedInCFOAuditOrOtherReview] # Add conditional fields conditional_fields = EmassClient::PoamConditionalFields.new conditional_fields.poc_first_name = [:pocFirstName] if [:pocFirstName] conditional_fields.poc_last_name = [:pocLastName] if [:pocLastName] conditional_fields.poc_email = [:pocEmail] if [:pocEmail] conditional_fields.poc_phone_number = [:pocPhoneNumber] if [:pocPhoneNumber] conditional_fields.severity = [:severity] if [:severity] conditional_fields.scheduled_completion_date = [:scheduledCompletionDate] if [:scheduledCompletionDate] conditional_fields.completion_date = [:completionDate] if [:completionDate] conditional_fields.comments = [:comments] if [:comments] conditional_fields.personnel_resources_funded_base_hours = [:personnelResourcesFundedBaseHours] if [:personnelResourcesFundedBaseHours] conditional_fields.personnel_resources_cost_code = [:personnelResourcesCostCode] if [:personnelResourcesCostCode] conditional_fields.personnel_resources_unfunded_base_hours = [:personnelResourcesUnfundedBaseHours] if [:personnelResourcesUnfundedBaseHours] conditional_fields.personnel_resources_nonfunding_obstacle = [:personnelResourcesNonfundingObstacle] if [:personnelResourcesNonfundingObstacle] conditional_fields.personnel_resources_nonfunding_obstacle_other_reason = [:personnelResourcesNonfundingObstacleOtherReason] if [:personnelResourcesNonfundingObstacleOtherReason] conditional_fields.non_personnel_resources_funded_amount = [:nonPersonnelResourcesFundedAmount] if [:nonPersonnelResourcesFundedAmount] conditional_fields.non_personnel_resources_cost_code = [:nonPersonnelResourcesCostCode] if [:nonPersonnelResourcesCostCode] conditional_fields.non_personnel_resources_unfunded_amount = [:nonPersonnelResourcesUnfundedAmount] if [:nonPersonnelResourcesUnfundedAmount] conditional_fields.non_personnel_resources_nonfunding_obstacle = [:nonPersonnelResourcesNonfundingObstacle] if [:nonPersonnelResourcesNonfundingObstacle] conditional_fields.non_personnel_resources_nonfunding_obstacle_other_reason = [:nonPersonnelResourcesNonfundingObstacleOtherReason] if [:nonPersonnelResourcesNonfundingObstacleOtherReason] # Add optional fields optional_fields = EmassClient::PoamOptionalFields.new optional_fields.external_uid = [:externalUid] if [:externalUid] optional_fields.control_acronym = [:controlAcronym] if [:controlAcronym] optional_fields.assessment_procedure = [:assessmentProcedure] if [:assessmentProcedure] optional_fields.security_checks = [:securityChecks] if [:securityChecks] optional_fields.raw_severity = [:rawSeverity] if [:rawSeverity] optional_fields.relevance_of_threat = [:relevanceOfThreat] if [:relevanceOfThreat] optional_fields.likelihood = [:likelihood] if [:likelihood] optional_fields.impact = [:impact] if [:impact] optional_fields.impact_description = [:impactDescription] if [:impactDescription] optional_fields.residual_risk_level = [:residualRiskLevel] if [:residualRiskLevel] optional_fields.recommendations = [:recommendations] if [:recommendations] optional_fields.mitigations = [:mitigations] if [:mitigations] optional_fields.resulting_residual_risk_level_after_proposed_mitigations = [:resultingResidualRiskLevelAfterProposedMitigations] if [:resultingResidualRiskLevelAfterProposedMitigations] optional_fields.predisposing_conditions = [:predisposingConditions] if [:predisposingConditions] optional_fields.threat_description = [:threatDescription] if [:threatDescription] optional_fields.devices_affected = [:devicesAffected] if [:devicesAffected] # Build the milestones object array milestone = {} milestone['milestoneId'] = [:milestone]['milestoneId'].to_i if [:milestone]['milestoneId'] milestone['description'] = [:milestone]['description'] if [:milestone]['description'] milestone['scheduledCompletionDate'] = [:milestone]['scheduledCompletionDate'].to_f if [:milestone]['scheduledCompletionDate'] milestone_array = Array.new(1, milestone) # Build the request body body = {} body = body.merge(require_id_fields) body = body.merge(require_fields) body = body.merge(optional_fields) body = body.merge(conditional_fields) body = body.merge({ milestones: milestone_array }) body_array = Array.new(1, body) begin result = EmassClient::POAMApi.new.update_poam_by_system_id([:systemId], body_array) puts to_output_hash(result).green rescue EmassClient::ApiError => e puts 'Exception when calling POAMApi->update_poam_by_system_id'.red puts to_output_hash(e) end end |