emass_client 3.4.0 → 3.9.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (124) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +23 -11
  3. data/lib/emass_client/api/artifacts_api.rb +7 -4
  4. data/lib/emass_client/api/artifacts_export_api.rb +2 -2
  5. data/lib/emass_client/api/cac_api.rb +2 -2
  6. data/lib/emass_client/api/{cloud_resources_api.rb → cloud_resource_results_api.rb} +8 -8
  7. data/lib/emass_client/api/cmmc_assessments_api.rb +2 -2
  8. data/lib/emass_client/api/{containers_api.rb → container_scan_results_api.rb} +8 -8
  9. data/lib/emass_client/api/controls_api.rb +2 -2
  10. data/lib/emass_client/api/dashboards_api.rb +868 -90
  11. data/lib/emass_client/api/milestones_api.rb +2 -2
  12. data/lib/emass_client/api/pac_api.rb +2 -2
  13. data/lib/emass_client/api/poam_api.rb +2 -2
  14. data/lib/emass_client/api/registration_api.rb +8 -19
  15. data/lib/emass_client/api/static_code_scans_api.rb +2 -2
  16. data/lib/emass_client/api/system_roles_api.rb +2 -2
  17. data/lib/emass_client/api/systems_api.rb +2 -2
  18. data/lib/emass_client/api/test_api.rb +2 -2
  19. data/lib/emass_client/api/test_results_api.rb +2 -2
  20. data/lib/emass_client/api/workflow_definitions_api.rb +2 -2
  21. data/lib/emass_client/api/workflow_instances_api.rb +2 -2
  22. data/lib/emass_client/api_client.rb +2 -2
  23. data/lib/emass_client/api_error.rb +3 -2
  24. data/lib/emass_client/configuration.rb +8 -8
  25. data/lib/emass_client/models/artifacts_get.rb +44 -68
  26. data/lib/emass_client/models/artifacts_request_delete_body_inner.rb +2 -2
  27. data/lib/emass_client/models/artifacts_response_del.rb +2 -2
  28. data/lib/emass_client/models/artifacts_response_del_data_inner.rb +2 -2
  29. data/lib/emass_client/models/artifacts_response_get.rb +2 -2
  30. data/lib/emass_client/models/artifacts_response_put_post.rb +2 -2
  31. data/lib/emass_client/models/artifacts_response_put_post_data_inner.rb +2 -2
  32. data/lib/emass_client/models/cac_get.rb +2 -2
  33. data/lib/emass_client/models/cac_response_get.rb +2 -2
  34. data/lib/emass_client/models/cac_response_post.rb +2 -2
  35. data/lib/emass_client/models/cac_response_post_data_inner.rb +2 -2
  36. data/lib/emass_client/models/cloud_resources_post.rb +2 -2
  37. data/lib/emass_client/models/cloud_resources_response_post.rb +2 -2
  38. data/lib/emass_client/models/cmmc_get.rb +111 -35
  39. data/lib/emass_client/models/cmmc_response_get.rb +2 -2
  40. data/lib/emass_client/models/connectivity_ccsd.rb +2 -2
  41. data/lib/emass_client/models/containers_resources_post.rb +2 -2
  42. data/lib/emass_client/models/containers_response_post.rb +2 -2
  43. data/lib/emass_client/models/controls_get.rb +2 -2
  44. data/lib/emass_client/models/controls_put.rb +2 -2
  45. data/lib/emass_client/models/controls_response_get.rb +2 -2
  46. data/lib/emass_client/models/controls_response_put.rb +2 -2
  47. data/lib/emass_client/models/definition_transitions.rb +2 -2
  48. data/lib/emass_client/models/instances_transitions.rb +2 -2
  49. data/lib/emass_client/models/milestone_response_get.rb +2 -2
  50. data/lib/emass_client/models/milestone_response_get_milestone.rb +2 -2
  51. data/lib/emass_client/models/milestone_response_post.rb +2 -2
  52. data/lib/emass_client/models/milestone_response_put.rb +2 -2
  53. data/lib/emass_client/models/milestones_get.rb +2 -2
  54. data/lib/emass_client/models/milestones_put_post_delete.rb +2 -2
  55. data/lib/emass_client/models/milestones_request_delete_body_inner.rb +2 -2
  56. data/lib/emass_client/models/milestones_required_post.rb +2 -2
  57. data/lib/emass_client/models/milestones_required_put.rb +2 -2
  58. data/lib/emass_client/models/pac_get.rb +2 -2
  59. data/lib/emass_client/models/pac_post.rb +2 -2
  60. data/lib/emass_client/models/pac_response_get.rb +2 -2
  61. data/lib/emass_client/models/pac_response_post.rb +2 -2
  62. data/lib/emass_client/models/poam_get.rb +2 -2
  63. data/lib/emass_client/models/poam_post_put_del.rb +2 -2
  64. data/lib/emass_client/models/poam_request_delete_body_inner.rb +2 -2
  65. data/lib/emass_client/models/poam_response_delete.rb +2 -2
  66. data/lib/emass_client/models/poam_response_get_poams.rb +2 -2
  67. data/lib/emass_client/models/poam_response_get_systems.rb +2 -2
  68. data/lib/emass_client/models/poam_response_post.rb +2 -2
  69. data/lib/emass_client/models/poam_response_put.rb +2 -2
  70. data/lib/emass_client/models/register.rb +2 -2
  71. data/lib/emass_client/models/register_data.rb +2 -2
  72. data/lib/emass_client/models/register_user_request_post_body.rb +2 -2
  73. data/lib/emass_client/models/response200.rb +2 -2
  74. data/lib/emass_client/models/response201.rb +2 -2
  75. data/lib/emass_client/models/response201_meta.rb +2 -2
  76. data/lib/emass_client/models/response400.rb +2 -2
  77. data/lib/emass_client/models/response400_meta.rb +2 -2
  78. data/lib/emass_client/models/response401.rb +2 -2
  79. data/lib/emass_client/models/response401_meta.rb +2 -2
  80. data/lib/emass_client/models/response403.rb +2 -2
  81. data/lib/emass_client/models/response403_meta.rb +2 -2
  82. data/lib/emass_client/models/response404.rb +2 -2
  83. data/lib/emass_client/models/response405.rb +2 -2
  84. data/lib/emass_client/models/response405_meta.rb +2 -2
  85. data/lib/emass_client/models/response411.rb +2 -2
  86. data/lib/emass_client/models/response411_meta.rb +2 -2
  87. data/lib/emass_client/models/response490.rb +2 -2
  88. data/lib/emass_client/models/response490_meta.rb +2 -2
  89. data/lib/emass_client/models/response500.rb +2 -2
  90. data/lib/emass_client/models/response500_meta.rb +2 -2
  91. data/lib/emass_client/models/role_category.rb +2 -2
  92. data/lib/emass_client/models/roles.rb +2 -2
  93. data/lib/emass_client/models/ssps.rb +2 -2
  94. data/lib/emass_client/models/stage.rb +2 -2
  95. data/lib/emass_client/models/static_code_application.rb +2 -2
  96. data/lib/emass_client/models/static_code_post.rb +2 -2
  97. data/lib/emass_client/models/static_code_request_post_body.rb +2 -2
  98. data/lib/emass_client/models/static_code_request_post_body_application.rb +2 -2
  99. data/lib/emass_client/models/static_code_response_post.rb +2 -2
  100. data/lib/emass_client/models/success200_response.rb +2 -2
  101. data/lib/emass_client/models/success200_response_data_inner.rb +2 -2
  102. data/lib/emass_client/models/system_response.rb +2 -2
  103. data/lib/emass_client/models/system_roles_category_response.rb +2 -2
  104. data/lib/emass_client/models/system_roles_response.rb +2 -2
  105. data/lib/emass_client/models/system_roles_response_data_inner.rb +2 -2
  106. data/lib/emass_client/models/systems.rb +399 -71
  107. data/lib/emass_client/models/systems_response.rb +2 -2
  108. data/lib/emass_client/models/test.rb +2 -2
  109. data/lib/emass_client/models/test_data.rb +2 -2
  110. data/lib/emass_client/models/test_results_get.rb +2 -2
  111. data/lib/emass_client/models/test_results_post.rb +2 -2
  112. data/lib/emass_client/models/test_results_response_get.rb +2 -2
  113. data/lib/emass_client/models/test_results_response_post.rb +2 -2
  114. data/lib/emass_client/models/users.rb +2 -2
  115. data/lib/emass_client/models/workflow_definition_get.rb +2 -2
  116. data/lib/emass_client/models/workflow_definition_response_get.rb +2 -2
  117. data/lib/emass_client/models/workflow_instance_get.rb +2 -2
  118. data/lib/emass_client/models/workflow_instance_response_get.rb +2 -2
  119. data/lib/emass_client/models/workflow_instances_get.rb +2 -2
  120. data/lib/emass_client/models/workflow_instances_response_get.rb +2 -2
  121. data/lib/emass_client/models/workflow_instances_response_get_pagination.rb +2 -2
  122. data/lib/emass_client/version.rb +3 -3
  123. data/lib/emass_client.rb +4 -4
  124. metadata +8 -31
