Skip to main content

A simple Python package that provides convenient access to the Paymob APIs from applications written in the Python language.

Project description

\n# Paymob Python Package

python pre-commit Code style: black

Table of Contents

Description

The Paymob Python package provides convenient access to the Paymob APIs from applications written in the Python language. Current version only supports the following services:

  • Accept

Payouts and the other services will be added in the next releases.

Requirements

Before you begin, ensure you have met the following requirements:

Installation Instructions

You don't need this source code unless you want to modify the package. If you just want to use the package, just run:

pip install --upgrade paymob

Usage

Services

1- Accept Client


Handling APIs Response

Each API Call retrieves a tuple which contains three values (Code, An Object of the API's Return, ResponseFeedBack Instance)

  • Code: A Number that represents API state. Codes Reference
  • API's Return Object: An object class of the API's Return and its attributes can be accessed using dot notation.
  • Response FeedBack: An object of ResponseFeedBack class which has the following attributes:
    • message: A human readable description of the Code
    • data: A dict represents the actual API's Response
    • status_code: Status code that has been returned from the API (2xx, 4xx, 5xx)

Successful API calls will return the following values:

  • Code: One of the Following Codes
  • API's Return Object: object (Depending on the API response)
  • Response FeedBack: ResponseFeedBack Object with the following attributes:
    • message: A success message depending on the API (Example: Get Order API will return a message like "Successfully Retrieved Order: 1")
    • data: None
    • status_code: 2xx

Example:

from paymob.accept import AcceptAPIClient

accept_api_client = AcceptAPIClient()
code, transaction, feedback = accept_api_client.get_transaction(
    transaction_id=112233
)

print(f"Code: {code}")
print(f"Transaction: {transaction}")
print(f"Transaction ID: {transaction.id}")
print(f"Feedback Message: {feedback.message}")
print(f"Feedback Data: {feedback.data}")
print(f"Feedback Status Code: {feedback.status_code}")

Output:

Code: 10
Transaction: Transaction No: 111859918
Transaction ID: 111859918
Feedback Message: Transaction: 111859918 Retrieved Successfully
Feedback Data: None
Feedback Status Code: 200

Unsuccessful API calls will return the following values:

  • Code: One of the Following Codes
  • API's Return Object: Example: Get Transaction API will return a Transaction instance (transaction.id, transaction.success, ..etc)
  • Response FeedBack: ResponseFeedBack Object with the following attributes:
    • message: A failure message depending on exception occured (Example: "An Error Occurred During the Request")
    • data: API's response dict (response.json())
    • status_code: 4xx or 5xx

Example:

from paymob.accept import AcceptAPIClient

accept_api_client = AcceptAPIClient()
code, transaction, feedback = accept_api_client.get_transaction(
    transaction_id=112233
)

print(f"Code: {code}")
print(f"Transaction: {transaction}")
print(f"Feedback Message: {feedback.message}")
print(f"Feedback Data: {feedback.data}")
print(f"Feedback Status Code: {feedback.status_code}")

Output:

Code: 22
Transaction: None
Feedback Message: Non 2xx Status Code Returned.
Feedback Data: {'detail': 'Not found.'}
Feedback Status Code: 404

Codes Reference

Success Codes

Variable Code Description
SUCCESS 10 API Called Successfully Without any Failures

Error Codes

Variable Code Description
JSON_DECODE_EXCEPTION 20 An Error Occurred While Parsing the Response into JSON
REQUEST_EXCEPTION 21 An Error Occurred During the Request
HTTP_EXCEPTION 22 Non 2xx Status Code Returned
UNHANDLED_EXCEPTION 23 Unhandled Exception [comment]: # Trace Error will be provided in the message

You can import these codes like the following:

from paymob.accept.response_codes import (
    SUCCESS, 
    JSON_DECODE_EXCEPTION, 
    REQUEST_EXCEPTION, 
    HTTP_EXCEPTION, 
    UNHANDLED_EXCEPTION
)

Settings

You can customized some behaves of Paymob by adding the following settings in .env file.

- ACCEPT_APIS_TIMEOUT_SECONDES

Sets Timeout for API Calls (The connect timeout is the number of seconds Requests will wait for your client to establish a connection or read data with/from Paymob server)

Example:

ACCEPT_APIS_TIMEOUT_SECONDES=20

- VALIDATE_API_RESPONSE (Not Added Yet)

Automatically validates the returned data of the APIs to ensure that there are no changed keys or data types

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Paymob-Toolbox-0.0.1.tar.gz (17.9 kB view hashes)

Uploaded Source

Built Distribution

Paymob_Toolbox-0.0.1-py3-none-any.whl (25.4 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page