ЕСОЗ - публічна документація

Create Program medication

Purpose

This WS allows to create new medication program participant.

 

Specification

Link

API paragraph not found

Resource

/program_medications

Scope

program_medication:write

Components

Drugs and Program medications

Microservices

API paragraph not found

Protocol type

REST

Request type

POST

Sync/Async

Sync

Public/Private/Internal

Internal. NHS Admin

 

Logic

  1. Create new program medication entity: store input into program_medications table (prm). Also, set:

    1. medication_request_allowed = true

    2. is_active = true

    3. inserted_at, updated_at = user_id (from token)

    4. inserted_at, updated_at = current date and time.

Key points

  1. This is a graphQl method used in the Administration panel only.

  2. Only authenticated and authorized NHS employee with an appropriate scope can create a Program medication.

  3. Program medication can be created only for a medical program with type MEDICATION.

 

GraphQl Specification

"Creates a single `ProgramMedication`." createProgramMedication( input: CreateProgramMedicationInput! ): CreateProgramMedicationPayload

 

""" Input for `createProgramMedication` mutation. User must have a scope **program_medication:write** """ input CreateProgramMedicationInput { "Id of medication" medicationId: ID! "Medical program Identifier" medicalProgramId: ID! "Reimbursement information" reimbursement: CreateReimbursementInput! "Factory gate price for package of medications" wholesalePrice: Float "Consumer price for package of medications" consumerPrice: Float "Reimbuersement amount for recommended daily dosage of medication" reimbursementDailyDosage: Float "The estimatied amount which patient should pay for package of medications after reimbursement" estimatedPaymentAmount: Float "Start date of action for this entry" startDate: Date "End date for this entry" endDate: Date "General registry identifier" registryNumber: String "Max Daily dose of medication, limited by WHO." maxDailyDosage: Float } """ Input for `Reimbursement` of `createProgramMedication` mutation. """ input CreateReimbursementInput { "Reimbursement type" type: ReimbursementType! "Reimbursement amount" reimbursementAmount: Float "Percentage of reimbursement." percentageDiscount: Float }
""" Return type for `createProgramMedication` mutation. """ type CreateProgramMedicationPayload { "Created `ProgramMedication`." programMedication: ProgramMedication } """ Program Medication linkes medication and medical program. In order to obtain details user must have a scope **program_medication:read** """ type ProgramMedication implements Node { "The ID of an object." id: ID! "Primary key identifier from the database." databaseId: UUID! "MedicalProgram." medicalProgram: MedicalProgram! "Medication" medication: Medication! "Reimbursement information." reimbursement: Reimbursement! "Factory gate price for package of medications" wholesalePrice: Float "Consumer price for package of medications" consumerPrice: Float "Reimbuersement amount for recommended daily dosage of medication" reimbursementDailyDosage: Float "The estimatied amount which patient should pay for package of medications after reimbursement" estimatedPaymentAmount: Float "Start date of action for this entry" startDate: Date "End date for this entry" endDate: Date "General registry identifier" registryNumber: String "Whether `ProgramMedication` is active or not?" isActive: Boolean! "Whether requesting medications allowed for the `ProgramMedication` or not?" medicationRequestAllowed: Boolean! "Date and time when record was inserted" insertedAt: DateTime! "Date and time when record was updated" updatedAt: DateTime! "Max Daily dose of medication, limited by WHO. Null will be returned, if this field has not been set in register." maxDailyDosage: Float }

 

 

Request structure

See on Apiary

 

Authorize

  • Verify the validity of access token

    • in case of error - return 401 (“Invalid access token”) in case of validation fails.

  • Verify that token is not expired

    • in case of error - return 401 (“Invalid access token”).

  • Check user scopes in order to perform this action (scope = 'program_medication:write')

    • return 403 (“Your scope does not allow to access this resource. Missing allowances: program_medication:read”) in case of invalid scope(s).

Request to process the request using a token in the headers

 

Headers

  • Content-Type:application/json

  • Authorization:Bearer c2778f3064753ea70de870a53795f5c9

 

Request data validation

Validate legal entity

  • Extract client_id from token.

  • Check client scopes in order to perform this action (scope = 'program_medication:write')

    • in case of error - return 403 (“Your scope does not allow to access this resource. Missing allowances: program_medication:write”).

Validate request

  1. Check medicalProgramId:

    1. exists in DB

      1. in case of error - return 404 ('not_found')

    2. has type = MEDICATION

      1. in case of error - return 409 ('MedicalProgram type should be MEDICATION')

    3. is_active = true

      1. in case of error - return 409 ('Medical program is not active')

  2. Check start_date < end_date

    1. in case of error - return 422 ('must be earlier than the end date')

  3. Validate reimbursement:

    1. If reimbursement type = FIXED, than reimbursementAmount field required

    2. If reimbursement type = PERCENTAGE, percentageDiscount field required

      1. in case of error - return 422 ('can't be blank')

  4. If percentageDiscount submitted in the reimbursement structure:

    1. Check it’s value in range from 0 to 100

      1. in case of error - return 422 ('expected the value to be <= 100')

  5. Validate medicationId:

    1. Check it is active and it’s type is BRAND

      1. in case of error - return 409 ('Medication is not active')

  6. Validate compliance of INNM_DOSAGE.mr_blank_type:

    1. in case when $.medication.type is BRAND :

      1. Check INNM_DOSAGE

        1. There is link of a BRAND to INNM_DOSAGE (in prm.ingredients table) and INNM_DOSAGE exists

          1. in case of error - return 404 ('INNM_DOSAGE of a BRAND not_found')

        2. is_active = true

          1. in case of error - return 409 ('INNM_DOSAGE of a BRAND is not active')

    2. in case when $.medication.type is INNM_DOSAGE:

      1. Check INNM_DOSAGE

        1. INNM_DOSAGE exists

          1. in case of error - return 404 ('INNM_DOSAGE not_found')

        2. is_active = true

          1. in case of error - return 409 ('INNM_DOSAGE is not active')

    3. Check compliance of INNM_DOSAGE of a BRAND to medicalProgram

      1. if INNM_DOSAGE.mr_blank_type = medicalProgram.mr_blank_type
        (i.e prm.medications.mr_blank_type = prm.medical_programs.mr_blank_type)

        1. in case of error - return 422 ('Dosage form of selected Medication does not comply with mr_blank_type requirement of Medical Program')

 

Response structure

See on Apiary

 

 

 

HTTP status codes

HTTP status code

Message

What caused the error

HTTP status code

Message

What caused the error

200

Response

 

201

 

 

401

Invalid access token

 

403

Your scope does not allow to access this resource. Missing allowances: program_medication:read

 

404

Not found

  • medicalProgramId exists in DB check fails.

  • INNM_DOSAGE of a BRAND not_found.

409

  • INNM_DOSAGE of a BRAND is not active.

  • Medication is not active.

  • Medical program is not active.

  • MedicalProgram type should be MEDICATION.

 

422

  • must be earlier than the end date.

  • can't be blank.

  • expected the value to be <= 100.

  • Dosage form of selected Medication does not comply with mr_blank_type requirement of Medical Program.

 

ЕСОЗ - публічна документація