@@ -3,10 +3,10 @@
3
3
 
4
4
  #The Enterprise Mission Assurance Support Service (eMASS) Representational State Transfer (REST) Application Programming Interface (API) enables users to perform assessments and complete actions associated with system records. <strong>Register External Application (that use the eMASS API)</strong></br> New users will need to [register](https://nisp.emass.apps.mil/Content/Help/jobaids/eMASS_OT_NewUser_Job_Aid.pdf) an API key with the eMASS development team prior to accessing the site for the first time. The eMASS REST API requires a client certificate (SSL/TLS, DoD PKI only). Use the `Registration` endpoint to register the client certificate.</br></br> Every call to the eMASS REST API will require the use of the agreed upon public key certificate and API key. The API key must be provided in the request header for all endpoint calls (api-key). If the service receives an untrusted certificate or API key, a 401 error response code will be returned along with an error message.</br></br> <strong>Available Request Headers</strong></br> <table> <tr> <th align=left>key</th> <th align=left>Example Value</th> <th align=left>Description</th> </tr> <tr> <td>`api-key`</td> <td>api-key-provided-by-emass</td> <td>This API key must be provided in the request header for all endpoint calls</td> </tr> <tr> <td>`user-uid`</td> <td>USER.UID.KEY</td> <td>This User unique identifier key must be provided in the request header for all PUT, POST, and DELETE endpoint calls</td> </tr> <tr> <td></td><td></td> <td> Note: For DoD users this is the DoD ID Number (EIDIPI) on their DoD CAC </td> </tr> </table> </br><strong>Approve API Client for Actionable Requests</strong></br> Users are required to log-in to eMASS and grant permissions for a client to update data within eMASS on their behalf. This is only required for actionable requests (PUT, POST, DELETE). The Registration Endpoint and all GET requests can be accessed without completing this process with the correct permissions. Please note that leaving a field parameter blank (for PUT/POST requests) has the potential to clear information in the active eMASS records. To establish an account with eMASS and/or acquire an api-key/user-uid, contact one of the listed POC:
5
5
 
6
- The version of the OpenAPI document: v3.4
6
+ The version of the OpenAPI document: v3.9
7
7
  Contact: disa.meade.id.mbx.emass-tier-iii-support@mail.mil
8
8
  Generated by: https://openapi-generator.tech
9
- OpenAPI Generator version: 6.1.1-SNAPSHOT
9
+ OpenAPI Generator version: 7.0.0-SNAPSHOT
10
10
 
11
11
  =end
12
12
 
@@ -15,6 +15,36 @@ require 'time'
15
15
 
16
16
  module EmassClient
17
17
  class Systems
18
+ # [Read-Only] Date the system was registered into eMASS.
19
+ attr_accessor :registration_completion_date
20
+
21
+ # [Read-Only] Identifies the current System Acquisition Phase for programs of record.
22
+ attr_accessor :system_life_cycle_acquisition_phase
23
+
24
+ # [Read-Only] Lists applicable tracking indicator(s).
25
+ attr_accessor :special_type
26
+
27
+ # [Read-Only] Provides a brief reason for any tracking indicator(s) selected.
28
+ attr_accessor :special_type_description
29
+
30
+ # [Read-Only] Identifies the appropriate portfolio or capability area. Navy only.
31
+ attr_accessor :mission_portfolio
32
+
33
+ # [Read-Only] Indicates whether Naval Nuclear Propulsion Information (NNPI) is stored, disseminated, or processed through this system. Navy only.
34
+ attr_accessor :is_nnpi
35
+
36
+ # [Read-Only] Indicates whether the system is pursuing an RBC authorization. Navy only.
37
+ attr_accessor :is_rbc
38
+
39
+ # [Read-Only] Indicates if the system has a waiver from OPNAV N2N6G (DDCIO(N)) to proceed with a DIACAP accreditation. Navy and DIACAP only.
40
+ attr_accessor :is_waiver
41
+
42
+ # [Read-Only] The system record's Program Office. Navy only.
43
+ attr_accessor :program_office
44
+
45
+ # [Read-Only] Vulnerability Remediation Asset Manager (VRAM) identification number. \"N/A\" indicates the system record is not currently registered in VRAM. Navy only.
46
+ attr_accessor :vram_id
47
+
18
48
  # [Read-only] Unique system record identifier.
19
49
  attr_accessor :system_id
20
50
 
@@ -33,11 +63,11 @@ module EmassClient
33
63
  # [Read-only] Description of the system record.
34
64
  attr_accessor :description
35
65
 
36
- # [Read-only] Owning organization of the system record.
37
- attr_accessor :system_owner
66
+ # [Read-Only] Name of the top-level component that owns the system.
67
+ attr_accessor :instance
38
68
 
39
- # [Read-only] Name of the top-level component that owns the system (e.g. Navy, Air Force, Army, etc..).
40
- attr_accessor :organization_name
69
+ # [Read-Only] Owning organization of the system record. Values match the eMASS instance Organizational Hierarchy.
70
+ attr_accessor :owning_organization
41
71
 
42
72
  # [Read-only] Secondary organization that owns the system record (i.e. Sub-Organization-level.
43
73
  attr_accessor :secondary_organization
@@ -45,7 +75,7 @@ module EmassClient
45
75
  # [Read-only] Version/Release Number of system record.
46
76
  attr_accessor :version_release_no
47
77
 
48
- # [Read-only] Type of the system record. RMF values include the following options (IS Major Application, IS Enclave, Platform IT System). DIACAP values include the following options (Platform IT, Interconnection, AIS Application)
78
+ # [Read-only] Type of the system record. RMF values include the following options (IS Major Application, IS Enclave, Platform IT System). DIACAP values include the following options (Platform IT Interconnection, AIS Application, Outsourced IT-Based Process (DoD-controlled), Enclave, Outsourced IT-Based Process (service provider shared))
49
79
  attr_accessor :system_type
50
80
 
51
81
  # [Read-only] Is the system record a National Security System?
@@ -63,6 +93,12 @@ module EmassClient
63
93
  # [Read-only] DITPR ID of the system record.
64
94
  attr_accessor :ditpr_id
65
95
 
96
+ # [Read-Only] Same field as ditprId but displays as apmsId for Army only.
97
+ attr_accessor :apms_id
98
+
99
+ # [Read-Only] Same field as ditprId but displays as vasiId for VA only.
100
+ attr_accessor :vasi_id
101
+
66
102
  # [Read-only] Authorization Status of the system record.
67
103
  attr_accessor :authorization_status
68
104
 
@@ -84,13 +120,13 @@ module EmassClient
84
120
  # [Read-only] Approval date of the system's RMF Security Plan.
85
121
  attr_accessor :security_plan_approval_date
86
122
 
87
- # [Read-only] Mission Criticality of the system record. Values include the following options (Mission Critical (MC), Mission Essential (ME), Mission Support (MS).
123
+ # [Read-only] Mission Criticality of the system record.
88
124
  attr_accessor :mission_criticality
89
125
 
90
- # [Read-only] Geographical Association of the system record (VA only).
126
+ # [Read-only] Geographical Association of the system record.
91
127
  attr_accessor :geographical_association
92
128
 
93
- # [Read-only] Ownership of the system record (VA only).
129
+ # [Read-only] Ownership of the system record.
94
130
  attr_accessor :system_ownership
95
131
 
96
132
  # [Read-only] Governing Mission Area of the system record.
@@ -201,6 +237,66 @@ module EmassClient
201
237
  # [Read-only] Indicates if the system reports to the DoD Cyber Hygiene Scorecard.
202
238
  attr_accessor :reports_for_scorecard
203
239
 
240
+ # [Read-Only] The overall classification level of information that the System is approved to collect, process, store, and/or distribute.
241
+ attr_accessor :highest_system_data_classification
242
+
243
+ # [Read-Only] Same field as highestSystemDataClassification, but displays as overallClassification for NISP only.
244
+ attr_accessor :overall_classification
245
+
246
+ # [Read-Only] Indicates if the system contains High Value Assets. Does not display if value is null
247
+ attr_accessor :is_hva
248
+
249
+ # [Read-Only] Per OMB Circular A-127, a financial management system includes the core financial systems and the financial portions of mixed systems necessary to support financial management, including automated and manual processes, procedures, and controls, data, hardware, software, and support personnel dedicated to the operation and maintenance of system functions. The following are examples of financial management systems: core financial systems, procurement systems, loan systems, grants systems, payroll systems, budget formulation systems, billing systems, and travel systems.
250
+ attr_accessor :is_financial_management
251
+
252
+ # [Read-Only] A reciprocity system is any information system that is part of a mutual agreement among participating organizations to accept each other's security assessments in order to reuse information system resources and/or to accept each other's assessed security posture in order to share information.
253
+ attr_accessor :is_reciprocity
254
+
255
+ # [Read-Only] The following justifications are acceptable for exemption from reciprocity: (a) the existence of the system is classified (not the data, but the existence of the system) or (b) the system's authorization to operate is in the process of being pulled (e.g. DATO, Decommission).
256
+ attr_accessor :reciprocity_exemption
257
+
258
+ # [Read-Only] Is this a cloud-based IS?
259
+ attr_accessor :cloud_computing
260
+
261
+ # [Read-Only] Values include the following: (Hybrid, Private, Public)
262
+ attr_accessor :cloud_type
263
+
264
+ # [Read-Only] The Authority to Connect decision. Values include the following: (Authority to Connect (ATC), Denial of Authority to Connect (DATC), Not Yet Connected, Decommissioned)
265
+ attr_accessor :atc_status
266
+
267
+ # [Read-Only] Software as a Service (SaaS) cloud service model.
268
+ attr_accessor :is_saa_s
269
+
270
+ # [Read-Only] Platform as a Service (PaaS) cloud service model.
271
+ attr_accessor :is_paa_s
272
+
273
+ # [Read-Only] Infrastructure as a Service (IaaS) cloud service model.
274
+ attr_accessor :is_iaa_s
275
+
276
+ # [Read-Only] Free text field to include other cloud service models.
277
+ attr_accessor :other_service_models
278
+
279
+ # [Read-Only] Indicates the date by which the System needs to be deployed to a production environment.
280
+ attr_accessor :need_date
281
+
282
+ # [Read-Only] The overall risk score of the system
283
+ attr_accessor :overall_risk_score
284
+
285
+ # [Read-Only] Identifies whether a System has been designated as High Risk Review. USCG and Navy only.
286
+ attr_accessor :is_hrr
287
+
288
+ # [Read-Only] The Connectivity Authorization Date.
289
+ attr_accessor :atc_date
290
+
291
+ # [Read-Only] The Connectivity Authorization Termination Date.
292
+ attr_accessor :atc_termination_date
293
+
294
+ # [Read-Only] Indicate the date by which the System needs to be deployed to a production environment. VA only.
295
+ attr_accessor :system_development_life_cycle
296
+
297
+ # [Read-Only] Is this IS reportable per Federal Information Security Management Act (FISMA) established requirements? VA only
298
+ attr_accessor :is_fisma_reportable
299
+
204
300
  attr_accessor :package
