From efe24441d606325a7b55d1c24a464f1a54b4a209 Mon Sep 17 00:00:00 2001 From: PEDRO DIEZ GARCIA Date: Sat, 25 May 2024 00:44:35 +0200 Subject: [PATCH] payment_remaining_amount_new_proposal --- code/API_definitions/carrier_billing.yaml | 35 -------- .../carrier_billing_refund.yaml | 81 +++++++++++++++++++ 2 files changed, 81 insertions(+), 35 deletions(-) diff --git a/code/API_definitions/carrier_billing.yaml b/code/API_definitions/carrier_billing.yaml index 0d70b12..a700b6e 100644 --- a/code/API_definitions/carrier_billing.yaml +++ b/code/API_definitions/carrier_billing.yaml @@ -648,10 +648,6 @@ components: type: string format: date-time description: Date time when the payment is effectively performed. This is a business information. It must follow RFC 3339 and must have time zone. Recommended format is yyyy-MM-dd'T'HH:mm:ss.SSSZ (i.e. which allows 2023-07-03T14:27:08.312+02:00 or 2023-07-03T12:27:08.312Z). - paymentRemainingAmount: - allOf: - - $ref: "#/components/schemas/PaymentRemainingAmount" - - description: Remaining Amount of a given payment not refunded yet. Only included when a payment has been refunded at least one time. Check Carrier Billing Refund API for details. webhook: allOf: - $ref: "#/components/schemas/Webhook" @@ -669,37 +665,6 @@ components: type: string description: Authentification token for callback endpoint example: "c8974e592c2fa383d4a3960714" - PaymentRemainingAmount: - type: object - required: - - amount - - currency - properties: - amount: - type: number - format: float - multipleOf: 0.001 - description: Specific amount not yet refunded for the payment. - example: 100 - currency: - type: string - description: Currency code in which amount is expressed as defined in [ISO 4217](https://www.iso.org/iso-4217-currency-codes.html). - example: "EUR" - description: - type: string - description: Description text (human readable) to contextualize this amount. Optionally indicated by Telco Operator. - example: "Current Amount not refunded so far" - isTaxIncluded: - type: boolean - default: false - description: If true, the `amount` is tax included, if false the `amount` is provided without tax. In both cases, `taxAmount` could be indicated to provide tax amount. - taxAmount: - type: number - format: float - multipleOf: 0.001 - description: | - The tax amount refunded by the merchant. Indicated when the merchant is the one applying taxes. This field also provides an indicator to the downstream billing system. - example: 21 AmountTransaction: required: - phoneNumber diff --git a/code/API_definitions/carrier_billing_refund.yaml b/code/API_definitions/carrier_billing_refund.yaml index e6ffd82..ad3e7dc 100644 --- a/code/API_definitions/carrier_billing_refund.yaml +++ b/code/API_definitions/carrier_billing_refund.yaml @@ -282,6 +282,53 @@ paths: $ref: "#/components/responses/Generic503" "504": $ref: "#/components/responses/Generic504" + /payments/{paymentId}/refunds/remainingAmount: + get: + security: + - openId: + - carrier-billing-refund:refunds:read + tags: + - Refund + summary: Get remaining amount not refunded for a given payment + operationId: retrievePaymentRemainingAmount + description: |- + Retrieve remaining amount not yet refunded for a given payment. + + When Access Token is issued for a given user phone number, information would be returned in case the `paymentId` is associated to that user phone number and API client, otherwise `404 NOT_FOUND` will be returned. When Access Token is not associated to a user phone number, the information is returned in case the API client managed that payment. + parameters: + - name: paymentId + in: path + description: Payment identifier associated to the `refundId` + required: true + schema: + type: string + - $ref: "#/components/parameters/x-correlator" + responses: + "200": + description: OK + headers: + x-correlator: + $ref: "#/components/headers/x-correlator" + Content-Last-Key: + $ref: "#/components/headers/Content-Last-Key" + X-Total-Count: + $ref: "#/components/headers/X-Total-Count" + content: + application/json: + schema: + $ref: "#/components/schemas/PaymentRemainingAmount" + "401": + $ref: "#/components/responses/Generic401" + "403": + $ref: "#/components/responses/RefundReadPermissionDenied403" + "404": + $ref: "#/components/responses/Generic404" + "500": + $ref: "#/components/responses/Generic500" + "503": + $ref: "#/components/responses/Generic503" + "504": + $ref: "#/components/responses/Generic504" components: securitySchemes: openId: @@ -564,6 +611,40 @@ components: description: | The tax amount refunded by the merchant. Indicated when the merchant is the one applying taxes. This field also provides an indicator to the downstream billing system. example: 21 + PaymentRemainingAmount: + type: object + description: Remaining Amount of a given payment not refunded yet. + required: + - amount + - currency + properties: + amount: + type: number + format: float + multipleOf: 0.001 + minimum: 0 + description: Specific amount not yet refunded for the payment. When takes value `0` it means whole payment has been refunded. + example: 100 + currency: + type: string + description: Currency code in which amount is expressed as defined in [ISO 4217](https://www.iso.org/iso-4217-currency-codes.html). + example: "EUR" + description: + type: string + description: Description text (human readable) to contextualize this amount. Optionally indicated by Telco Operator. + example: "Current Amount not refunded so far" + isTaxIncluded: + type: boolean + default: false + description: If true, the `amount` is tax included, if false the `amount` is provided without tax. In both cases, `taxAmount` could be indicated to provide tax amount. + taxAmount: + type: number + format: float + multipleOf: 0.001 + minimum: 0 + description: | + The tax amount refunded by the merchant. Indicated when the merchant is the one applying taxes. This field also provides an indicator to the downstream billing system. + example: 21 CloudEvent: description: The notification format required: