diff --git a/app/controllers/v0/pension_claims_controller.rb b/app/controllers/v0/pension_claims_controller.rb index 79f039d112d..d84178c373c 100644 --- a/app/controllers/v0/pension_claims_controller.rb +++ b/app/controllers/v0/pension_claims_controller.rb @@ -1,5 +1,7 @@ # frozen_string_literal: true +require 'pension_21p527ez/tag_sentry' + module V0 class PensionClaimsController < ClaimsBaseController service_tag 'pension-application' @@ -45,7 +47,7 @@ def show # Creates and validates an instance of the class, removing any copies of # the form that had been previously saved by the user. def create - PensionBurial::TagSentry.tag_sentry + Pension21p527ez::TagSentry.tag_sentry claim = claim_class.new(form: filtered_params[:form]) user_uuid = current_user&.uuid diff --git a/app/sidekiq/lighthouse/pension_benefit_intake_job.rb b/app/sidekiq/lighthouse/pension_benefit_intake_job.rb index e75b27be4f6..1decf91402d 100644 --- a/app/sidekiq/lighthouse/pension_benefit_intake_job.rb +++ b/app/sidekiq/lighthouse/pension_benefit_intake_job.rb @@ -3,6 +3,7 @@ require 'benefits_intake_service/service' require 'central_mail/datestamp_pdf' require 'simple_forms_api_submission/metadata_validator' +require 'pension_21p527ez/tag_sentry' module Lighthouse class PensionBenefitIntakeJob @@ -33,6 +34,8 @@ class PensionBenefitIntakeError < StandardError; end # @param [Integer] saved_claim_id # rubocop:disable Metrics/MethodLength def perform(saved_claim_id) + Pension21p527ez::TagSentry.tag_sentry + @saved_claim_id = saved_claim_id @claim = SavedClaim::Pension.find(saved_claim_id) raise PensionBenefitIntakeError, "Unable to find SavedClaim::Pension #{saved_claim_id}" unless @claim diff --git a/lib/pension_21p527ez/tag_sentry.rb b/lib/pension_21p527ez/tag_sentry.rb new file mode 100644 index 00000000000..d11a5a5876a --- /dev/null +++ b/lib/pension_21p527ez/tag_sentry.rb @@ -0,0 +1,13 @@ +# frozen_string_literal: true + +module Pension21p527ez + module TagSentry + module_function + + TAG_NAME = 'pension_21p527ez' + + def tag_sentry + Sentry.set_tags(feature: TAG_NAME) + end + end +end diff --git a/modules/claims_api/app/swagger/claims_api/description/v2.md b/modules/claims_api/app/swagger/claims_api/description/v2.md index cb01ef73d9e..50f6fe94d65 100644 --- a/modules/claims_api/app/swagger/claims_api/description/v2.md +++ b/modules/claims_api/app/swagger/claims_api/description/v2.md @@ -6,14 +6,11 @@ The Benefits Claims API Version 2 lets internal consumers: - Automatically establish an Intent To File (21-0966) in VBMS - Automatically establish a disability compensation claim (21-526EZ) in VBMS - Digitally submit supporting documentation for disability compensation claims -- Retrieve the active Power of Attorney for a Veteran +- Retrieve the active Power of Attorney organization of individual with power of attorney for a Veteran +- Automatically establish a power of attorney appointment in VBMS for an accredited organization (VA Form 21-22). +- Automatically establish a power of attorney appointment in VBMS for an accredited individual (VA Form 21-22a). -Additional functionality will be added over time. - -You should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if:  - -- You are a consumer outside of VA and do not have the necessary VA agreements to use this API, and/or -- You want automatic establishment of power of attorney (21-22 or 21-22a) +You should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if you are a consumer outside of VA and do not have the necessary VA agreements to use this API. ## Technical Overview diff --git a/modules/claims_api/app/swagger/claims_api/v2/dev/swagger.json b/modules/claims_api/app/swagger/claims_api/v2/dev/swagger.json index 45d2acf2493..0298380c65d 100644 --- a/modules/claims_api/app/swagger/claims_api/v2/dev/swagger.json +++ b/modules/claims_api/app/swagger/claims_api/v2/dev/swagger.json @@ -3,7 +3,7 @@ "info": { "title": "Benefits Claims", "version": "v2", - "description": "## Background\n\nThe Benefits Claims API Version 2 lets internal consumers: \n\n- Retrieve existing claim information, including status, by claim ID\n- Automatically establish an Intent To File (21-0966) in VBMS\n- Automatically establish a disability compensation claim (21-526EZ) in VBMS\n- Digitally submit supporting documentation for disability compensation claims\n- Retrieve the active Power of Attorney for a Veteran\n\nAdditional functionality will be added over time.\n\nYou should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if: \n\n- You are a consumer outside of VA and do not have the necessary VA agreements to use this API, and/or\n- You want automatic establishment of power of attorney (21-22 or 21-22a)\n \n## Technical Overview\n\nThis API accepts a payload of requests and responses with the payload identifying the claim and Veteran. Responses provide the submission’s processing status. Responses also provide a unique ID which can be used with the appropriate GET endpoint to return detailed, end-to-end claims status tracking. \n\nEnd-to-end claims tracking provides the status of claims as they move through the submission process, but does not return whether the claim was approved or denied. \n\n### Claim statuses\n\nClaims are first submitted by this API and then established in Veterans Benefits Management System (VBMS). A 200 response means that the claim was successfully submitted by the API. It does not mean VA has received the claim. Use the appropriate GET endpoint and the ID returned with your submission response to confirm the status of the submission. Statuses are:\n\n- Pending - the claim is successfully submitted for processing\n- Errored - the submission encountered upstream errors\n- Canceled - the claim was identified as a duplicate or another issue caused the claim to be canceled. For duplicate claims, the tracking of the claim's progress happens under a different Claim ID . \n\nOther statuses this API returns align with the [VA.gov](http://va.gov/) [claim status descriptions](https://www.va.gov/resources/what-your-claim-status-means/), which are:\n\n- Claim received\n- Initial review\n- Evidence gathering, review, and decision\n- Preparation for notification\n- Complete\n\n### Finding a Veteran's unique VA ID\n\nThis API uses a unique Veteran identifier to identify the subject of each API request. This Veteran identifier can be retrieved by passing the Veteran’s first name, last name, DOB, and SSN to the ‘/veteran-id’ endpoint. This identifier should then be used as the Veteran ID parameter in request URLs.\n\nNote: though Veteran identifiers are typically static, they may change over time. If a specific Veteran ID suddenly responds with a ‘404 not found’ error, the identifier may have changed. It’s a good idea to periodically check the identifier for each Veteran.\n\n### Authentication and authorization\n\nThe authentication model for the Benefits Claims Version 2 is based on OAuth 2.0 / OpenID Connect and supports the [client credentials grant](https://developer.va.gov/explore/authorization/docs/client-credentials?api=claims).\n\n**Important**: To get production access, you must either work for VA or have specific VA agreements in place. If you have questions, [contact us](https://developer.va.gov/support/contact-us).\n\n### Test data for sandbox environment use\n\nWe use mock [test data in the sandbox environment](https://github.com/department-of-veterans-affairs/vets-api-clients/blob/master/test_accounts.md). Sandbox test data and test users for the Benefits Claims API are valid for all versions of the API.\n" + "description": "## Background\n\nThe Benefits Claims API Version 2 lets internal consumers: \n\n- Retrieve existing claim information, including status, by claim ID\n- Automatically establish an Intent To File (21-0966) in VBMS\n- Automatically establish a disability compensation claim (21-526EZ) in VBMS\n- Digitally submit supporting documentation for disability compensation claims\n- Retrieve the active Power of Attorney organization of individual with power of attorney for a Veteran\n- Automatically establish a power of attorney appointment in VBMS for an accredited organization (VA Form 21-22).\n- Automatically establish a power of attorney appointment in VBMS for an accredited individual (VA Form 21-22a).\n\nYou should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if you are a consumer outside of VA and do not have the necessary VA agreements to use this API.\n \n## Technical Overview\n\nThis API accepts a payload of requests and responses with the payload identifying the claim and Veteran. Responses provide the submission’s processing status. Responses also provide a unique ID which can be used with the appropriate GET endpoint to return detailed, end-to-end claims status tracking. \n\nEnd-to-end claims tracking provides the status of claims as they move through the submission process, but does not return whether the claim was approved or denied. \n\n### Claim statuses\n\nClaims are first submitted by this API and then established in Veterans Benefits Management System (VBMS). A 200 response means that the claim was successfully submitted by the API. It does not mean VA has received the claim. Use the appropriate GET endpoint and the ID returned with your submission response to confirm the status of the submission. Statuses are:\n\n- Pending - the claim is successfully submitted for processing\n- Errored - the submission encountered upstream errors\n- Canceled - the claim was identified as a duplicate or another issue caused the claim to be canceled. For duplicate claims, the tracking of the claim's progress happens under a different Claim ID . \n\nOther statuses this API returns align with the [VA.gov](http://va.gov/) [claim status descriptions](https://www.va.gov/resources/what-your-claim-status-means/), which are:\n\n- Claim received\n- Initial review\n- Evidence gathering, review, and decision\n- Preparation for notification\n- Complete\n\n### Finding a Veteran's unique VA ID\n\nThis API uses a unique Veteran identifier to identify the subject of each API request. This Veteran identifier can be retrieved by passing the Veteran’s first name, last name, DOB, and SSN to the ‘/veteran-id’ endpoint. This identifier should then be used as the Veteran ID parameter in request URLs.\n\nNote: though Veteran identifiers are typically static, they may change over time. If a specific Veteran ID suddenly responds with a ‘404 not found’ error, the identifier may have changed. It’s a good idea to periodically check the identifier for each Veteran.\n\n### Authentication and authorization\n\nThe authentication model for the Benefits Claims Version 2 is based on OAuth 2.0 / OpenID Connect and supports the [client credentials grant](https://developer.va.gov/explore/authorization/docs/client-credentials?api=claims).\n\n**Important**: To get production access, you must either work for VA or have specific VA agreements in place. If you have questions, [contact us](https://developer.va.gov/support/contact-us).\n\n### Test data for sandbox environment use\n\nWe use mock [test data in the sandbox environment](https://github.com/department-of-veterans-affairs/vets-api-clients/blob/master/test_accounts.md). Sandbox test data and test users for the Benefits Claims API are valid for all versions of the API.\n" }, "tags": [ { @@ -28,7 +28,7 @@ }, { "name": "Power of Attorney", - "description": "Allows authenticated and authorized users to retrieve the active power of attorney for a Veteran\n" + "description": "Allows authenticated and authorized users to automatically establish power of attorney appointments to an organization or an individual. Organizations and individuals must be VA accredited representatives.\n" } ], "components": { @@ -5720,7 +5720,7 @@ "application/json": { "example": { "data": { - "id": "bb700978-5b4c-435d-b8ec-d16914ed3174", + "id": "cf532e4e-e89e-4f9c-aebd-ce8361336a41", "type": "forms/526", "attributes": { "veteran": { @@ -7804,8 +7804,8 @@ "id": "1", "type": "intent_to_file", "attributes": { - "creationDate": "2024-03-14", - "expirationDate": "2025-03-14", + "creationDate": "2024-03-26", + "expirationDate": "2025-03-26", "type": "compensation", "status": "active" } @@ -8524,7 +8524,7 @@ "status": "422", "detail": "Could not retrieve Power of Attorney due to multiple representatives with code: A1Q", "source": { - "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/base_controller.rb:111:in `representative'" + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/base_controller.rb:112:in `representative'" } } ] @@ -8623,7 +8623,7 @@ "application/json": { "example": { "data": { - "id": "3d2234a1-0151-4ddc-921f-7e3575089d6e", + "id": "29b16b36-3108-411f-9f5f-2c1c2e147ea3", "type": "individual", "attributes": { "code": "083", @@ -9323,7 +9323,7 @@ "application/json": { "example": { "data": { - "id": "45bf00c5-36b3-4157-9620-6a89d5bd37ae", + "id": "a7114d11-8ffd-4545-ad99-d70e74991e11", "type": "organization", "attributes": { "code": "083", @@ -11261,11 +11261,11 @@ "application/json": { "example": { "data": { - "id": "d3048cf3-3869-4c31-a873-996e4959b13a", + "id": "7b0c58e1-4bf7-413c-a3ab-c8f6b95208b0", "type": "claimsApiPowerOfAttorneys", "attributes": { "status": "submitted", - "dateRequestAccepted": "2024-03-14", + "dateRequestAccepted": "2024-03-26", "representative": { "serviceOrganization": { "poaCode": "074" diff --git a/modules/claims_api/app/swagger/claims_api/v2/production/swagger.json b/modules/claims_api/app/swagger/claims_api/v2/production/swagger.json index aeeecb629ae..43450b6625d 100644 --- a/modules/claims_api/app/swagger/claims_api/v2/production/swagger.json +++ b/modules/claims_api/app/swagger/claims_api/v2/production/swagger.json @@ -3,7 +3,7 @@ "info": { "title": "Benefits Claims", "version": "v2", - "description": "## Background\n\nThe Benefits Claims API Version 2 lets internal consumers: \n\n- Retrieve existing claim information, including status, by claim ID\n- Automatically establish an Intent To File (21-0966) in VBMS\n- Automatically establish a disability compensation claim (21-526EZ) in VBMS\n- Digitally submit supporting documentation for disability compensation claims\n- Retrieve the active Power of Attorney for a Veteran\n\nAdditional functionality will be added over time.\n\nYou should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if: \n\n- You are a consumer outside of VA and do not have the necessary VA agreements to use this API, and/or\n- You want automatic establishment of power of attorney (21-22 or 21-22a)\n \n## Technical Overview\n\nThis API accepts a payload of requests and responses with the payload identifying the claim and Veteran. Responses provide the submission’s processing status. Responses also provide a unique ID which can be used with the appropriate GET endpoint to return detailed, end-to-end claims status tracking. \n\nEnd-to-end claims tracking provides the status of claims as they move through the submission process, but does not return whether the claim was approved or denied. \n\n### Claim statuses\n\nClaims are first submitted by this API and then established in Veterans Benefits Management System (VBMS). A 200 response means that the claim was successfully submitted by the API. It does not mean VA has received the claim. Use the appropriate GET endpoint and the ID returned with your submission response to confirm the status of the submission. Statuses are:\n\n- Pending - the claim is successfully submitted for processing\n- Errored - the submission encountered upstream errors\n- Canceled - the claim was identified as a duplicate or another issue caused the claim to be canceled. For duplicate claims, the tracking of the claim's progress happens under a different Claim ID . \n\nOther statuses this API returns align with the [VA.gov](http://va.gov/) [claim status descriptions](https://www.va.gov/resources/what-your-claim-status-means/), which are:\n\n- Claim received\n- Initial review\n- Evidence gathering, review, and decision\n- Preparation for notification\n- Complete\n\n### Finding a Veteran's unique VA ID\n\nThis API uses a unique Veteran identifier to identify the subject of each API request. This Veteran identifier can be retrieved by passing the Veteran’s first name, last name, DOB, and SSN to the ‘/veteran-id’ endpoint. This identifier should then be used as the Veteran ID parameter in request URLs.\n\nNote: though Veteran identifiers are typically static, they may change over time. If a specific Veteran ID suddenly responds with a ‘404 not found’ error, the identifier may have changed. It’s a good idea to periodically check the identifier for each Veteran.\n\n### Authentication and authorization\n\nThe authentication model for the Benefits Claims Version 2 is based on OAuth 2.0 / OpenID Connect and supports the [client credentials grant](https://developer.va.gov/explore/authorization/docs/client-credentials?api=claims).\n\n**Important**: To get production access, you must either work for VA or have specific VA agreements in place. If you have questions, [contact us](https://developer.va.gov/support/contact-us).\n\n### Test data for sandbox environment use\n\nWe use mock [test data in the sandbox environment](https://github.com/department-of-veterans-affairs/vets-api-clients/blob/master/test_accounts.md). Sandbox test data and test users for the Benefits Claims API are valid for all versions of the API.\n" + "description": "## Background\n\nThe Benefits Claims API Version 2 lets internal consumers: \n\n- Retrieve existing claim information, including status, by claim ID\n- Automatically establish an Intent To File (21-0966) in VBMS\n- Automatically establish a disability compensation claim (21-526EZ) in VBMS\n- Digitally submit supporting documentation for disability compensation claims\n- Retrieve the active Power of Attorney organization of individual with power of attorney for a Veteran\n- Automatically establish a power of attorney appointment in VBMS for an accredited organization (VA Form 21-22).\n- Automatically establish a power of attorney appointment in VBMS for an accredited individual (VA Form 21-22a).\n\nYou should use the [Benefits Claims API Version 1](https://developer.va.gov/explore/benefits/docs/claims?version=current) if you are a consumer outside of VA and do not have the necessary VA agreements to use this API.\n \n## Technical Overview\n\nThis API accepts a payload of requests and responses with the payload identifying the claim and Veteran. Responses provide the submission’s processing status. Responses also provide a unique ID which can be used with the appropriate GET endpoint to return detailed, end-to-end claims status tracking. \n\nEnd-to-end claims tracking provides the status of claims as they move through the submission process, but does not return whether the claim was approved or denied. \n\n### Claim statuses\n\nClaims are first submitted by this API and then established in Veterans Benefits Management System (VBMS). A 200 response means that the claim was successfully submitted by the API. It does not mean VA has received the claim. Use the appropriate GET endpoint and the ID returned with your submission response to confirm the status of the submission. Statuses are:\n\n- Pending - the claim is successfully submitted for processing\n- Errored - the submission encountered upstream errors\n- Canceled - the claim was identified as a duplicate or another issue caused the claim to be canceled. For duplicate claims, the tracking of the claim's progress happens under a different Claim ID . \n\nOther statuses this API returns align with the [VA.gov](http://va.gov/) [claim status descriptions](https://www.va.gov/resources/what-your-claim-status-means/), which are:\n\n- Claim received\n- Initial review\n- Evidence gathering, review, and decision\n- Preparation for notification\n- Complete\n\n### Finding a Veteran's unique VA ID\n\nThis API uses a unique Veteran identifier to identify the subject of each API request. This Veteran identifier can be retrieved by passing the Veteran’s first name, last name, DOB, and SSN to the ‘/veteran-id’ endpoint. This identifier should then be used as the Veteran ID parameter in request URLs.\n\nNote: though Veteran identifiers are typically static, they may change over time. If a specific Veteran ID suddenly responds with a ‘404 not found’ error, the identifier may have changed. It’s a good idea to periodically check the identifier for each Veteran.\n\n### Authentication and authorization\n\nThe authentication model for the Benefits Claims Version 2 is based on OAuth 2.0 / OpenID Connect and supports the [client credentials grant](https://developer.va.gov/explore/authorization/docs/client-credentials?api=claims).\n\n**Important**: To get production access, you must either work for VA or have specific VA agreements in place. If you have questions, [contact us](https://developer.va.gov/support/contact-us).\n\n### Test data for sandbox environment use\n\nWe use mock [test data in the sandbox environment](https://github.com/department-of-veterans-affairs/vets-api-clients/blob/master/test_accounts.md). Sandbox test data and test users for the Benefits Claims API are valid for all versions of the API.\n" }, "tags": [ { @@ -28,7 +28,7 @@ }, { "name": "Power of Attorney", - "description": "Allows authenticated and authorized users to retrieve the active power of attorney for a Veteran\n" + "description": "Allows authenticated and authorized users to automatically establish power of attorney appointments to an organization or an individual. Organizations and individuals must be VA accredited representatives.\n" } ], "components": { @@ -5720,7 +5720,7 @@ "application/json": { "example": { "data": { - "id": "450bd9ed-ec42-414a-a338-d79c766f7c8e", + "id": "8b3c6607-078b-419b-8549-726da40193df", "type": "forms/526", "attributes": { "veteran": { @@ -5871,7 +5871,7 @@ "status": "404", "detail": "Resource not found", "source": { - "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/disability_compensation_controller.rb:66:in `attachments'" + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/disability_compensation_controller.rb:70:in `attachments'" } } ] @@ -7804,8 +7804,8 @@ "id": "1", "type": "intent_to_file", "attributes": { - "creationDate": "2024-02-12", - "expirationDate": "2025-02-12", + "creationDate": "2024-03-26", + "expirationDate": "2025-03-26", "type": "compensation", "status": "active" } @@ -8524,7 +8524,2910 @@ "status": "422", "detail": "Could not retrieve Power of Attorney due to multiple representatives with code: A1Q", "source": { - "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney_controller.rb:108:in `representative'" + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/base_controller.rb:112:in `representative'" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + } + } + } + }, + "/veterans/{veteranId}/2122a": { + "post": { + "summary": "Appoint an individual Power of Attorney for a Veteran.", + "tags": [ + "Power of Attorney" + ], + "operationId": "post2122a", + "security": [ + { + "productionOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "sandboxOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "bearer_token": [ + + ] + } + ], + "parameters": [ + { + "name": "veteranId", + "in": "path", + "required": true, + "example": "1012667145V762142", + "description": "ID of Veteran", + "schema": { + "type": "string" + } + } + ], + "description": "Updates current Power of Attorney for Veteran.", + "responses": { + "202": { + "description": "Valid request response", + "content": { + "application/json": { + "example": { + "data": { + "id": "9a9b6db5-abfc-45f3-ab60-785e3fb052ed", + "type": "individual", + "attributes": { + "code": "083", + "name": "Firstname Lastname", + "phoneNumber": "555-555-5555" + } + } + }, + "schema": { + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "additionalProperties": false, + "required": [ + "type", + "attributes" + ], + "properties": { + "type": { + "type": "string" + }, + "id": { + "type": "string" + }, + "attributes": { + "type": "object", + "additionalProperties": false, + "required": [ + "code" + ], + "properties": { + "code": { + "type": "string", + "description": "code for Power of attorney" + }, + "phoneNumber": { + "type": "string" + }, + "name": { + "type": "string" + } + } + } + } + } + } + } + } + } + }, + "401": { + "description": "Unauthorized", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Not authorized", + "status": "401", + "detail": "Not authorized" + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "422": { + "description": "Unprocessable Entity", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Unprocessable entity", + "detail": "The property /representative did not contain the required key poaCode", + "status": "422", + "source": { + "pointer": "data/attributes/representative" + } + }, + { + "title": "Unprocessable entity", + "detail": "The property / did not contain the required key veteran", + "status": "422", + "source": { + "pointer": "data/attributes/" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "404": { + "description": "Resource not found", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Resource not found", + "status": "404", + "detail": "Could not find an Accredited Representative with code: 083", + "source": { + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/individual_controller.rb:35:in `validate_individual_poa_code!'" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + } + }, + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "required": [ + "attributes", + null + ], + "properties": { + "attributes": { + "$schema": "http://json-schema.org/draft-07/schema#", + "description": "Form 2122a Schema", + "type": "object", + "additionalProperties": false, + "required": [ + "veteran", + "representative" + ], + "properties": { + "veteran": { + "type": "object", + "additionalProperties": false, + "required": [ + "address" + ], + "properties": { + "serviceNumber": { + "description": "The Veteran's Service Number", + "type": "string", + "maxLength": 9 + }, + "serviceBranch": { + "description": "Service Branch for the veteran.", + "type": "string", + "enum": [ + "AIR_FORCE", + "ARMY", + "COAST_GUARD", + "MARINE_CORPS", + "NAVY", + "SPACE_FORCE", + "OTHER" + ], + "example": "ARMY" + }, + "serviceBranchOther": { + "description": "For a 'service branch' of value 'other', please provide the service branch name.", + "type": "string", + "maxLength": 27, + "example": "Air National Guard" + }, + "address": { + "type": "object", + "additionalProperties": false, + "required": [ + "addressLine1", + "city", + "stateCode", + "country", + "zipCode" + ], + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the veteran.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran@example.com" + } + } + }, + "claimant": { + "type": "object", + "additionalProperties": false, + "properties": { + "claimantId": { + "type": "string", + "example": "123456789", + "description": "Id of the claimant." + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name. Required if claimant information provided.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address. Required if claimant information provided.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address. Required if claimant information provided.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address. Required if claimant information provided.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address. Required if claimant information provided.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the claimant.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "claimant@example.com" + }, + "relationship": { + "description": "Relationship of claimant to the veteran. Required if claimant information provided.", + "type": "string", + "example": "Spouse" + } + } + }, + "representative": { + "description": "Details of the individual representative representing the veteran.", + "type": "object", + "additionalProperties": false, + "required": [ + "poaCode", + "firstName", + "lastName", + "type" + ], + "properties": { + "poaCode": { + "description": "The POA code of the representative.", + "type": "string", + "example": "A1Q" + }, + "firstName": { + "description": "First Name of the representative.", + "type": "string", + "example": "John" + }, + "lastName": { + "description": "Last Name of the representative", + "type": "string", + "example": "Doe" + }, + "type": { + "description": "Type of individual representative", + "type": "string", + "enum": [ + "ATTORNEY", + "AGENT" + ], + "example": "ATTORNEY" + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "organizationName": { + "description": "Name of the service organization.", + "type": "string", + "example": "I help vets LLC." + } + } + }, + "recordConsent": { + "description": "AUTHORIZATION FOR REPRESENTATIVE'S ACCESS TO RECORDS PROTECTED BY SECTION 7332, TITLE 38, U.S.C.", + "type": "boolean" + }, + "consentLimits": { + "description": "Consent in Item 19 for the disclosure of records relating to treatment for drug abuse, alcoholism or alcohol abuse, infection with the human immunodeficiency virus (HIV), or sickle cell anemia is limited as follows.", + "type": "array", + "items": { + "type": "string", + "enum": [ + "DRUG_ABUSE", + "ALCOHOLISM", + "HIV", + "SICKLE_CELL" + ] + }, + "example": "DRUG ABUSE" + }, + "consentAddressChange": { + "description": "AUTHORIZATION FOR REPRESENTATIVE TO ACT ON CLAIMANT'S BEHALF TO CHANGE CLAIMANT'S ADDRESS.", + "type": "boolean" + }, + "conditionsOfAppointment": { + "description": "If the individual named in Item 15A is an accredited agent or attorney, the scope of representation provided before VA may be limited by the agent or attorney as indicated below in Item 23", + "type": "array", + "items": { + "type": "string" + } + } + } + } + } + } + }, + "example": { + "data": { + "attributes": { + "veteran": { + "address": { + "addressLine1": "123", + "addressLine2": "2a", + "city": "city", + "country": "US", + "stateCode": "OR", + "zipCode": "12345", + "zipCodeSuffix": "6789" + } + }, + "representative": { + "poaCode": "083", + "firstName": "my", + "lastName": "name", + "type": "ATTORNEY", + "address": { + "addressLine1": "123", + "addressLine2": "2a", + "city": "city", + "country": "US", + "stateCode": "OR", + "zipCode": "12345", + "zipCodeSuffix": "6789" + } + } + } + } + } + } + } + }, + "required": true + } + } + }, + "/veterans/{veteranId}/2122": { + "post": { + "summary": "Appoint an organization Power of Attorney for a Veteran.", + "description": "Updates current Power of Attorney for Veteran.", + "tags": [ + "Power of Attorney" + ], + "operationId": "post2122", + "security": [ + { + "productionOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "sandboxOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "bearer_token": [ + + ] + } + ], + "parameters": [ + { + "name": "veteranId", + "in": "path", + "required": true, + "example": "1012667145V762142", + "description": "ID of Veteran", + "schema": { + "type": "string" + } + } + ], + "responses": { + "202": { + "description": "Valid request response", + "content": { + "application/json": { + "example": { + "data": { + "id": "618d9ba4-44cf-490a-bd56-8012b59b30e7", + "type": "organization", + "attributes": { + "code": "083", + "name": "083 - DISABLED AMERICAN VETERANS", + "phoneNumber": "555-555-5555" + } + } + }, + "schema": { + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "additionalProperties": false, + "required": [ + "type", + "attributes" + ], + "properties": { + "type": { + "type": "string" + }, + "id": { + "type": "string" + }, + "attributes": { + "type": "object", + "additionalProperties": false, + "required": [ + "code" + ], + "properties": { + "code": { + "type": "string", + "description": "code for Power of attorney" + }, + "phoneNumber": { + "type": "string" + }, + "name": { + "type": "string" + } + } + } + } + } + } + } + } + } + }, + "401": { + "description": "Unauthorized", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Not authorized", + "status": "401", + "detail": "Not authorized" + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "422": { + "description": "Unprocessable Entity", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Unprocessable entity", + "detail": "The property /serviceOrganization did not contain the required key poaCode", + "status": "422", + "source": { + "pointer": "data/attributes/serviceOrganization" + } + }, + { + "title": "Unprocessable entity", + "detail": "The property / did not contain the required key veteran", + "status": "422", + "source": { + "pointer": "data/attributes/" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "404": { + "description": "Resource not found", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Resource not found", + "status": "404", + "detail": "Could not find an Organization with code: 083", + "source": { + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/organization_controller.rb:35:in `validate_org_poa_code!'" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + } + }, + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "required": [ + "attributes", + null + ], + "properties": { + "attributes": { + "$schema": "http://json-schema.org/draft-07/schema#", + "description": "Form 2122 Schema", + "type": "object", + "additionalProperties": false, + "required": [ + "veteran", + "serviceOrganization" + ], + "properties": { + "veteran": { + "type": "object", + "additionalProperties": false, + "required": [ + "address" + ], + "properties": { + "address": { + "type": "object", + "additionalProperties": false, + "required": [ + "addressLine1", + "city", + "country", + "stateCode", + "zipCode" + ], + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the veteran.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran@example.com" + }, + "serviceNumber": { + "description": "Service number for the veteran.", + "type": "string", + "pattern": "^\\d{9}?$", + "example": "123456789" + } + } + }, + "claimant": { + "type": "object", + "additionalProperties": false, + "properties": { + "claimantId": { + "type": "string", + "example": "123456789", + "description": "Id of the claimant." + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name. Required if claimant information provided.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address. Required if claimant information provided.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address. Required if claimant information provided.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address. Required if claimant information provided.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address. Required if claimant information provided.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + }, + "additionalProperties": { + "type": "boolean" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the claimant.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "claimant@example.com" + }, + "relationship": { + "description": "Relationship of claimant to the veteran. Required if claimant information provided.", + "type": "string", + "example": "Spouse" + } + } + }, + "serviceOrganization": { + "description": "Details of the Service Organization representing the veteran.", + "type": "object", + "additionalProperties": false, + "required": [ + "poaCode" + ], + "properties": { + "poaCode": { + "description": "The POA code of the organization.", + "type": "string", + "example": "A1Q" + }, + "organizationName": { + "description": "Name of the service organization.", + "type": "string", + "example": "I help vets LLC." + }, + "firstName": { + "description": "First Name of the representative.", + "type": "string", + "example": "John" + }, + "lastName": { + "description": "Last Name of the representative", + "type": "string", + "example": "Doe" + }, + "jobTitle": { + "description": "Job title of the representative.", + "type": "string", + "example": "Veteran Service representative" + }, + "email": { + "description": "Email address of the service organization or representative.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran_representative@example.com" + }, + "appointmentDate": { + "description": "Date of appointment with Veteran.", + "type": "string", + "pattern": "^(\\d{4})-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1])$" + } + } + }, + "recordConsent": { + "description": "AUTHORIZATION FOR REPRESENTATIVE'S ACCESS TO RECORDS PROTECTED BY SECTION 7332, TITLE 38, U.S.C.", + "type": "boolean" + }, + "consentLimits": { + "description": "Consent in Item 19 for the disclosure of records relating to treatment for drug abuse, alcoholism or alcohol abuse, infection with the human immunodeficiency virus (HIV), or sickle cell anemia is limited as follows.", + "type": "array", + "items": { + "type": "string", + "enum": [ + "DRUG_ABUSE", + "ALCOHOLISM", + "HIV", + "SICKLE_CELL" + ] + }, + "example": "DRUG_ABUSE" + }, + "consentAddressChange": { + "description": "AUTHORIZATION FOR REPRESENTATIVE TO ACT ON CLAIMANT'S BEHALF TO CHANGE CLAIMANT'S ADDRESS.", + "type": "boolean" + } + } + } + } + } + }, + "example": { + "data": { + "attributes": { + "veteran": { + "address": { + "addressLine1": "123", + "city": "city", + "stateCode": "OR", + "country": "US", + "zipCode": "12345" + } + }, + "serviceOrganization": { + "poaCode": "083" + } + } + } + } + } + } + }, + "required": true + } + } + }, + "/veterans/{veteranId}/2122a/validate": { + "post": { + "summary": "Validates a 2122a form submission.", + "tags": [ + "Power of Attorney" + ], + "operationId": "post2122aValidate", + "security": [ + { + "productionOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "sandboxOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "bearer_token": [ + + ] + } + ], + "parameters": [ + { + "name": "veteranId", + "in": "path", + "required": true, + "example": "1012667145V762142", + "description": "ID of Veteran", + "schema": { + "type": "string" + } + } + ], + "description": "Validates a request appointing an individual as Power of Attorney (21-22a).\n", + "responses": { + "200": { + "description": "Valid request response", + "content": { + "application/json": { + "example": { + "data": { + "type": "form/21-22a/validation", + "attributes": { + "status": "valid" + } + } + }, + "schema": { + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "additionalProperties": false, + "required": [ + "type", + "attributes" + ], + "properties": { + "type": { + "type": "string" + }, + "attributes": { + "type": "object", + "additionalProperties": false, + "required": [ + "status" + ], + "properties": { + "status": { + "type": "string", + "description": "Says if submission of 21-22a would work with the given parameters", + "enum": [ + "valid" + ] + } + } + } + } + } + } + } + } + } + }, + "401": { + "description": "Unauthorized", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Not authorized", + "status": "401", + "detail": "Not authorized" + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "422": { + "description": "Unprocessable Entity", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Unprocessable entity", + "detail": "The property /representative did not contain the required key poaCode", + "status": "422", + "source": { + "pointer": "data/attributes/representative" + } + }, + { + "title": "Unprocessable entity", + "detail": "The property / did not contain the required key veteran", + "status": "422", + "source": { + "pointer": "data/attributes/" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "404": { + "description": "Resource not found", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Resource not found", + "status": "404", + "detail": "Could not find an Accredited Representative with code: 083", + "source": { + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/individual_controller.rb:35:in `validate_individual_poa_code!'" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + } + }, + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "required": [ + "attributes", + null + ], + "properties": { + "attributes": { + "$schema": "http://json-schema.org/draft-07/schema#", + "description": "Form 2122a Schema", + "type": "object", + "additionalProperties": false, + "required": [ + "veteran", + "representative" + ], + "properties": { + "veteran": { + "type": "object", + "additionalProperties": false, + "required": [ + "address" + ], + "properties": { + "serviceNumber": { + "description": "The Veteran's Service Number", + "type": "string", + "maxLength": 9 + }, + "serviceBranch": { + "description": "Service Branch for the veteran.", + "type": "string", + "enum": [ + "AIR_FORCE", + "ARMY", + "COAST_GUARD", + "MARINE_CORPS", + "NAVY", + "SPACE_FORCE", + "OTHER" + ], + "example": "ARMY" + }, + "serviceBranchOther": { + "description": "For a 'service branch' of value 'other', please provide the service branch name.", + "type": "string", + "maxLength": 27, + "example": "Air National Guard" + }, + "address": { + "type": "object", + "additionalProperties": false, + "required": [ + "addressLine1", + "city", + "stateCode", + "country", + "zipCode" + ], + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the veteran.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran@example.com" + } + } + }, + "claimant": { + "type": "object", + "additionalProperties": false, + "properties": { + "claimantId": { + "type": "string", + "example": "123456789", + "description": "Id of the claimant." + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name. Required if claimant information provided.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address. Required if claimant information provided.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address. Required if claimant information provided.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address. Required if claimant information provided.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address. Required if claimant information provided.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the claimant.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "claimant@example.com" + }, + "relationship": { + "description": "Relationship of claimant to the veteran. Required if claimant information provided.", + "type": "string", + "example": "Spouse" + } + } + }, + "representative": { + "description": "Details of the individual representative representing the veteran.", + "type": "object", + "additionalProperties": false, + "required": [ + "poaCode", + "firstName", + "lastName", + "type" + ], + "properties": { + "poaCode": { + "description": "The POA code of the representative.", + "type": "string", + "example": "A1Q" + }, + "firstName": { + "description": "First Name of the representative.", + "type": "string", + "example": "John" + }, + "lastName": { + "description": "Last Name of the representative", + "type": "string", + "example": "Doe" + }, + "type": { + "description": "Type of individual representative", + "type": "string", + "enum": [ + "ATTORNEY", + "AGENT" + ], + "example": "ATTORNEY" + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "organizationName": { + "description": "Name of the service organization.", + "type": "string", + "example": "I help vets LLC." + } + } + }, + "recordConsent": { + "description": "AUTHORIZATION FOR REPRESENTATIVE'S ACCESS TO RECORDS PROTECTED BY SECTION 7332, TITLE 38, U.S.C.", + "type": "boolean" + }, + "consentLimits": { + "description": "Consent in Item 19 for the disclosure of records relating to treatment for drug abuse, alcoholism or alcohol abuse, infection with the human immunodeficiency virus (HIV), or sickle cell anemia is limited as follows.", + "type": "array", + "items": { + "type": "string", + "enum": [ + "DRUG_ABUSE", + "ALCOHOLISM", + "HIV", + "SICKLE_CELL" + ] + }, + "example": "DRUG ABUSE" + }, + "consentAddressChange": { + "description": "AUTHORIZATION FOR REPRESENTATIVE TO ACT ON CLAIMANT'S BEHALF TO CHANGE CLAIMANT'S ADDRESS.", + "type": "boolean" + }, + "conditionsOfAppointment": { + "description": "If the individual named in Item 15A is an accredited agent or attorney, the scope of representation provided before VA may be limited by the agent or attorney as indicated below in Item 23", + "type": "array", + "items": { + "type": "string" + } + } + } + } + } + } + }, + "example": { + "data": { + "attributes": { + "veteran": { + "address": { + "addressLine1": "123", + "addressLine2": "2a", + "city": "city", + "country": "US", + "stateCode": "OR", + "zipCode": "12345", + "zipCodeSuffix": "6789" + } + }, + "representative": { + "poaCode": "083", + "firstName": "my", + "lastName": "name", + "type": "ATTORNEY", + "address": { + "addressLine1": "123", + "addressLine2": "2a", + "city": "city", + "country": "US", + "stateCode": "OR", + "zipCode": "12345", + "zipCodeSuffix": "6789" + } + } + } + } + } + } + } + }, + "required": true + } + } + }, + "/veterans/{veteranId}/2122/validate": { + "post": { + "summary": "Validates a 2122 form submission.", + "tags": [ + "Power of Attorney" + ], + "operationId": "post2122Validate", + "security": [ + { + "productionOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "sandboxOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "bearer_token": [ + + ] + } + ], + "parameters": [ + { + "name": "veteranId", + "in": "path", + "required": true, + "example": "1012667145V762142", + "description": "ID of Veteran", + "schema": { + "type": "string" + } + } + ], + "description": "Validates a request appointing an organization as Power of Attorney (21-22).\n", + "responses": { + "200": { + "description": "Valid request response", + "content": { + "application/json": { + "example": { + "data": { + "type": "form/21-22/validation", + "attributes": { + "status": "valid" + } + } + }, + "schema": { + "$schema": "http://json-schema.org/draft-07/schema#", + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "additionalProperties": false, + "required": [ + "type", + "attributes" + ], + "properties": { + "type": { + "type": "string" + }, + "attributes": { + "type": "object", + "additionalProperties": false, + "required": [ + "status" + ], + "properties": { + "status": { + "type": "string", + "description": "Says if submission of 21-22 would work with the given parameters", + "enum": [ + "valid" + ] + } + } + } + } + } + } + } + } + } + }, + "401": { + "description": "Unauthorized", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Not authorized", + "status": "401", + "detail": "Not authorized" + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "422": { + "description": "Unprocessable Entity", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Unprocessable entity", + "detail": "The property /serviceOrganization did not contain the required key poaCode", + "status": "422", + "source": { + "pointer": "data/attributes/serviceOrganization" + } + }, + { + "title": "Unprocessable entity", + "detail": "The property / did not contain the required key veteran", + "status": "422", + "source": { + "pointer": "data/attributes/" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "404": { + "description": "Resource not found", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Resource not found", + "status": "404", + "detail": "Could not find an Organization with code: 083", + "source": { + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/organization_controller.rb:35:in `validate_org_poa_code!'" + } + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + } + }, + "requestBody": { + "content": { + "application/json": { + "schema": { + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "required": [ + "attributes", + null + ], + "properties": { + "attributes": { + "$schema": "http://json-schema.org/draft-07/schema#", + "description": "Form 2122 Schema", + "type": "object", + "additionalProperties": false, + "required": [ + "veteran", + "serviceOrganization" + ], + "properties": { + "veteran": { + "type": "object", + "additionalProperties": false, + "required": [ + "address" + ], + "properties": { + "address": { + "type": "object", + "additionalProperties": false, + "required": [ + "addressLine1", + "city", + "country", + "stateCode", + "zipCode" + ], + "properties": { + "addressLine1": { + "description": "Street address with number and name.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the veteran.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran@example.com" + }, + "serviceNumber": { + "description": "Service number for the veteran.", + "type": "string", + "pattern": "^\\d{9}?$", + "example": "123456789" + } + } + }, + "claimant": { + "type": "object", + "additionalProperties": false, + "properties": { + "claimantId": { + "type": "string", + "example": "123456789", + "description": "Id of the claimant." + }, + "address": { + "type": "object", + "additionalProperties": false, + "properties": { + "addressLine1": { + "description": "Street address with number and name. Required if claimant information provided.", + "type": "string", + "pattern": "^([-a-zA-Z0-9'.,&#]([-a-zA-Z0-9'.,&# ])?)+$", + "maxLength": 30 + }, + "addressLine2": { + "type": "string", + "maxLength": 5 + }, + "city": { + "description": "City for the address. Required if claimant information provided.", + "type": "string", + "example": "Portland", + "maxLength": 18 + }, + "stateCode": { + "description": "State for the address. Required if claimant information provided.", + "type": "string", + "pattern": "^[a-z,A-Z]{2}$", + "example": "OR" + }, + "country": { + "description": "Country of the address. Required if claimant information provided.", + "type": "string", + "example": "USA" + }, + "zipCode": { + "description": "Zipcode (First 5 digits) of the address. Required if claimant information provided.", + "type": "string", + "pattern": "^\\d{5}?$", + "example": "12345" + }, + "zipCodeSuffix": { + "description": "Zipcode (Last 4 digits) of the address.", + "type": "string", + "pattern": "^\\d{4}?$", + "example": "6789" + }, + "additionalProperties": { + "type": "boolean" + } + } + }, + "phone": { + "$comment": "the phone fields must not exceed 20 chars, when concatenated", + "type": "object", + "additionalProperties": false, + "required": [ + "areaCode", + "phoneNumber" + ], + "properties": { + "countryCode": { + "type": "string", + "pattern": "^[0-9]+$" + }, + "areaCode": { + "description": "Area code of the phone number.", + "type": "string", + "pattern": "^[2-9][0-9]{2}$", + "example": "555" + }, + "phoneNumber": { + "description": "Phone number.", + "type": "string", + "pattern": "^[0-9]{1,14}$", + "example": "555-5555" + }, + "phoneNumberExt": { + "type": "string", + "pattern": "^[a-zA-Z0-9]{1,10}$" + } + } + }, + "email": { + "description": "Email address of the claimant.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "claimant@example.com" + }, + "relationship": { + "description": "Relationship of claimant to the veteran. Required if claimant information provided.", + "type": "string", + "example": "Spouse" + } + } + }, + "serviceOrganization": { + "description": "Details of the Service Organization representing the veteran.", + "type": "object", + "additionalProperties": false, + "required": [ + "poaCode" + ], + "properties": { + "poaCode": { + "description": "The POA code of the organization.", + "type": "string", + "example": "A1Q" + }, + "organizationName": { + "description": "Name of the service organization.", + "type": "string", + "example": "I help vets LLC." + }, + "firstName": { + "description": "First Name of the representative.", + "type": "string", + "example": "John" + }, + "lastName": { + "description": "Last Name of the representative", + "type": "string", + "example": "Doe" + }, + "jobTitle": { + "description": "Job title of the representative.", + "type": "string", + "example": "Veteran Service representative" + }, + "email": { + "description": "Email address of the service organization or representative.", + "type": "string", + "pattern": ".@.", + "maxLength": 61, + "example": "veteran_representative@example.com" + }, + "appointmentDate": { + "description": "Date of appointment with Veteran.", + "type": "string", + "pattern": "^(\\d{4})-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1])$" + } + } + }, + "recordConsent": { + "description": "AUTHORIZATION FOR REPRESENTATIVE'S ACCESS TO RECORDS PROTECTED BY SECTION 7332, TITLE 38, U.S.C.", + "type": "boolean" + }, + "consentLimits": { + "description": "Consent in Item 19 for the disclosure of records relating to treatment for drug abuse, alcoholism or alcohol abuse, infection with the human immunodeficiency virus (HIV), or sickle cell anemia is limited as follows.", + "type": "array", + "items": { + "type": "string", + "enum": [ + "DRUG_ABUSE", + "ALCOHOLISM", + "HIV", + "SICKLE_CELL" + ] + }, + "example": "DRUG_ABUSE" + }, + "consentAddressChange": { + "description": "AUTHORIZATION FOR REPRESENTATIVE TO ACT ON CLAIMANT'S BEHALF TO CHANGE CLAIMANT'S ADDRESS.", + "type": "boolean" + } + } + } + } + } + }, + "example": { + "data": { + "attributes": { + "veteran": { + "address": { + "addressLine1": "123", + "city": "city", + "stateCode": "OR", + "country": "US", + "zipCode": "12345" + } + }, + "serviceOrganization": { + "poaCode": "083" + } + } + } + } + } + } + }, + "required": true + } + } + }, + "/veterans/{veteranId}/power-of-attorney/{id}": { + "get": { + "summary": "Checks status of Power of Attorney appointment form submission", + "description": "Gets the Power of Attorney appointment request status (21-22/21-22a)", + "tags": [ + "Power of Attorney" + ], + "operationId": "getPowerOfAttorneyStatus", + "security": [ + { + "productionOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "sandboxOauth": [ + "system/claim.read", + "system/claim.write" + ] + }, + { + "bearer_token": [ + + ] + } + ], + "parameters": [ + { + "name": "veteranId", + "in": "path", + "required": true, + "example": "1012667145V762142", + "description": "ID of Veteran", + "schema": { + "type": "string" + } + }, + { + "name": "id", + "in": "path", + "required": true, + "example": "12e13134-7229-4e44-90ae-bcea2a4525fa", + "description": "The ID of the 21-22 submission", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Valid request response", + "content": { + "application/json": { + "example": { + "data": { + "id": "5d78a9f2-fffb-4867-a621-6ddee5bd5e58", + "type": "claimsApiPowerOfAttorneys", + "attributes": { + "status": "submitted", + "dateRequestAccepted": "2024-03-26", + "representative": { + "serviceOrganization": { + "poaCode": "074" + } + }, + "previousPoa": null + } + } + }, + "schema": { + "$schema": "http://json-schema.org/draft-04/schema#", + "type": "object", + "required": [ + "data" + ], + "properties": { + "data": { + "type": "object", + "additionalProperties": false, + "required": [ + "id", + "type", + "attributes" + ], + "properties": { + "id": { + "type": "string", + "description": "Power of Attorney Submission UUID" + }, + "type": { + "type": "string" + }, + "attributes": { + "type": "object", + "additionalProperties": false, + "required": [ + "status", + "dateRequestAccepted", + "representative" + ], + "properties": { + "status": { + "type": "string", + "description": "Says if the power of attorney is pending, submitted, updated or errored", + "enum": [ + "pending", + "submitted", + "updated", + "errored" + ] + }, + "dateRequestAccepted": { + "type": "string", + "description": "Date request was first accepted", + "format": "date" + }, + "representative": { + "type": "object", + "additionalProperties": false, + "required": [ + "serviceOrganization" + ], + "properties": { + "serviceOrganization": { + "type": "object", + "additionalProperties": true, + "required": [ + "poaCode" + ], + "properties": { + "poa_code": { + "type": "string", + "description": "Power of Attorney Code submitted for Veteran" + } + } + } + } + }, + "previousPoa": { + "type": "string", + "nullable": true, + "description": "Current or Previous Power of Attorney Code submitted for Veteran" + } + } + } + } + } + } + } + } + } + }, + "401": { + "description": "Unauthorized", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Not authorized", + "status": "401", + "detail": "Not authorized" + } + ] + }, + "schema": { + "required": [ + "errors" + ], + "properties": { + "errors": { + "type": "array", + "items": { + "additionalProperties": false, + "required": [ + "title", + "detail" + ], + "properties": { + "title": { + "type": "string", + "description": "HTTP error title" + }, + "detail": { + "type": "string", + "description": "HTTP error detail" + }, + "status": { + "type": "string", + "description": "HTTP error status code" + }, + "source": { + "type": "object", + "additionalProperties": false, + "description": "Source of error", + "properties": { + "pointer": { + "type": "string", + "description": "Pointer to source of error" + } + } + } + } + } + } + } + } + } + } + }, + "404": { + "description": "Resource not found", + "content": { + "application/json": { + "example": { + "errors": [ + { + "title": "Resource not found", + "status": "404", + "detail": "Could not find Power of Attorney with id: -1", + "source": { + "pointer": "/modules/claims_api/app/controllers/claims_api/v2/veterans/power_of_attorney/base_controller.rb:32:in `status'" } } ] diff --git a/modules/claims_api/spec/requests/v2/veterans/rswag_power_of_attorney_spec.rb b/modules/claims_api/spec/requests/v2/veterans/rswag_power_of_attorney_spec.rb index fb6eebe5285..92075a1c2fb 100644 --- a/modules/claims_api/spec/requests/v2/veterans/rswag_power_of_attorney_spec.rb +++ b/modules/claims_api/spec/requests/v2/veterans/rswag_power_of_attorney_spec.rb @@ -143,7 +143,7 @@ end end - path '/veterans/{veteranId}/2122a', production: false do + path '/veterans/{veteranId}/2122a' do post 'Appoint an individual Power of Attorney for a Veteran.' do tags 'Power of Attorney' operationId 'post2122a' @@ -312,7 +312,7 @@ end end - path '/veterans/{veteranId}/2122', production: false do + path '/veterans/{veteranId}/2122' do post 'Appoint an organization Power of Attorney for a Veteran.' do description 'Updates current Power of Attorney for Veteran.' tags 'Power of Attorney' @@ -468,7 +468,7 @@ end end - path '/veterans/{veteranId}/2122a/validate', production: false do + path '/veterans/{veteranId}/2122a/validate' do post 'Validates a 2122a form submission.' do tags 'Power of Attorney' operationId 'post2122aValidate' @@ -638,7 +638,7 @@ end end - path '/veterans/{veteranId}/2122/validate', production: false do + path '/veterans/{veteranId}/2122/validate' do post 'Validates a 2122 form submission.' do tags 'Power of Attorney' operationId 'post2122Validate' @@ -796,7 +796,7 @@ end end - path '/veterans/{veteranId}/power-of-attorney/{id}', production: false do + path '/veterans/{veteranId}/power-of-attorney/{id}' do get 'Checks status of Power of Attorney appointment form submission' do description 'Gets the Power of Attorney appointment request status (21-22/21-22a)' tags 'Power of Attorney' diff --git a/modules/claims_api/spec/support/rswag_config.rb b/modules/claims_api/spec/support/rswag_config.rb index 19474e1856e..264da3585fb 100644 --- a/modules/claims_api/spec/support/rswag_config.rb +++ b/modules/claims_api/spec/support/rswag_config.rb @@ -127,7 +127,7 @@ def config # rubocop:disable Metrics/MethodLength { name: 'Power of Attorney', description: <<~VERBIAGE - Allows authenticated and authorized users to retrieve the active power of attorney for a Veteran + Allows authenticated and authorized users to automatically establish power of attorney appointments to an organization or an individual. Organizations and individuals must be VA accredited representatives. VERBIAGE } ],