205
301
 
206
302
  attr_accessor :connectivity_ccsd
@@ -230,14 +326,24 @@ module EmassClient
230
326
  # Attribute mapping from ruby-style variable name to JSON key.
231
327
  def self.attribute_map
232
328
  {
329
+ :'registration_completion_date' => :'registrationCompletionDate',
330
+ :'system_life_cycle_acquisition_phase' => :'systemLifeCycleAcquisitionPhase',
331
+ :'special_type' => :'specialType',
332
+ :'special_type_description' => :'specialTypeDescription',
333
+ :'mission_portfolio' => :'missionPortfolio',
334
+ :'is_nnpi' => :'isNNPI',
335
+ :'is_rbc' => :'isRBC',
336
+ :'is_waiver' => :'isWaiver',
337
+ :'program_office' => :'programOffice',
338
+ :'vram_id' => :'vramId',
233
339
  :'system_id' => :'systemId',
234
340
  :'policy' => :'policy',
235
341
  :'registration_type' => :'registrationType',
236
342
  :'name' => :'name',
237
343
  :'acronym' => :'acronym',
238
344
  :'description' => :'description',
239
- :'system_owner' => :'systemOwner',
240
- :'organization_name' => :'organizationName',
345
+ :'instance' => :'instance',
346
+ :'owning_organization' => :'owningOrganization',
241
347
  :'secondary_organization' => :'secondaryOrganization',
242
348
  :'version_release_no' => :'versionReleaseNo',
243
349
  :'system_type' => :'systemType',
@@ -246,6 +352,8 @@ module EmassClient
246
352
  :'coams_id' => :'coamsId',
247
353
  :'is_type_authorization' => :'isTypeAuthorization',
248
354
  :'ditpr_id' => :'ditprId',
355
+ :'apms_id' => :'apmsId',
356
+ :'vasi_id' => :'vasiId',
249
357
  :'authorization_status' => :'authorizationStatus',
250
358
  :'authorization_date' => :'authorizationDate',
251
359
  :'authorization_termination_date' => :'authorizationTerminationDate',
@@ -292,6 +400,26 @@ module EmassClient
292
400
  :'current_rmf_lifecycle_step' => :'currentRmfLifecycleStep',
293
401
  :'other_information' => :'otherInformation',
294
402
  :'reports_for_scorecard' => :'reportsForScorecard',
403
+ :'highest_system_data_classification' => :'highestSystemDataClassification',
404
+ :'overall_classification' => :'overallClassification',
405
+ :'is_hva' => :'isHVA',
406
+ :'is_financial_management' => :'isFinancialManagement',
407
+ :'is_reciprocity' => :'isReciprocity',
408
+ :'reciprocity_exemption' => :'reciprocityExemption',
409
+ :'cloud_computing' => :'cloudComputing',
410
+ :'cloud_type' => :'cloudType',
411
+ :'atc_status' => :'atcStatus',
412
+ :'is_saa_s' => :'isSaaS',
413
+ :'is_paa_s' => :'isPaaS',
414
+ :'is_iaa_s' => :'isIaaS',
415
+ :'other_service_models' => :'otherServiceModels',
416
+ :'need_date' => :'needDate',
417
+ :'overall_risk_score' => :'overallRiskScore',
418
+ :'is_hrr' => :'isHRR',
419
+ :'atc_date' => :'atcDate',
420
+ :'atc_termination_date' => :'atcTerminationDate',
421
+ :'system_development_life_cycle' => :'systemDevelopmentLifeCycle',
422
+ :'is_fisma_reportable' => :'isFISMAReportable',
295
423
  :'package' => :'package',
296
424
  :'connectivity_ccsd' => :'connectivityCcsd'
297
425
  }
@@ -305,14 +433,24 @@ module EmassClient
305
433
  # Attribute type mapping.
306
434
  def self.openapi_types
