Versions Compared
Version | Old Version 64 | New Version 65 |
---|---|---|
Changes made by | ||
Saved on |
Key
- This line was added.
- This line was removed.
- Formatting was changed.
InPost Pay (Basket App) - jest to moduł udostępniający API, pozwalający na wymianę informacji o koszyku i realizacji zamówienia. W tej sekcji znajdziesz informacje o metodach API udostępnionych przez InPost służących do komunikacji pomiędzy Merchantem a InPost Pay.
Na tej stronie
Table of Contents |
---|
InPost Pay API
Środowisko produkcyjne
Adres środowiska produkcyjnego:https://api.inpost.pl
Środowisko sandbox
Adres środowiska testowego: https://sandbox-api.inpost.pl
Lista endpointów
Poniższa tabel przedstawia listę endpointów wystawionych przez aplikacje InPost Pay, służących do komunikacji pomiędzy Merchantem a aplikacją InPost Pay.
Metoda | Opis | |
---|---|---|
Przeglądarka | Metoda usuwa powiązaną przeglądarkę lub usuwa telefon z powiązanej przeglądarki. | |
Koszyk | Metoda aktualizuje lub tworzy koszyk, np. zmienia ilość produktów, typ dostawy itp | |
Desynchronizacja koszyka z numerem telefonu | ||
Metoda łączy koszyk z aplikacją InPost | ||
Metoda sprawdza, czy koszyk jest połączony z aplikacją InPost | ||
Opcjonalny endpoint back office'owy, zwraca listę koszyków dla Merchanta | ||
Zamówienie | Aktualizacja zamówienia | |
Opcjonalny endpoint back office'owy, zwraca listę zamówień dla Merchanta | ||
Płatności | Zwraca metody płatności dostępne dla Merchanta - metoda dostępna w kolejnej wersji aplikacji | |
Weryfikacja sygnatury | Zwraca publiczne klucze podpisujące | |
Zwraca publiczny klucz podpisujący dla wersji |
Confluence open api |
---|
--- openapi: 3.0.3 info: title: Swagger description: 'Basket APP API for Merchant' version: 4.0.1 tags: - name: Browser description: Provides access to binding browsers. - name: Basket description: Provides access to managing baskets. - name: Order description: Provides access to managing orders. - name: Payment description: Payment - name: Signature verification description: Signature verification paths: /v1/izi/basket/{basket_id}: put: tags: - Basket summary: Create or update a basket. Consumer Basket App. description: This method updates or creates a basket e.g. change products quantity, delivery type etc. operationId: addFaq parameters: - name: basket_id in: path description: ID basket assigned by merchant to update required: true style: simple explode: false schema: type: string requestBody: content: application/json: schema: $ref: '#/components/schemas/basket_request_put' required: true responses: "200": description: Create or update basket response content: application/json: schema: $ref: '#/components/schemas/response_put_basket' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "400": description: Bad request. content: application/json: schema: $ref: '#/components/schemas/error' examples: argumentNotValidError: $ref: '#/components/examples/argumentNotValidError' malformedRequest: $ref: '#/components/examples/malformedRequest' "404": description: Resource not found. content: application/json: schema: $ref: '#/components/schemas/error' examples: basketNotFound: $ref: '#/components/examples/basketNotFound' browserNotFound: $ref: '#/components/examples/browserNotFound' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' basketExpired: $ref: '#/components/examples/basketExpired' /v1/izi/basket/{basket_id}/binding: delete: tags: - Basket summary: Desynchronisation of basket with telephone number description: Desynchronisation of basket with telephone number operationId: deleteBasketMerchant parameters: - name: basket_id in: path description: ID basket assigned by merchant to update required: true style: simple explode: false schema: type: string - name: if_basket_realized in: query description: If basket deleted because order completed at merchant required: false style: form explode: false schema: type: boolean responses: "204": description: basket deleted "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "404": description: Resource not found. content: application/json: schema: $ref: '#/components/schemas/error' examples: basketNotFound: $ref: '#/components/examples/basketNotFound' "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' basketExpired: $ref: '#/components/examples/basketExpired' basketNotBoundError: $ref: '#/components/examples/basketNotBoundError' post: tags: - Basket summary: Binding basket and InPost app. description: This method connect basket with InPost app. operationId: updateBasket parameters: - name: basket_id in: path description: ID basket assigned by merchant required: true style: simple explode: false schema: type: string requestBody: content: application/json: schema: $ref: '#/components/schemas/request_basket_binding' responses: "200": description: Basket response if binding_method = DEEP_LINK content: application/json: schema: $ref: '#/components/schemas/response_basket_binding' "202": description: Basket response if binding_method = PHONE "400": description: Bad request. content: application/json: schema: $ref: '#/components/schemas/error' examples: argumentNotValidError: $ref: '#/components/examples/argumentNotValidError' malformedRequest: $ref: '#/components/examples/malformedRequest' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: basketBoundError: $ref: '#/components/examples/basketBoundError' merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' basketExpired: $ref: '#/components/examples/basketExpired' phoneBindingMethodUnavailableError: $ref: '#/components/examples/phoneBindingMethodUnavailableError' bindingRedundantPhoneError: $ref: '#/components/examples/bindingRedundantPhoneError' bindingPhoneRequiredError: $ref: '#/components/examples/bindingPhoneRequiredError' bindingBrowserRequiredError: $ref: '#/components/examples/bindingBrowserRequiredError' get: tags: - Basket summary: Information about basket bound with InPost Pay and trusted browser. description: This method verify if basket is connected with InPost app. operationId: verifyBasket parameters: - name: basket_id in: path description: ID basket assigned by merchant required: true style: simple explode: false schema: type: string - name: browser_id in: query description: ID basket to update required: false style: form explode: false schema: type: string responses: "200": description: Basket response content: application/json: schema: $ref: '#/components/schemas/response_basket_connected' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' basketExpired: $ref: '#/components/examples/basketExpired' /v1/izi/baskets: get: tags: - Basket summary: Returns baskets list for merchnat description: Returns baskets list for merchnat operationId: basketsList parameters: - name: page_index in: query required: false style: form explode: true schema: type: string - name: page_size in: query required: false style: form explode: true schema: type: string responses: "200": description: Basket details content: application/json: schema: $ref: '#/components/schemas/merchant_baskets' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' /v1/izi/browser/{browser_id}/binding: delete: tags: - Browser summary: Deletes a binded browser. description: Method deletes binded browser or removes phone from binded browser. operationId: deleteBrowserMerchant parameters: - name: browser_id in: path description: ID of browser required: true style: simple explode: false schema: type: string responses: "204": description: browser deleted "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "404": description: Resource not found. content: application/json: schema: $ref: '#/components/schemas/error' examples: browserNotFound: $ref: '#/components/examples/browserNotFound' "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' /v1/izi/order/{order_id}/event: post: tags: - Order summary: Update order operationId: updateOrderMerchant parameters: - name: order_id in: path description: ID order assigned by merchant to update required: true style: simple explode: false schema: type: string requestBody: content: application/json: schema: $ref: '#/components/schemas/request_order_event_merchant' required: true responses: "200": description: Order update default: description: unexpected error content: application/json: schema: $ref: '#/components/schemas/error' "400": description: Bad request. content: application/json: schema: $ref: '#/components/schemas/error' examples: argumentNotValidError: $ref: '#/components/examples/argumentNotValidError' malformedRequest: $ref: '#/components/examples/malformedRequest' "404": description: Resource not found. content: application/json: schema: $ref: '#/components/schemas/error' examples: orderNotFound: $ref: '#/components/examples/orderNotFound' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' orderStatusError: $ref: '#/components/examples/orderStatusError' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. /v1/izi/orders: get: tags: - Order summary: Returns orders list for merchant description: Returns orders list for merchant operationId: ordersList parameters: - name: page_index in: query required: false style: form explode: true schema: type: string - name: page_size in: query required: false style: form explode: true schema: type: string responses: "200": description: Get list of orders content: application/json: schema: $ref: '#/components/schemas/orders_list' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' /v1/izi/signing-keys/public: get: tags: - Signature verification summary: Returns public signing keys description: Returns public signing keys operationId: signingKeys responses: "200": description: Get list of orders content: application/json: schema: $ref: '#/components/schemas/response_signing_keys' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' /v1/izi/signing-keys/public/{version}: get: tags: - Signature verification summary: Returns public signing key for version description: Returns public signing key for version operationId: versionSigningKeys parameters: - name: version in: path description: version required: true style: simple explode: false schema: type: string responses: "200": description: Get list of orders content: application/json: schema: $ref: '#/components/schemas/response_version_signing_keys' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' "404": description: Resource not found. content: application/json: schema: $ref: '#/components/schemas/error' examples: publicKeyNotFound: $ref: '#/components/examples/publicKeyNotFound' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' /v1/izi/payments: get: tags: - Payment summary: Returns returns available payment types for merchant - method available in next version of app description: Returns returns available payment types for merchant - method available in next version of app operationId: paymentsTypes responses: "200": description: Get list of orders content: application/json: schema: $ref: '#/components/schemas/responseGetPayments' "401": content: application/json: example: error_code: UNAUTHORIZED error_message: Given user is not authorized to access the resource. schema: $ref: '#/components/schemas/error' description: Unauthorized. "403": content: application/json: example: error_code: FORBIDDEN error_message: Access to given resource is forbidden for current user. schema: $ref: '#/components/schemas/error' description: Forbidden. "500": description: Internal server error content: application/json: schema: $ref: '#/components/schemas/error' examples: internalServerError: $ref: '#/components/examples/internalServerError' "409": description: Conflict. Request cannot be handled with the current state of the target resource. content: application/json: schema: $ref: '#/components/schemas/error' examples: merchantDisabledError: $ref: '#/components/examples/merchantDisabledError' components: examples: merchantDisabledError: value: error_code: MERCHANT_DISABLE error_message: 'Merchant with given id is DISABLED' summary: MERCHANT_DISABLE description: Service is temporarily disabled, because of to many incorrect requests or manual blockade basketBoundError: value: error_code: BASKET_IS_BINDED error_message: 'Basket already bound' summary: BASKET_IS_BINDED description: Basket already bound. basketExpired: value: error_code: BASKET_EXPIRED error_message: 'Basket expired' summary: BASKET_EXPIRED description: Basket expired and will be removed soon. basketNotBoundError: value: error_code: BASKET_NOT_BOUND error_message: 'Basket not bound' summary: BASKET_NOT_BOUND description: Basket not bound. bindingRedundantPhoneError: value: error_code: ERROR_VALIDATION_PHONE_NUMBER error_message: 'Phone number required for PHONE binding method only' summary: ERROR_VALIDATION_PHONE_NUMBER description: Phone number should not be passed for binding methods other than PHONE. bindingPhoneRequiredError: value: error_code: ERROR_VALIDATION_PHONE_NUMBER_REQUIRED error_message: 'Phone number is required' summary: ERROR_VALIDATION_PHONE_NUMBER_REQUIRED description: Phone number is required for PHONE method binding. bindingBrowserRequiredError: value: error_code: ERROR_VALIDATION_BROWSER_REQUIRED error_message: 'Browser is required for PHONE binding method' summary: ERROR_VALIDATION_BROWSER_REQUIRED description: Browser details are required for PHONE binding method phoneBindingMethodUnavailableError: value: error_code: PHONE_BINDING_METHOD_UNAVAILABLE error_message: 'Unavailable' summary: PHONE_BINDING_METHOD_UNAVAILABLE description: Phone binding method temporarily unavailable for requested number. orderStatusError: value: error_code: STATUS_ORDER_ERROR error_message: 'Unavailable' summary: STATUS_ORDER_ERROR description: Can't be changed ORDER_COMPLETED publicKeyNotFound: value: error_code: PUBLIC_KEY_NOT_FOUND error_message: 'Public key version {} not found' summary: PUBLIC_KEY_NOT_FOUND description: public key not found argumentNotValidError: value: error_code: BAD_REQUEST error_message: Invalid request. summary: BAD_REQUEST description: Request validation error. Error message might optionally contain information about constraint violations. malformedRequest: value: error_code: MALFORMED_REQUEST error_message: Request not readable. summary: MALFORMED_REQUEST description: The server was not able to read the request. notFound: value: error_code: NOT_FOUND error_message: Resource not found. summary: NOT_FOUND description: The server was not able to read the request. basketNotFound: value: error_code: BASKET_NOT_FOUND error_message: Basket not found. summary: BASKET_NOT_FOUND description: Basket not found. orderNotFound: value: error_code: ORDER_NOT_FOUND error_message: Order not found. summary: ORDER_NOT_FOUND description: Order not found. browserNotFound: value: error_code: BROWSER_NOT_FOUND error_message: Browser not found summary: BROWSER_NOT_FOUND description: Browser not found . internalServerError: value: error_code: INTERNAL_SERVER_ERROR error_message: Something went wrong. Please try again later. summary: INTERNAL_SERVER_ERROR description: The server encountered unexpected error. schemas: error: required: - errorCode type: object properties: error_code: type: string description: Code that indicates the nature of an error. error_message: type: string description: Additional information which may be useful. merchant_baskets: type: object properties: page_size: type: integer description: page size total_items: type: integer description: total items page_index: type: integer description: page index baskets: type: array description: baskets list items: $ref: '#/components/schemas/merchant_basket_details' request_order_event_merchant: type: object required: - event_id - event_data_time - event_data properties: event_id: type: string description: event id event_data_time: type: string description: event date time phone_number: $ref: '#/components/schemas/phone_number' event_data: $ref: '#/components/schemas/event_data_merchant' basket_request_put: type: object required: - summary - delivery - products - consents properties: browser_id: type: string description: browser id summary: $ref: '#/components/schemas/basket_summary' delivery: type: array description: delivery list items: $ref: '#/components/schemas/delivery_basket_response' promo_codes: type: array description: promo codes items: $ref: '#/components/schemas/promo_codes' products: type: array description: products order list items: $ref: '#/components/schemas/get_products' related_products: type: array description: related product information items: $ref: '#/components/schemas/get_related_products' consents: type: array description: consents list items: $ref: '#/components/schemas/consents' merchant_store: type: object required: - url - cookies properties: url: type: string description: Url of the merchant shop or direct address to cart example: "https://uat.outofthebox.pl/cart/" cookies: type: array items: $ref: '#/components/schemas/cookies' get_products: type: object required: - product_id - product_name - base_price - quantity properties: product_id: type: string description: product id product_category: type: string description: product category ean: type: string description: ean code product_name: type: string description: product name product_description: type: string description: product description product_link: type: string description: product link product_image: type: string description: product image additional_product_images: type: array description: additional product images. Object available in next version app items: $ref: '#/components/schemas/product_images' base_price: $ref: '#/components/schemas/base_price' promo_price: $ref: '#/components/schemas/base_price' lowest_price: $ref: '#/components/schemas/base_price' quantity: $ref: '#/components/schemas/quantity' product_attributes: type: array description: product attributes items: $ref: '#/components/schemas/product_attributes' variants: type: array description: variant product ordered list items: $ref: '#/components/schemas/variants' delivery_product: type: array description: additional delivery information for product - object for use in next version app items: $ref: '#/components/schemas/delivery_product' get_related_products: type: object required: - product_id - product_name - base_price - quantity properties: product_id: type: string description: product id product_category: type: string description: product category ean: type: string description: ean code product_name: type: string description: product name product_description: type: string description: product description product_link: type: string description: product link product_image: type: string description: product image additional_product_images: type: array description: additional product images. Object available in next version app items: $ref: '#/components/schemas/product_images' base_price: $ref: '#/components/schemas/base_price' promo_price: $ref: '#/components/schemas/base_price' lowest_price: $ref: '#/components/schemas/base_price' quantity: $ref: '#/components/schemas/quantity' product_attributes: type: array description: product attributes items: $ref: '#/components/schemas/product_attributes' variants: type: array description: variant product ordered list items: $ref: '#/components/schemas/variants' delivery_related_products: type: array description: additional delivery information for product - object for use in next version app items: $ref: '#/components/schemas/delivery_related_products' get_products_order: type: object required: - product_id - product_name - base_price - quantity properties: product_id: type: string description: product id product_category: type: string description: product category ean: type: string description: ean code product_name: type: string description: product name product_description: type: string description: product description product_link: type: string description: product link product_image: type: string description: product image additional_product_images: type: array description: additional product images. Object available in next version app items: $ref: '#/components/schemas/product_images' base_price: $ref: '#/components/schemas/base_price' lowest_price: $ref: '#/components/schemas/base_price' quantity: $ref: '#/components/schemas/quantity_order' product_attributes: type: array description: product attributes items: $ref: '#/components/schemas/product_attributes' variants: type: array description: variant product ordered list items: $ref: '#/components/schemas/variants' variants: type: object description: variant product ordered required: - variant_id - variant_name properties: variant_id: type: string description: variant id variant_name: type: string description: variant name variant_description: type: string description: variant description variant_type: type: string description: variant type variant_values: type: string description: variant values consents: type: object description: Consents list required: - consent_id - consent_description - consent_version - requirement_type - consent_link properties: consent_id: type: string description: consent id consent_link: type: string description: consent link label_link: type: string description: label link presented in app additional_consent_links: type: array description: Object to additional links on consents. Available in next version of app items: $ref: '#/components/schemas/additional_consent_links' consent_description: type: string description: consent description consent_version: type: string description: consent version requirement_type: type: string enum: - OPTIONAL - REQUIRED_ONCE - REQUIRED_ALWAYS description: information on requirement consent additional_consent_links: type: object required: - consent_id - consent_link properties: consent_id: type: string description: consent id consent_link: type: string description: consent link label_link: type: string description: label link presented in app delivery: type: object description: delivery information required: - delivery_type - delivery_price - delivery_date properties: delivery_type: type: string enum: - APM - COURIER description: delivery type (APM; COURIER) delivery_date: description: delivery date type: string format: date-time delivery_options: type: array description: delivery options items: $ref: '#/components/schemas/delivery_options' mail: type: string description: email phone_number: $ref: '#/components/schemas/phone_number' delivery_point: type: string description: APM delivery point delivery_address: $ref: '#/components/schemas/delivery_address' delivery_price: $ref: '#/components/schemas/base_price' courier_note: type: string description: additional information for courier delivery_address: type: object description: delivery address required: - name - country_code - address - city - postal_code properties: name: type: string description: name country_code: type: string description: country code address: type: string description: address city: type: string description: city postal_code: type: string description: postal code client_address: type: object description: delivery address required: - country_code - address - city - postal_code properties: country_code: type: string description: country code address: type: string description: address city: type: string description: city postal_code: type: string description: postal code delivery_basket_response: type: object required: - delivery_type - delivery_date - delivery_price properties: delivery_type: type: string description: delivery type (APM; COURIER) enum: - APM - COURIER delivery_date: type: string format: date-time description: delivery date delivery_options: type: array description: delivery options items: $ref: '#/components/schemas/delivery_options' delivery_price: $ref: '#/components/schemas/base_price' free_delivery_minimum_gross_price: type: number format: decimal description: free delivery minimum gross price delivery_options: type: object description: additional delivery options required: - delivery_name - delivery_code_value - delivery_option_price properties: delivery_name: type: string description: delivery name example: Paczka w Weekend delivery_code_value: type: string enum: - COD - PWW description: delivery code value. COD - option with payment on delivery, PWW - option with weekend delivery example: PWW delivery_option_price: $ref: '#/components/schemas/base_price' basket_summary: type: object required: - basket_base_price - currency - payment_type properties: basket_base_price: $ref: '#/components/schemas/base_price' basket_final_price: $ref: '#/components/schemas/base_price' basket_promo_price: $ref: '#/components/schemas/base_price' currency: type: string description: basket currency enum: - PLN basket_expiration_date: type: string format: date-time description: expiry date of basket basket_additional_information: type: string description: additional information payment_type: type: array description: payment type items: $ref: '#/components/schemas/payment_type' basket_notice: $ref: '#/components/schemas/information' payment_type: type: string description: payment type enum: - CARD - CARD_TOKEN - GOOGLE_PAY - APPLE_PAY - BLIK_CODE - BLIK_TOKEN - PAY_BY_LINK - SHOPPING_LIMIT - DEFERRED_PAYMENT - CASH_ON_DELIVERY invoice_details: type: object description: invoice details properties: legal_form: type: string description: legal form of customer enum: - PERSON - COMPANY country_code: type: string description: country code tax_id_prefix: type: string description: tax id prefix tax_id: type: string description: tax id company_name: type: string description: company name name: type: string description: name surname: type: string description: surname city: type: string description: city street: type: string description: street building: type: string description: number building flat: type: string description: number flat postal_code: type: string description: postal code mail: type: string description: email registration_data_edited: type: string description: registration data edited additional_information: type: string description: additional information account_info: type: object required: - name - surname - phone_number - client_address - mail properties: name: type: string description: name surname: type: string description: surname phone_number: $ref: '#/components/schemas/phone_number' mail: type: string description: email client_address: $ref: '#/components/schemas/client_address' consents_order: type: object description: consents order list required: - consent_id - is_accepted properties: consent_id: type: string description: consent id consent_version: type: string description: consent version is_accepted: type: boolean description: is accepted consent orders_list: type: object description: orders details list properties: page_size: type: integer description: page size total_items: type: integer description: total size page_index: type: integer description: page index orders: type: array items: $ref: '#/components/schemas/merchant_order_response' get_payment: required: - payment_type - payment_status properties: payment_type: type: string description: order status enum: - CARD - CARD_TOKEN - GOOGLE_PAY - APPLE_PAY - BLIK_CODE - BLIK_TOKEN - PAY_BY_LINK - SHOPPING_LIMIT - DEFERRED_PAYMENT - CASH_ON_DELIVERY payment_status: type: string description: payment status. UNPAID - status after creation of order. unpaid (assigned by BasketApp), STARTED - status initiating payment reference process and returning payment type selected by customer (assigned by BasketApp), PENDING - start of process in PEGAZ/SDK with success (assigned by Basket or PEGAZ), AUTHORIZED - payment successfully completed, funds blocked (assigned by PEGAZ), DECLINED - payment refused (assigned by PEGAZ), CANCELLED - payment cancelled (assigned by PEGAZ), ERROR - error (assigned by PEGAZ or INPOST), COD- cash on delivery enum: - UNPAID - STARTED - PENDING - AUTHORIZED - DECLINED - CANCELLED - ERROR - COD available_payment_types: type: array description: available payment types for order items: $ref: '#/components/schemas/payment_type' payment_details: $ref: '#/components/schemas/payment_details' payment_details: type: object required: - payment_type - payment_status - payment_reference properties: payment_reference: type: string description: payment reference payment_id: type: string description: payment reference payment_sec_token: type: string description: security token used to payment process payment_type: type: string description: order status enum: - CARD - CARD_TOKEN - GOOGLE_PAY - APPLE_PAY - BLIK_CODE - BLIK_TOKEN - PAY_BY_LINK - SHOPPING_LIMIT - DEFERRED_PAYMENT - CASH_ON_DELIVERY payment_token: type: string description: card token or blik alias payment_card: $ref: '#/components/schemas/payment_card' payment_status: type: string description: payment status. UNPAID - status after creation of order. unpaid (assigned by BasketApp), STARTED - status initiating payment reference process and returning payment type selected by customer (assigned by BasketApp), PENDING - start of process in PEGAZ/SDK with success (assigned by Basket or PEGAZ), AUTHORIZED - payment successfully completed, funds blocked (assigned by PEGAZ), DECLINED - payment refused (assigned by PEGAZ), CANCELLED - payment cancelled (assigned by PEGAZ), ERROR - error (assigned by PEGAZ or INPOST), COD - cash on delivery enum: - UNPAID - STARTED - PENDING - AUTHORIZED - DECLINED - CANCELLED - ERROR - COD payment_code: type: string description: payment code payment_description: type: string description: payment description payment_error_code: type: string description: payment error code payment_message_code: type: string description: payment error code payment_date: type: string format: date-time description: payment date delivery_references: type: string description: delivery references promo_codes: type: object description: promo codes required: - name - promo_code_value properties: name: type: string description: promo code name promo_code_value: type: string description: promo code value product_attributes: type: object description: product attributes required: - attribute_name - attribute_value properties: attribute_name: type: string description: attribute name attribute_value: type: string description: attribute value response_basket_binding: type: object required: - qr_code - deep_link - deep_link_hms properties: qr_code: type: string description: qr-code deep_link: type: string description: deep link deep_link_hms: type: string description: deep link response_basket_connected: type: object required: - basket_linked - browser_trusted properties: basket_linked: type: boolean description: is basket linked inpost_basket_id: type: string description: basket id created by BasketApp browser_trusted: type: boolean description: is browser trusted client_details: $ref: '#/components/schemas/client_details' client_details: type: object required: - phone_number - masked_phone_number - name - surname properties: phone_number: $ref: '#/components/schemas/phone_number' masked_phone_number: type: string description: masked phone number example: 60*****00 name: type: string description: client name surname: type: string description: client surname event_data_merchant: type: object description: Data on events properties: order_status: type: string description: order status - Merchant can change order status to; ORDER_COMPLETED - order completed in merchant's shop, ORDER_REJECTED - order rejected by merchant enum: - ORDER_COMPLETED - ORDER_REJECTED order_merchant_status_description: type: string description: order merchant status description delivery_references_list: type: array description: delivery references list items: $ref: '#/components/schemas/delivery_references' base_price: required: - net - gross - vat properties: net: type: number format: decimal description: net price gross: type: number format: decimal description: gross price vat: type: number format: decimal description: VAT quantity: type: object description: product quantity required: - quantity properties: quantity: type: number description: product quantity quantity_type: type: string enum: - DECIMAL - INTEGER description: product quantity type quantity_unit: type: string description: unit quantity available_quantity: type: number format: decimal description: product quantity available max_quantity: type: number format: decimal description: maximum product quantity min_quantity: type: number format: decimal description: minimum product quantity. Field available in next version app quantity_order: type: object description: product quantity required: - quantity properties: quantity: type: number description: product quantity quantity_type: type: string enum: - DECIMAL - INTEGER description: product quantity type quantity_unit: type: string description: unit quantity phone_number: type: object description: phone number required: - country_prefix - phone properties: country_prefix: type: string description: prefix example: '+48' phone: type: string example: 600123123 request_basket_binding: allOf: - type: object required: - browser properties: binding_method: type: string enum: - PHONE - DEEP_LINK description: binding method binding_place: type: string enum: - PRODUCT_CARD - BASKET_SUMMARY - ORDER_CREATE - BASKET_POPUP - THANK_YOU_PAGE - LOGIN_PAGE - CHECKOUT_PAGE - REGISTERFORM_PAGE - MINICART_PAGE description: client binding place phone_number: $ref: '#/components/schemas/phone_number' browser: $ref: '#/components/schemas/browser_details' browser_details: type: object description: browser details required: - browser_id - user_agent - platform - architecture - data_time - location - customer_ip - port properties: user_agent: type: string description: user agent description: type: string description: additional description platform: type: string description: platform architecture: type: string description: architecture data_time: type: string format: date-time description: tiem location: type: string description: location customer_ip: type: string description: browser id port: type: string description: port merchant_order_response: type: object required: - order_details - account_info - delivery - products - consents properties: order_details: $ref: '#/components/schemas/merchant_orders_details' account_info: $ref: '#/components/schemas/account_info' invoice_details: $ref: '#/components/schemas/invoice_details' delivery: $ref: '#/components/schemas/delivery' products: type: array description: products order list items: $ref: '#/components/schemas/get_products_order' consents: type: array description: consents list items: $ref: '#/components/schemas/consents_order' merchant_orders_details: type: object required: - order_id - merchant_order_id - pos_id - order_creation_date - merchant_id - basket_hash - payment_status - order_status - order_merchant_status_description - order_base_price - order_final_price - currency properties: order_comments: type: string description: order information order_id: type: string description: ID order assigned by merchant customer_order_id: type: string description: order ID presented to customer and used for payment. In case of lack of customer_order_id order_id will be used. pos_id: type: string description: POS identifier provided by Vodeno, allowing merchant to filter payments in the reporting tools order_creation_date: type: string format: date-time description: order creation date order_update_date: type: string format: date-time description: order update date payment: $ref: '#/components/schemas/get_payment' order_status: type: string description: order status. ORDER_PROCESSING - status given by Basket App when order is created, payment possible ORDER_COMPLETED - order completed at merchant, payment not possible, ORDER_REJECTED - order rejected by merchant or at Inpost app, payment not possible. enum: - ORDER_COMPLETED - ORDER_REJECTED - ORDER_PROCESSING order_merchant_status_description: type: string description: order merchant status description order_base_price: type: object description: price for order without delivery costs required: - net - gross - vat properties: net: type: number format: decimal description: net price gross: type: number format: decimal description: gross price vat: type: number format: decimal description: VAT order_final_price: type: object description: total order price with delivery costs required: - net - gross - vat properties: net: type: number format: decimal description: net price gross: type: number format: decimal description: gross price vat: type: number format: decimal description: VAT order_discount: type: number format: decimal description: Value used discount coupons on order currency: type: string description: basket currency enum: - PLN delivery_references_list: type: array description: delivery references list items: $ref: '#/components/schemas/delivery_references' merchant_basket_details: type: object required: - summary - delivery - products - consents properties: basket_id: type: string description: ID basket assigned by merchant creation_date: type: string format: date-time description: date basket creation update_date: type: string format: date-time description: date basket update summary: $ref: '#/components/schemas/basket_summary' delivery: type: array description: delivery list items: $ref: '#/components/schemas/delivery_basket_response' promo_codes: type: array description: promo codes items: $ref: '#/components/schemas/promo_codes' products: type: array description: products order list items: $ref: '#/components/schemas/get_products' related_products: type: array description: related product information items: $ref: '#/components/schemas/get_related_products' consents: type: array description: consents list items: $ref: '#/components/schemas/consents' information: type: object required: - type - description properties: type: type: string enum: - ATTENTION - ERROR description: type additional notice description: type: string description: basket additional notice payment_card: type: object required: - type - description properties: last_four_digits: type: string description: Last 4 digits of original PAN (card number) scheme: type: string description: Scheme in which the card operates card_type: type: string enum: - DEBIT - CREDIT - PREPAID - CHARGE - DEFERRED_DEBIT description: Scheme in which the card operates response_signing_keys: type: object properties: merchant_external_id: type: string description: merchant external id public_keys: type: array description: public keys items: $ref: '#/components/schemas/public_key' public_key: type: object required: - type - description properties: public_key_base64: type: string description: public key in format base64 version: type: string description: version response_version_signing_keys: type: object properties: merchant_external_id: type: string description: merchant external id public_key: properties: public_key_base64: type: string description: public key in format base64 version: type: string description: version response_put_basket: type: object required: - inpost_basket_id properties: inpost_basket_id: type: string description: basket id created by BasketApp delivery_product: type: object description: additional delivery information for product properties: delivery_type: type: string description: delivery type (APM; COURIER) enum: - APM - COURIER if_delivery_available: type: boolean description: if type of delivery available for product delivery_related_products: type: object description: additional delivery information for product properties: delivery_type: type: string description: delivery type (APM; COURIER) enum: - APM - COURIER if_delivery_free: type: boolean description: is free delivery for a type of delivery if_delivery_available: type: boolean description: if type of delivery available for product responseGetPayments: type: object required: - payment_type properties: payment_type: type: array description: payment type items: $ref: '#/components/schemas/payment_type' product_images: type: object description: additional product images required: - small_size - normal_size properties: small_size: type: string description: product image. Preferred size 360 x 352 normal_size: type: string description: product image. Preferred size 360 x 504 cookies: required: - domain - keyValue - key - value - path type: object properties: domain: type: string description: Domain of the cookie represented by pair key-value example: "uat.outofthebox.pl" key: type: string description: Cookie key example: "wp_woocommerce_session_f3cd21b400c074e165b59837d7a9d0a4" value: type: string description: Cookie value example: "t_f13664beda2ec455d97546c1ddab8b%7C%7C1699438060%7C%7C1699434460%7C%7Cf77d310ce1f0440cb4812f5043736989" path: type: string description: Cookie path example: "/" expires: type: string description: Cookie expiration time or maxAge example: "2025-01-16T14:17:02.486Z" format: date-time secure: type: boolean description: Cookie security information example: false http_only: type: boolean description: Cookie http information example: true same_site: type: string enum: - STRICT - LAX - NONE description: Cookie sameSite information example: "LAX" priority: type: string enum: - LOW - MEDIUM - HIGH description: Cookie priority example: "MEDIUM" max_age: type: integer description: Cookie max age example: 0 |
Przykład implementacji w języku PHP
Tworzymy interfejs serwisu klienta, który będzie odpowiedzialny za komunikację Merchant -> InPost - InPost Pay (Basket App) .
Code Block language php <?php declare(strict_types=1); namespace Iteo\InpostPayClient\Client; use Iteo\InpostPayClient\SDK\Basket\BasketApp\Basket; use Iteo\InpostPayClient\SDK\Basket\Binding\BindingBasket; use Iteo\InpostPayClient\SDK\Basket\Binding\QrCode\QrCodeData; use Iteo\InpostPayClient\SDK\Basket\Binding\Request\BasketApp\BasketBindingRequest; use Iteo\InpostPayClient\SDK\Basket\Response\BasketsResponse; use Iteo\InpostPayClient\SDK\Basket\Response\InpostBasketId; use Iteo\InpostPayClient\SDK\Core\Exceptions\InpostPayEndpointException; use Iteo\InpostPayClient\SDK\Core\Exceptions\InpostPayPostBasketBindingException; use Iteo\InpostPayClient\SDK\Core\Exceptions\InpostPayPostOrderEventException; use Iteo\InpostPayClient\SDK\Order\Request\BasketApp\OrderEventRequest; use Iteo\InpostPayClient\SDK\Order\Response\BasketApp\OrdersResponse; use Iteo\InpostPayClient\SDK\SignatureVerification\SigningKeys\SigningKeysResponse; use Iteo\InpostPayClient\SDK\SignatureVerification\SigningVersionKey\SigningKeyResponse; /** * Client interface used for communication between Merchant and InPost Pay application. */ interface InpostPayClientInterface { /** * This method verify if basket is connected with InPost app. * * @param string $basketId ID basket assigned by merchant * @param string|null $browserId Browser ID from cookie * * @return BindingBasket Object with information about whether the browser is trusted * and whether the basket is linked * * @throws InpostPayEndpointException */ public function getBasketBinding(string $basketId, ?string $browserId): BindingBasket; /** * This method connect basket with InPost app. * * @param string $basketId ID basket assigned by merchant * @param BasketBindingRequest $requestBody Request data, needed for binding basket * * @return ?QrCodeData Object with data for QR Code when successful binding with QR Code or null * when successful binding with phone number * * @throws InpostPayPostBasketBindingException|InpostPayEndpointException */ public function postBasketBinding(string $basketId, BasketBindingRequest $requestBody): ?QrCodeData; /** * This method desynchronize basket with Inpost Pay mobile app. * * @param string $basketId ID basket assigned by merchant * @param ?bool $ifBasketRealized Information about the fact that the basket will be deleted because * it has been realized * * @throws InpostPayEndpointException */ public function deleteBasketBinding(string $basketId, ?bool $ifBasketRealized): void; /** * This method updates or creates a basket e.g. change products quantity, delivery type etc. * * @param string $basketId ID basket assigned by merchant * @param Basket $basket All Basket data * * @return InpostBasketId Object with basket ID created from Inpost mobile app * * @throws InpostPayEndpointException */ public function putBasket(string $basketId, Basket $basket): InpostBasketId; /** * This method update order. * * @param string $orderId ID order assigned by merchant * @param OrderEventRequest $orderEventRequest Information about order event, that will change order status * * @throws InpostPayPostOrderEventException|InpostPayEndpointException */ public function postOrderEvent(string $orderId, OrderEventRequest $orderEventRequest): void; /** * This method deletes binded browser from Inpost Pay mobile app. * * @param string $browserId ID browser from cookie * * @throws InpostPayEndpointException */ public function deleteBrowserBinding(string $browserId): void; /** * This method get baskets list for merchant. * * @param ?int $pageIndex Information about page index of merchant baskets list * @param ?int $pageSize Information about page size of merchant baskets list page * * @return BasketsResponse Object containing list of baskets for merchant for strict page index * * @throws InpostPayEndpointException */ public function getBaskets(?int $pageIndex, ?int $pageSize): BasketsResponse; /** * This method get orders list for merchant. * * @param ?int $pageIndex Information about page index of merchant orders list * @param ?int $pageSize Information about page size of merchant orders list page * * @return OrdersResponse Object containing list of orders for merchant for strict page index * * @throws InpostPayEndpointException */ public function getOrders(?int $pageIndex, ?int $pageSize): OrdersResponse; /** * This method get public signing keys. * * @return SigningKeysResponse Object containing list of public signing keys * * @throws InpostPayEndpointException */ public function getSigningKeys(): SigningKeysResponse; /** * This method get public signing key for version. * * @param string $version Version of signing-key * * @return SigningKeyResponse Object containing public signing key * * @throws InpostPayEndpointException */ public function getSigningKey(string $version): SigningKeyResponse; }
View file | ||
---|---|---|
|
Tworzymy interfejs url creatora, który będzie odpowiedzialny za uzyskanie odpowiedniego adresu url do API InPostPay'a.
Code Block language php <?php declare(strict_types=1); namespace Iteo\InpostPayClient\Client; /** * Interface used for creating url for communication with Inpost Pay. */ interface InpostPayURLCreatorInterface { /** * Method that return url for Inpost Pay. * * @return InpostPayURL url for Inpost Pay */ public function create(): InpostPayURL; }
View file | ||
---|---|---|
|
Tworzymy implementację serwisu url creatora dla środowiska Sandbox.
Code Block language php <?php declare(strict_types=1); namespace Iteo\InpostPayClient\Client; /** * PHP URL Creator Service implementation used for creating url to Sandbox InpostPay. */ final class SandboxInPostPayURLCreator implements InpostPayURLCreatorInterface { /** * {@inheritdoc} */ public function create(): InpostPayURL { return new InpostPayURL('https://sandbox-api.inpost.pl/v1/izi/'); } }
View file | ||
---|---|---|
|
Tworzymy implementację serwisu url creatora dla środowiska Produkcyjnego.
Code Block language php <?php declare(strict_types=1); namespace Iteo\InpostPayClient\Client; /** * PHP URL Creator Service implementation used for creating url to Production InpostPay. */ final class ProductionInPostPayURLCreator implements InpostPayURLCreatorInterface { /** * {@inheritdoc} */ public function create(): InpostPayURL { return new InpostPayURL('https://api.inpost.pl/v1/izi/'); } }
View file | ||
---|---|---|
|
Tworzymy implementację serwisu klienta, wykorzystując do tego PSR'owego klienta do komunikacji REST, oraz wcześniej zaimplementowany interfejs url creatora aby uzyskać url do API InpostPay'a oraz interfejs serwisu bearera aby uzyskać access token. Aby klient był w całości sprawny, potrzebna jest implementacja funkcji opisanych w interfejsie, odpowiedzialnych za konkretne endpointy w Lista endpointów.
Code Block language php /** * Client symfony implementation used for communication between Merchant and InPost Pay application. * * @param InpostPayBearerServiceInterface $inpostPayBearerService <p> Bearer service interface, * with contains creating bearer token which is required for communication with Inpost Pay </p> * */ final class InpostPayClient implements InpostPayClientInterface { private ClientInterface $client; private InpostPayURLCreatorInterface $URLCreator; private InpostPayBearerServiceInterface $bearerService; public function __construct( ClientInterface $client, InpostPayURLCreatorInterface $URLCreator, InpostPayBearerServiceInterface $bearerService ) { $this->client = $client; $this->URLCreator = $URLCreator; $this->bearerService = $bearerService; } /** * @return array{ * Authorization: string, * Content-Type: string * } * * @throws InpostPayEndpointException */ private function provideDefaultClientHeaders(): array { return [ 'Authorization' => sprintf('Bearer %s', $this->bearerService->getBearerToken()), 'Content-Type' => 'application/json', ]; } private function buildUri(string $path): string { return sprintf( '%s%s', $this->URLCreator->create()->getUrl(), $path ); } }
View file | ||
---|---|---|
|