A CLI tool for integrating with Chapa API.
Project description
Chapa CLI
Chapa CLI is a command-line tool that helps you integrate, manage, and interact with Chapa's payment API directly from your terminal. This tool provides various commands to handle transactions, retrieve bank details, and more, making it easier to work with Chapa's API without the need for manual API calls.
Chapa CLI in Action
Features
- Initialize Transactions: Create new transactions directly from the CLI.
- Verify Transactions: Check the status of a transaction.
- Get Banks: Retrieve a list of supported banks.
- Get Transaction Events: Fetch and display events related to a specific transaction.
- Webhook Management: Listen to and test webhooks, including signature verification using HMAC SHA256.
Installation
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 chapa-cli
Install from source with:
Prerequisites
- Python 3.7 or later (PyPy supported)
- pip (Python package installer)
Steps
-
Clone the Repository:
git clone https://github.com/chapa-Et/chapa-cli.git cd chapa-cli
-
Create and Activate a Virtual Environment:
python -m venv chapa-env source chapa-env/bin/activate # On Windows use: chapa-env\Scripts\activate
-
Install the CLI:
pip install -e .
Usage
Login
Before using most commands, you need to log in by providing your Chapa API token.
chapa login
You will be prompted to enter your Chapa secret token. This token is securely stored and used for authenticating API requests.
Initialize a Transaction
chapa transaction initialize --amount 100 --phone 0911112233 --tx_ref REF123 --callback_url https://souq.com/callback
Verify a Transaction
chapa transaction verify --reference REF123
Get Supported Banks
chapa transaction banks
Get Transaction Events
chapa transaction events AP9ARo9XvMO5
Webhook Management
Listen to a Webhook
chapa webhook listen /pay/chapa-webhook
Ping a Webhook
chapa webhook ping http://localhost:5000/pay/chapa-webhook
Verify a Webhook URL
You can verify your webhook URL using Chapa's standard webhook protocol, which includes checking the URL's reachability, support for the POST method, SSL certificate validity, and validating the webhook signature with a provided secret key.
chapa webhook verifywebhook https://webhook.site/your-webhook-url --usekey your_secret_key
- URL: The webhook URL you want to verify.
- --usekey: (Optional) Your secret key used to sign the request and validate the response. This is crucial for ensuring the integrity and authenticity of webhook requests.
Configuration
Storing the Token
Your Chapa secret token is stored in a configuration file located at ~/.chapa-cli_config.json
. This file is created when you log in using the chapa login
command.
Environment Variables
If needed, you can also set environment variables for the CLI:
CHAPA_API_TOKEN
: Set this to your Chapa API token if you want to bypass the login prompt.
Development
Running Tests
To run tests, you can use pytest
or any other testing framework of your choice:
pytest
Contributing
Contributions are welcome! Please fork the repository, make your changes, and submit a pull request.
- Fork the repository.
- Create your feature branch:
git checkout -b feature/your-feature-name
. - Commit your changes:
git commit -am 'Add some feature'
. - Push to the branch:
git push origin feature/your-feature-name
. - Open a pull request.
License
This project is licensed under the MIT License. Check the LICENSE file for details.
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
Built Distribution
File details
Details for the file chapa_cli-0.0.4.tar.gz
.
File metadata
- Download URL: chapa_cli-0.0.4.tar.gz
- Upload date:
- Size: 11.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2eb91ed7a70fe470bf4cfff53718a2c84c57960253a73933eae27c179e203660 |
|
MD5 | 4226bfb16f2e9288a4f5ce98ed03a19d |
|
BLAKE2b-256 | ba7f60d596a1120d311c1914028a44343fe9af744993bcba44c5ffc69401633e |
File details
Details for the file chapa_cli-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: chapa_cli-0.0.4-py3-none-any.whl
- Upload date:
- Size: 11.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 97e9d85aa230bb65cb317a8c1d29feff5130939c7806300888e8d7eb4e920749 |
|
MD5 | 17521f970bde812298472746399ef32d |
|
BLAKE2b-256 | e892d3b901ef820f67de4155cd07ed4e2db7a409127a4deed90e7038af091b43 |