307
435
  {
436
+ :'registration_completion_date' => :'Integer',
437
+ :'system_life_cycle_acquisition_phase' => :'String',
438
+ :'special_type' => :'String',
439
+ :'special_type_description' => :'String',
440
+ :'mission_portfolio' => :'String',
441
+ :'is_nnpi' => :'Boolean',
442
+ :'is_rbc' => :'Boolean',
443
+ :'is_waiver' => :'Boolean',
444
+ :'program_office' => :'String',
445
+ :'vram_id' => :'String',
308
446
  :'system_id' => :'Integer',
309
447
  :'policy' => :'String',
310
448
  :'registration_type' => :'String',
311
449
  :'name' => :'String',
312
450
  :'acronym' => :'String',
313
451
  :'description' => :'String',
314
- :'system_owner' => :'String',
315
- :'organization_name' => :'String',
452
+ :'instance' => :'String',
453
+ :'owning_organization' => :'String',
316
454
  :'secondary_organization' => :'String',
317
455
  :'version_release_no' => :'String',
318
456
  :'system_type' => :'String',
@@ -321,6 +459,8 @@ module EmassClient
321
459
  :'coams_id' => :'Integer',
322
460
  :'is_type_authorization' => :'Boolean',
323
461
  :'ditpr_id' => :'String',
462
+ :'apms_id' => :'String',
463
+ :'vasi_id' => :'String',
324
464
  :'authorization_status' => :'String',
325
465
  :'authorization_date' => :'Integer',
326
466
  :'authorization_termination_date' => :'Integer',
@@ -367,6 +507,26 @@ module EmassClient
367
507
  :'current_rmf_lifecycle_step' => :'String',
368
508
  :'other_information' => :'String',
369
509
  :'reports_for_scorecard' => :'Boolean',
510
+ :'highest_system_data_classification' => :'String',
511
+ :'overall_classification' => :'String',
512
+ :'is_hva' => :'Boolean',
513
+ :'is_financial_management' => :'Boolean',
514
+ :'is_reciprocity' => :'Boolean',
515
+ :'reciprocity_exemption' => :'String',
516
+ :'cloud_computing' => :'Boolean',
517
+ :'cloud_type' => :'String',
518
+ :'atc_status' => :'String',
519
+ :'is_saa_s' => :'Boolean',
520
+ :'is_paa_s' => :'Boolean',
521
+ :'is_iaa_s' => :'Boolean',
522
+ :'other_service_models' => :'String',
523
+ :'need_date' => :'Integer',
524
+ :'overall_risk_score' => :'String',
525
+ :'is_hrr' => :'Boolean',
526
+ :'atc_date' => :'Integer',
527
+ :'atc_termination_date' => :'Integer',
528
+ :'system_development_life_cycle' => :'String',
529
+ :'is_fisma_reportable' => :'Boolean',
370
530
  :'package' => :'Array<PacGet>',
371
531
  :'connectivity_ccsd' => :'Array<ConnectivityCcsd>'
372
532
  }
@@ -375,13 +535,23 @@ module EmassClient
375
535
  # List of attributes with nullable: true
376
536
  def self.openapi_nullable
377
537
  Set.new([
538
+ :'registration_completion_date',
539
+ :'system_life_cycle_acquisition_phase',
540
+ :'special_type',
541
+ :'special_type_description',
542
+ :'mission_portfolio',
543
+ :'is_nnpi',
544
+ :'is_rbc',
545
+ :'is_waiver',
546
+ :'program_office',
547
+ :'vram_id',
378
548
  :'policy',
379
549
  :'registration_type',
380
550
  :'name',
381
551
  :'acronym',
382
552
  :'description',
383
- :'system_owner',
384
- :'organization_name',
553
+ :'instance',
554
+ :'owning_organization',
385
555
  :'secondary_organization',
386
556
  :'version_release_no',
387
557
  :'system_type',
@@ -389,6 +559,8 @@ module EmassClient
389
559
  :'is_public_facing',
390
560
  :'coams_id',
391
561
  :'is_type_authorization',
562
+ :'apms_id',
563
+ :'vasi_id',
392
564
  :'authorization_status',
393
565
  :'authorization_date',
394
566
  :'authorization_termination_date',
@@ -435,6 +607,26 @@ module EmassClient
435
607
  :'current_rmf_lifecycle_step',
436
608
  :'other_information',
437
609
  :'reports_for_scorecard',
610
+ :'highest_system_data_classification',
611
+ :'overall_classification',
612
+ :'is_hva',
613
+ :'is_financial_management',
614
+ :'is_reciprocity',
615
+ :'reciprocity_exemption',
616
+ :'cloud_computing',
617
+ :'cloud_type',
618
+ :'atc_status',
619
+ :'is_saa_s',
620
+ :'is_paa_s',
621
+ :'is_iaa_s',
622
+ :'other_service_models',
623
+ :'need_date',
624
+ :'overall_risk_score',
625
+ :'is_hrr',
626
+ :'atc_date',
627
+ :'atc_termination_date',
628
+ :'system_development_life_cycle',
629
+ :'is_fisma_reportable',
438
630
  :'package',
439
631
  :'connectivity_ccsd'
440
632
  ])
@@ -455,6 +647,46 @@ module EmassClient
455
647
  h[k.to_sym] = v
456
648
  }
457
649
 
650
+ if attributes.key?(:'registration_completion_date')
651
+ self.registration_completion_date = attributes[:'registration_completion_date']
652
+ end
653
+
654
+ if attributes.key?(:'system_life_cycle_acquisition_phase')
655
+ self.system_life_cycle_acquisition_phase = attributes[:'system_life_cycle_acquisition_phase']
656
+ end
657
+
658
+ if attributes.key?(:'special_type')
659
+ self.special_type = attributes[:'special_type']
660
+ end
661
+
662
+ if attributes.key?(:'special_type_description')
663
+ self.special_type_description = attributes[:'special_type_description']
664
+ end
665
+
666
+ if attributes.key?(:'mission_portfolio')
667
+ self.mission_portfolio = attributes[:'mission_portfolio']
668
+ end
669
+
670
+ if attributes.key?(:'is_nnpi')
671
+ self.is_nnpi = attributes[:'is_nnpi']
672
+ end
673
+
674
+ if attributes.key?(:'is_rbc')
675
+ self.is_rbc = attributes[:'is_rbc']
676
+ end
677
+
678
+ if attributes.key?(:'is_waiver')
679
+ self.is_waiver = attributes[:'is_waiver']
680
+ end
681
+
682
+ if attributes.key?(:'program_office')
683
+ self.program_office = attributes[:'program_office']
684
+ end
685
+
686
+ if attributes.key?(:'vram_id')
687
+ self.vram_id = attributes[:'vram_id']
688
+ end
689
+
458
690
  if attributes.key?(:'system_id')
459
691
  self.system_id = attributes[:'system_id']
460
692
  end
@@ -479,12 +711,12 @@ module EmassClient
479
711
  self.description = attributes[:'description']
480
712
  end
481
713
 
482
- if attributes.key?(:'system_owner')
483
- self.system_owner = attributes[:'system_owner']
714
+ if attributes.key?(:'instance')
715
+ self.instance = attributes[:'instance']
484
716
  end
485
717
 
486
- if attributes.key?(:'organization_name')
487
- self.organization_name = attributes[:'organization_name']
718
+ if attributes.key?(:'owning_organization')
719
+ self.owning_organization = attributes[:'owning_organization']
488
720
  end
489
721
 
490
722
  if attributes.key?(:'secondary_organization')
@@ -519,6 +751,14 @@ module EmassClient
519
751
  self.ditpr_id = attributes[:'ditpr_id']
520
752
  end
521
753
 
754
+ if attributes.key?(:'apms_id')
755
+ self.apms_id = attributes[:'apms_id']
756
+ end
757
+
758
+ if attributes.key?(:'vasi_id')
759
+ self.vasi_id = attributes[:'vasi_id']
760
+ end
761
+
522
762
  if attributes.key?(:'authorization_status')
523
763
  self.authorization_status = attributes[:'authorization_status']
524
764
  end
@@ -703,6 +943,86 @@ module EmassClient
703
943
  self.reports_for_scorecard = attributes[:'reports_for_scorecard']
704
944
  end
705
945
 
946
+ if attributes.key?(:'highest_system_data_classification')
947
+ self.highest_system_data_classification = attributes[:'highest_system_data_classification']
948
+ end
949
+
950
+ if attributes.key?(:'overall_classification')
951
+ self.overall_classification = attributes[:'overall_classification']
952
+ end
953
+
954
+ if attributes.key?(:'is_hva')
955
+ self.is_hva = attributes[:'is_hva']
956
+ end
957
+
958
+ if attributes.key?(:'is_financial_management')
959
+ self.is_financial_management = attributes[:'is_financial_management']
960
+ end
961
+
962
+ if attributes.key?(:'is_reciprocity')
963
+ self.is_reciprocity = attributes[:'is_reciprocity']
964
+ end
965
+
966
+ if attributes.key?(:'reciprocity_exemption')
967
+ self.reciprocity_exemption = attributes[:'reciprocity_exemption']
968
+ end
969
+
970
+ if attributes.key?(:'cloud_computing')
971
+ self.cloud_computing = attributes[:'cloud_computing']
972
+ end
973
+
974
+ if attributes.key?(:'cloud_type')
975
+ self.cloud_type = attributes[:'cloud_type']
976
+ end
977
+
978
+ if attributes.key?(:'atc_status')
979
+ self.atc_status = attributes[:'atc_status']
980
+ end
981
+
982
+ if attributes.key?(:'is_saa_s')
983
+ self.is_saa_s = attributes[:'is_saa_s']
984
+ end
985
+
986
+ if attributes.key?(:'is_paa_s')
987
+ self.is_paa_s = attributes[:'is_paa_s']
988
+ end
989
+
990
+ if attributes.key?(:'is_iaa_s')
991
+ self.is_iaa_s = attributes[:'is_iaa_s']
992
+ end
993
+
994
+ if attributes.key?(:'other_service_models')
995
+ self.other_service_models = attributes[:'other_service_models']
996
+ end
997
+
998
+ if attributes.key?(:'need_date')
999
+ self.need_date = attributes[:'need_date']
1000
+ end
1001
+
1002
+ if attributes.key?(:'overall_risk_score')
1003
+ self.overall_risk_score = attributes[:'overall_risk_score']
1004
+ end
1005
+
1006
+ if attributes.key?(:'is_hrr')
1007
+ self.is_hrr = attributes[:'is_hrr']
1008
+ end
1009
+
1010
+ if attributes.key?(:'atc_date')
1011
+ self.atc_date = attributes[:'atc_date']
1012
+ end
1013
+
1014
+ if attributes.key?(:'atc_termination_date')
1015
+ self.atc_termination_date = attributes[:'atc_termination_date']
1016
+ end
1017
+
1018
+ if attributes.key?(:'system_development_life_cycle')
1019
+ self.system_development_life_cycle = attributes[:'system_development_life_cycle']
1020
+ end
1021
+
1022
+ if attributes.key?(:'is_fisma_reportable')
1023
+ self.is_fisma_reportable = attributes[:'is_fisma_reportable']
1024
+ end
1025
+
706
1026
  if attributes.key?(:'package')
707
1027
  if (value = attributes[:'package']).is_a?(Array)
708
1028
  self.package = value
@@ -740,18 +1060,10 @@ module EmassClient
740
1060
  return false unless registration_type_validator.valid?(@registration_type)
741
1061
  system_type_validator = EnumAttributeValidator.new('String', ["IS Major Application", "IS Enclave", "Platform IT", "Platform IT System", "Platform IT Interconnection", "AIS Application", "Outsourced IT-Based Process (DoD-controlled)", "Enclave", "Outsourced IT-Based Process (service provider shared)", "unknown_default_open_api"])
742
1062
  return false unless system_type_validator.valid?(@system_type)
743
- authorization_status_validator = EnumAttributeValidator.new('String', ["Authority to Operate (ATO)", "Authorization to Operate (ATO)", "Authority to Operate with Conditions (ATO w/Conditions)", "Interim Authority to Test (IATT)", "Interim Authority to Operate (IATO)", "Denied Authority to Operate (DATO)", "Denial of Authorization to Operate (DATO)", "Not Yet Authorized", "Decommissioned", "Unaccredited", "unknown_default_open_api"])
744
- return false unless authorization_status_validator.valid?(@authorization_status)
745
1063
  return false if !@authorization_length.nil? && @authorization_length > 1825
746
1064
  return false if !@authorization_length.nil? && @authorization_length < 28
747
1065
  security_plan_approval_status_validator = EnumAttributeValidator.new('String', ["Approved", "Not Yet Approved", "Denied", "unknown_default_open_api"])
748
1066
  return false unless security_plan_approval_status_validator.valid?(@security_plan_approval_status)
749
- mission_criticality_validator = EnumAttributeValidator.new('String', ["Mission Critical (MC)", "Mission Essential (ME)", "Mission Support (MS)", "unknown_default_open_api"])
750
- return false unless mission_criticality_validator.valid?(@mission_criticality)
751
- geographical_association_validator = EnumAttributeValidator.new('String', ["VA Operated IS", "non-VA Operated IS", "unknown_default_open_api"])
752
- return false unless geographical_association_validator.valid?(@geographical_association)
753
- governing_mission_area_validator = EnumAttributeValidator.new('String', ["Business MA (BMA)", "DoD portion of the Intelligence MA (DIMA)", "Enterprise Information Environment MA (EIEMA)", "Warfighting MA (WMA)", "unknown_default_open_api"])
754
- return false unless governing_mission_area_validator.valid?(@governing_mission_area)
755
1067
  primary_control_set_validator = EnumAttributeValidator.new('String', ["NIST SP 800-53 Revision 4", "DoDI 8500.2", "unknown_default_open_api"])
756
1068
  return false unless primary_control_set_validator.valid?(@primary_control_set)
757
1069
  confidentiality_validator = EnumAttributeValidator.new('String', ["High", "Moderate", "Low", "unknown_default_open_api"])
@@ -770,6 +1082,10 @@ module EmassClient
770
1082
  return false unless pia_status_validator.valid?(@pia_status)
771
1083
  current_rmf_lifecycle_step_validator = EnumAttributeValidator.new('String', ["1 - Categorize", "2 - Select", "3 - Implement", "4 - Assess", "5 - Authorize", "6 - Monitor", "unknown_default_open_api"])
772
1084
  return false unless current_rmf_lifecycle_step_validator.valid?(@current_rmf_lifecycle_step)
1085
+ cloud_type_validator = EnumAttributeValidator.new('String', ["Hybrid", "Private", "Public", "unknown_default_open_api"])
1086
+ return false unless cloud_type_validator.valid?(@cloud_type)
1087
+ atc_status_validator = EnumAttributeValidator.new('String', ["Authority to Connect (ATC)", "Denial of Authority to Connect (DATC)", "Not Yet Connected", "Decommissioned", "unknown_default_open_api"])
1088
+ return false unless atc_status_validator.valid?(@atc_status)
773
1089
  true
774
1090
  end
775
1091
 
@@ -803,16 +1119,6 @@ module EmassClient
803
1119
  @system_type = system_type
804
1120
  end
805
1121
 
806
- # Custom attribute writer method checking allowed values (enum).
807
- # @param [Object] authorization_status Object to be assigned
808
- def authorization_status=(authorization_status)
809
- validator = EnumAttributeValidator.new('String', ["Authority to Operate (ATO)", "Authorization to Operate (ATO)", "Authority to Operate with Conditions (ATO w/Conditions)", "Interim Authority to Test (IATT)", "Interim Authority to Operate (IATO)", "Denied Authority to Operate (DATO)", "Denial of Authorization to Operate (DATO)", "Not Yet Authorized", "Decommissioned", "Unaccredited", "unknown_default_open_api"])
810
- unless validator.valid?(authorization_status)
811
- fail ArgumentError, "invalid value for \"authorization_status\", must be one of #{validator.allowable_values}."
812
- end
813
- @authorization_status = authorization_status
814
- end
815
-
816
1122
  # Custom attribute writer method with validation
817
1123
  # @param [Object] authorization_length Value to be assigned
818
1124
  def authorization_length=(authorization_length)
@@ -837,36 +1143,6 @@ module EmassClient
837
1143
  @security_plan_approval_status = security_plan_approval_status
838
1144
  end
839
1145
 
840
- # Custom attribute writer method checking allowed values (enum).
841
- # @param [Object] mission_criticality Object to be assigned
842
- def mission_criticality=(mission_criticality)
843
- validator = EnumAttributeValidator.new('String', ["Mission Critical (MC)", "Mission Essential (ME)", "Mission Support (MS)", "unknown_default_open_api"])
844
- unless validator.valid?(mission_criticality)
845
- fail ArgumentError, "invalid value for \"mission_criticality\", must be one of #{validator.allowable_values}."
846
- end
847
- @mission_criticality = mission_criticality
848
- end
849
-
850
- # Custom attribute writer method checking allowed values (enum).
851
- # @param [Object] geographical_association Object to be assigned
852
- def geographical_association=(geographical_association)
853
- validator = EnumAttributeValidator.new('String', ["VA Operated IS", "non-VA Operated IS", "unknown_default_open_api"])
854
- unless validator.valid?(geographical_association)
855
- fail ArgumentError, "invalid value for \"geographical_association\", must be one of #{validator.allowable_values}."
856
- end
857
- @geographical_association = geographical_association
858
- end
859
-
860
- # Custom attribute writer method checking allowed values (enum).
861
- # @param [Object] governing_mission_area Object to be assigned
862
- def governing_mission_area=(governing_mission_area)
863
- validator = EnumAttributeValidator.new('String', ["Business MA (BMA)", "DoD portion of the Intelligence MA (DIMA)", "Enterprise Information Environment MA (EIEMA)", "Warfighting MA (WMA)", "unknown_default_open_api"])
864
- unless validator.valid?(governing_mission_area)
865
- fail ArgumentError, "invalid value for \"governing_mission_area\", must be one of #{validator.allowable_values}."
866
- end
867
- @governing_mission_area = governing_mission_area
868
- end
869
-
870
1146
  # Custom attribute writer method checking allowed values (enum).
871
1147
  # @param [Object] primary_control_set Object to be assigned
872
1148
  def primary_control_set=(primary_control_set)
@@ -957,19 +1233,49 @@ module EmassClient
957
1233
  @current_rmf_lifecycle_step = current_rmf_lifecycle_step
958
1234
  end
959
1235
 
1236
+ # Custom attribute writer method checking allowed values (enum).
1237
+ # @param [Object] cloud_type Object to be assigned
1238
+ def cloud_type=(cloud_type)
1239
+ validator = EnumAttributeValidator.new('String', ["Hybrid", "Private", "Public", "unknown_default_open_api"])
1240
+ unless validator.valid?(cloud_type)
1241
+ fail ArgumentError, "invalid value for \"cloud_type\", must be one of #{validator.allowable_values}."
1242
+ end
1243
+ @cloud_type = cloud_type
1244
+ end
1245
+
1246
+ # Custom attribute writer method checking allowed values (enum).
1247
+ # @param [Object] atc_status Object to be assigned
1248
+ def atc_status=(atc_status)
1249
+ validator = EnumAttributeValidator.new('String', ["Authority to Connect (ATC)", "Denial of Authority to Connect (DATC)", "Not Yet Connected", "Decommissioned", "unknown_default_open_api"])
1250
+ unless validator.valid?(atc_status)
1251
+ fail ArgumentError, "invalid value for \"atc_status\", must be one of #{validator.allowable_values}."
1252
+ end
1253
+ @atc_status = atc_status
1254
+ end
1255
+
960
1256
  # Checks equality by comparing each attribute.
961
1257
  # @param [Object] Object to be compared
962
1258
  def ==(o)
963
1259
  return true if self.equal?(o)
964
1260
  self.class == o.class &&
1261
+ registration_completion_date == o.registration_completion_date &&
1262
+ system_life_cycle_acquisition_phase == o.system_life_cycle_acquisition_phase &&
1263
+ special_type == o.special_type &&
1264
+ special_type_description == o.special_type_description &&
1265
+ mission_portfolio == o.mission_portfolio &&
1266
+ is_nnpi == o.is_nnpi &&
1267
+ is_rbc == o.is_rbc &&
1268
+ is_waiver == o.is_waiver &&
1269
+ program_office == o.program_office &&
1270
+ vram_id == o.vram_id &&
965
1271
  system_id == o.system_id &&
966
1272
  policy == o.policy &&
967
1273
  registration_type == o.registration_type &&
968
1274
  name == o.name &&
969
1275
  acronym == o.acronym &&
970
1276
  description == o.description &&
971
- system_owner == o.system_owner &&
972
- organization_name == o.organization_name &&
1277
+ instance == o.instance &&
1278
+ owning_organization == o.owning_organization &&
973
1279
  secondary_organization == o.secondary_organization &&
974
1280
  version_release_no == o.version_release_no &&
975
1281
  system_type == o.system_type &&
@@ -978,6 +1284,8 @@ module EmassClient
978
1284
  coams_id == o.coams_id &&
979
1285
  is_type_authorization == o.is_type_authorization &&
980
1286
  ditpr_id == o.ditpr_id &&
1287
+ apms_id == o.apms_id &&
1288
+ vasi_id == o.vasi_id &&
981
1289
  authorization_status == o.authorization_status &&
982
1290
  authorization_date == o.authorization_date &&
983
1291
  authorization_termination_date == o.authorization_termination_date &&
@@ -1024,6 +1332,26 @@ module EmassClient
1024
1332
  current_rmf_lifecycle_step == o.current_rmf_lifecycle_step &&
1025
1333
  other_information == o.other_information &&
1026
1334
  reports_for_scorecard == o.reports_for_scorecard &&
1335
+ highest_system_data_classification == o.highest_system_data_classification &&
1336
+ overall_classification == o.overall_classification &&
1337
+ is_hva == o.is_hva &&
1338
+ is_financial_management == o.is_financial_management &&
1339
+ is_reciprocity == o.is_reciprocity &&
1340
+ reciprocity_exemption == o.reciprocity_exemption &&
1341
+ cloud_computing == o.cloud_computing &&
1342
+ cloud_type == o.cloud_type &&
1343
+ atc_status == o.atc_status &&
1344
+ is_saa_s == o.is_saa_s &&
1345
+ is_paa_s == o.is_paa_s &&
1346
+ is_iaa_s == o.is_iaa_s &&
1347
+ other_service_models == o.other_service_models &&
1348
+ need_date == o.need_date &&
1349
+ overall_risk_score == o.overall_risk_score &&
1350
+ is_hrr == o.is_hrr &&
1351
+ atc_date == o.atc_date &&
1352
+ atc_termination_date == o.atc_termination_date &&
1353
+ system_development_life_cycle == o.system_development_life_cycle &&
1354
+ is_fisma_reportable == o.is_fisma_reportable &&
1027
1355
  package == o.package &&
1028
1356
  connectivity_ccsd == o.connectivity_ccsd
1029
1357
  end
@@ -1037,7 +1365,7 @@ module EmassClient
1037
1365
  # Calculates hash code according to all attributes.
1038
1366
  # @return [Integer] Hash code
1039
1367
  def hash
1040
- [system_id, policy, registration_type, name, acronym, description, system_owner, organization_name, secondary_organization, version_release_no, system_type, is_nss, is_public_facing, coams_id, is_type_authorization, ditpr_id, authorization_status, authorization_date, authorization_termination_date, authorization_length, terms_for_auth, security_plan_approval_status, security_plan_approval_date, mission_criticality, geographical_association, system_ownership, governing_mission_area, primary_functional_area, secondary_functional_area, primary_control_set, confidentiality, integrity, availability, applied_overlays, rmf_activity, cross_domain_ticket, ditpr_don_id, mac, dod_confidentiality, contingency_plan_tested, contingency_plan_test_date, security_review_date, has_open_poam_item, has_open_poam_item90to120_past_scheduled_completion_date, has_open_poam_item120_plus_past_scheudled_completion_date, impact, has_cui, has_pii, has_phi, ppsm_registry_number, interconnected_information_system_and_identifiers, is_pia_required, pia_status, pia_date, user_defined_field1, user_defined_field2, user_defined_field3, user_defined_field4, user_defined_field5, current_rmf_lifecycle_step, other_information, reports_for_scorecard, package, connectivity_ccsd].hash
1368
+ [registration_completion_date, system_life_cycle_acquisition_phase, special_type, special_type_description, mission_portfolio, is_nnpi, is_rbc, is_waiver, program_office, vram_id, system_id, policy, registration_type, name, acronym, description, instance, owning_organization, secondary_organization, version_release_no, system_type, is_nss, is_public_facing, coams_id, is_type_authorization, ditpr_id, apms_id, vasi_id, authorization_status, authorization_date, authorization_termination_date, authorization_length, terms_for_auth, security_plan_approval_status, security_plan_approval_date, mission_criticality, geographical_association, system_ownership, governing_mission_area, primary_functional_area, secondary_functional_area, primary_control_set, confidentiality, integrity, availability, applied_overlays, rmf_activity, cross_domain_ticket, ditpr_don_id, mac, dod_confidentiality, contingency_plan_tested, contingency_plan_test_date, security_review_date, has_open_poam_item, has_open_poam_item90to120_past_scheduled_completion_date, has_open_poam_item120_plus_past_scheudled_completion_date, impact, has_cui, has_pii, has_phi, ppsm_registry_number, interconnected_information_system_and_identifiers, is_pia_required, pia_status, pia_date, user_defined_field1, user_defined_field2, user_defined_field3, user_defined_field4, user_defined_field5, current_rmf_lifecycle_step, other_information, reports_for_scorecard, highest_system_data_classification, overall_classification, is_hva, is_financial_management, is_reciprocity, reciprocity_exemption, cloud_computing, cloud_type, atc_status, is_saa_s, is_paa_s, is_iaa_s, other_service_models, need_date, overall_risk_score, is_hrr, atc_date, atc_termination_date, system_development_life_cycle, is_fisma_reportable, package, connectivity_ccsd].hash
1041
1369
  end
1042
1370
 
1043
1371
  # Builds the object from hash