# paddle-billing-client
<div align="center">
[](https://github.com/websideproject/paddle-billing-client/actions?query=workflow%3Abuild)
[](https://pypi.org/project/paddle-billing-client/)
[](https://github.com/websideproject/paddle-billing-client/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Aapp%2Fdependabot)
[](https://github.com/psf/black)
[](https://github.com/PyCQA/bandit)
[](https://github.com/websideproject/paddle-billing-client/blob/main/.pre-commit-config.yaml)
[](https://github.com/websideproject/paddle-billing-client/releases)
[](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE)




Python wrapper around the new Paddle Billing API
</div>
## Paddle Classic vs Paddle Billing
- Paddle Classic is the original Paddle API, which is still in use by many merchants. More info can be found [here](https://developer.paddle.com/classic/api-reference/1384a288aca7a-api-reference)
- If you are looking for the Paddle Classic API wrapper, please see [`paddle-client`](https://github.com/paddle-python/paddle-client)
- Paddle Billing is the new API, which is just launched at 2023, August. Paddle Billing is a complete rewrite of the Paddle Classic API, and is designed to be more flexible and easier to use. More info can be found [here](https://developer.paddle.com/api-reference/overview)
### Django Integration
- For Paddle Classic, there is a Django integration available at [`dj-paddle`](https://github.com/paddle-python/dj-paddle) and [`django-paddle`](https://github.com/kennell/django-paddle)
- For Paddle Billing, there is a Work In Progress Django integration available at [`django-paddle-billing`](https://github.com/websideproject/django-paddle-billing)
---
## π¦ Features
- Pydantic models for all API requests and responses
- Tests with [`pytest`](https://docs.pytest.org/en/latest/) and [`VCR.py`](https://vcrpy.readthedocs.io/en/latest/) for mocking HTTP requests
- [`Website stalker`](https://github.com/EdJoPaTo/website-stalker) Github Action to monitor any API changes
- Pagination support with generator to process pages one by one
- Helper function for signature validation for webhooks
### Tests
- [x] Products
- [x] Prices
- [x] Discounts
- [x] Customers
- [ ] Customer Credit balances
- [x] Addresses
- [x] Businesses
- [x] Transactions
- [x] Subscriptions (except activate)
- [x] Subscription Resume
- [ ] Subscription Activate Trialing
- [x] Adjustments
- [x] Pricing Previews
- [ ] Reports
- [x] Event types
- [x] Events
- [x] Notification Settings
- [x] Notifications
- [ ] Notification logs
## Installation
```bash
pip install -U paddle-billing-client
```
or install with `Poetry`
```bash
poetry add paddle-billing-client
```
## Usage
```python
from paddle_billing_client.client import PaddleApiClient
from apiclient import HeaderAuthentication
client = PaddleApiClient(
base_url="https://sandbox-api.paddle.com",
authentication_method=HeaderAuthentication(token="your-paddle-token")
)
# Create a product
product = client.create_product(
ProductRequest(
name="Test Product New",
tax_category="standard",
description="Test Product Description",
image_url="https://example.com/image.png",
custom_data=dict(foo="bar"),
)
)
# Get all products
products = client.list_products()
# Get all prices
plans = client.list_prices()
# Pagination
from paddle_billing_client.pagination import paginate
from paddle_billing_client.models.notification import NotificationQueryParams
for notification in paginate(client.list_notifications, query_params=NotificationQueryParams(
status="delivered",
after='ntf_01hb1n6nw8yx1wwts2cyh632s9',
per_page=10
)):
# Process notifications page by page
print("Notification:")
print(len(notification.data))
print(notification.data[-1].id)
```
### Debugging
To print the raw exception response, you can use the `VerboseErrorHandler`:
```python
from paddle_billing_client.client import PaddleApiClient
from apiclient import HeaderAuthentication
from paddle_billing_client.errors import VerboseErrorHandler
client = PaddleApiClient(
base_url="https://sandbox-api.paddle.com",
authentication_method=HeaderAuthentication(token="your-paddle-token"),
error_handler=VerboseErrorHandler
)
```
- Sandbox API url: `https://sandbox-api.paddle.com/`
- Live API url: `https://api.paddle.com/`
More usage examples can be found in **tests**.
### Helper functions
```python
from paddle_billing_client.helpers import validate_webhook_signature
# Validate webhook signature
is_valid = validate_webhook_signature(
signature_header=request.headers.get("HTTP_PADDLE_SIGNATURE"),
raw_body=request.data,
secret_key="your-paddle-secret-key",
)
```
### Makefile usage
[`Makefile`](https://github.com/websideproject/paddle-billing-client/blob/main/Makefile) contains a lot of functions for faster development.
<details>
<summary>1. Download and remove Poetry</summary>
<p>
To download and install Poetry run:
```bash
make poetry-download
```
To uninstall
```bash
make poetry-remove
```
</p>
</details>
<details>
<summary>2. Install all dependencies and pre-commit hooks</summary>
<p>
Install requirements:
```bash
make install
```
Pre-commit hooks coulb be installed after `git init` via
```bash
make pre-commit-install
```
</p>
</details>
<details>
<summary>3. Codestyle</summary>
<p>
Automatic formatting uses `pyupgrade`, `isort` and `black`.
```bash
make codestyle
# or use synonym
make formatting
```
Codestyle checks only, without rewriting files:
```bash
make check-codestyle
```
> Note: `check-codestyle` uses `isort`, `black` and `darglint` library
Update all dev libraries to the latest version using one comand
```bash
make update-dev-deps
```
<details>
<summary>4. Code security</summary>
<p>
```bash
make check-safety
```
This command launches `Poetry` integrity checks as well as identifies security issues with `Safety` and `Bandit`.
```bash
make check-safety
```
</p>
</details>
</p>
</details>
<details>
<summary>5. Type checks</summary>
<p>
Run `mypy` static type checker
```bash
make mypy
```
</p>
</details>
<details>
<summary>6. Tests with coverage badges</summary>
<p>
Run `pytest`
```bash
make test
```
</p>
</details>
<details>
<summary>7. All linters</summary>
<p>
Of course there is a command to ~~rule~~ run all linters in one:
```bash
make lint
```
the same as:
```bash
make test && make check-codestyle && make mypy && make check-safety
```
</p>
</details>
<details>
<summary>8. Docker</summary>
<p>
```bash
make docker-build
```
which is equivalent to:
```bash
make docker-build VERSION=latest
```
Remove docker image with
```bash
make docker-remove
```
More information [about docker](https://github.com/websideproject/paddle-billing-client/tree/main/docker).
</p>
</details>
<details>
<summary>9. Cleanup</summary>
<p>
Delete pycache files
```bash
make pycache-remove
```
Remove package build
```bash
make build-remove
```
Delete .DS_STORE files
```bash
make dsstore-remove
```
Remove .mypycache
```bash
make mypycache-remove
```
Or to remove all above run:
```bash
make cleanup
```
</p>
</details>
## π Releases
You can see the list of available releases on the [GitHub Releases](https://github.com/websideproject/paddle-billing-client/releases) page.
We follow [Semantic Versions](https://semver.org/) specification.
We use [`Release Drafter`](https://github.com/marketplace/actions/release-drafter). As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when youβre ready. With the categories option, you can categorize pull requests in release notes using labels.
### List of labels and corresponding titles
| **Label** | **Title in Releases** |
| :-----------------------------------: | :---------------------: |
| `enhancement`, `feature` | π Features |
| `bug`, `refactoring`, `bugfix`, `fix` | π§ Fixes & Refactoring |
| `build`, `ci`, `testing` | π¦ Build System & CI/CD |
| `breaking` | π₯ Breaking Changes |
| `documentation` | π Documentation |
| `dependencies` | β¬οΈ Dependencies updates |
You can update it in [`release-drafter.yml`](https://github.com/websideproject/paddle-billing-client/blob/main/.github/release-drafter.yml).
GitHub creates the `bug`, `enhancement`, and `documentation` labels for you. Dependabot creates the `dependencies` label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.
### Building and releasing your package
Building a new version of the application contains steps:
- Bump the version of your package `poetry version <version>`. You can pass the new version explicitly, or a rule such as `major`, `minor`, or `patch`. For more details, refer to the [Semantic Versions](https://semver.org/) standard.
- Make a commit to `GitHub`.
- Create a `GitHub release`.
- And... publish π `poetry publish --build`
## π Package Template Features
### Development features
- Supports for `Python 3.7` and higher.
- [`Poetry`](https://python-poetry.org/) as the dependencies manager. See configuration in [`pyproject.toml`](https://github.com/websideproject/paddle-billing-client/blob/main/pyproject.toml) and [`setup.cfg`](https://github.com/websideproject/paddle-billing-client/blob/main/setup.cfg).
- Automatic codestyle with [`black`](https://github.com/psf/black), [`isort`](https://github.com/timothycrosley/isort) and [`pyupgrade`](https://github.com/asottile/pyupgrade).
- Ready-to-use [`pre-commit`](https://pre-commit.com/) hooks with code-formatting.
- Type checks with [`mypy`](https://mypy.readthedocs.io); docstring checks with [`darglint`](https://github.com/terrencepreilly/darglint); security checks with [`safety`](https://github.com/pyupio/safety) and [`bandit`](https://github.com/PyCQA/bandit)
- Testing with [`pytest`](https://docs.pytest.org/en/latest/).
- Ready-to-use [`.editorconfig`](https://github.com/websideproject/paddle-billing-client/blob/main/.editorconfig), [`.dockerignore`](https://github.com/websideproject/paddle-billing-client/blob/main/.dockerignore), and [`.gitignore`](https://github.com/websideproject/paddle-billing-client/blob/main/.gitignore). You don't have to worry about those things.
### Deployment features
- `GitHub` integration: issue and pr templates.
- `Github Actions` with predefined [build workflow](https://github.com/websideproject/paddle-billing-client/blob/main/.github/workflows/build.yml) as the default CI/CD.
- Everything is already set up for security checks, codestyle checks, code formatting, testing, linting, docker builds, etc with [`Makefile`](https://github.com/websideproject/paddle-billing-client/blob/main/Makefile#L89). More details in [makefile-usage](#makefile-usage).
- [Dockerfile](https://github.com/websideproject/paddle-billing-client/blob/main/docker/Dockerfile) for your package.
- Always up-to-date dependencies with [`@dependabot`](https://dependabot.com/). You will only [enable it](https://docs.github.com/en/github/administering-a-repository/enabling-and-disabling-version-updates#enabling-github-dependabot-version-updates).
- Automatic drafts of new releases with [`Release Drafter`](https://github.com/marketplace/actions/release-drafter). You may see the list of labels in [`release-drafter.yml`](https://github.com/websideproject/paddle-billing-client/blob/main/.github/release-drafter.yml). Works perfectly with [Semantic Versions](https://semver.org/) specification.
### Open source community features
- Ready-to-use [Pull Requests templates](https://github.com/websideproject/paddle-billing-client/blob/main/.github/PULL_REQUEST_TEMPLATE.md) and several [Issue templates](https://github.com/websideproject/paddle-billing-client/tree/main/.github/ISSUE_TEMPLATE).
- Files such as: `LICENSE`, `CONTRIBUTING.md`, `CODE_OF_CONDUCT.md`, and `SECURITY.md` are generated automatically.
- [`Stale bot`](https://github.com/apps/stale) that closes abandoned issues after a period of inactivity. (You will only [need to setup free plan](https://github.com/marketplace/stale)). Configuration is [here](https://github.com/websideproject/paddle-billing-client/blob/main/.github/.stale.yml).
- [Semantic Versions](https://semver.org/) specification with [`Release Drafter`](https://github.com/marketplace/actions/release-drafter).
## π‘ License
[](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE)
This project is licensed under the terms of the `MIT` license. See [LICENSE](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE) for more details.
## π Citation
```bibtex
@misc{paddle-billing-client,
author = {Benjamin Gervan},
title = {Python wrapper around the new Paddle Billing API},
year = {2023},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/websideproject/paddle-billing-client}}
}
```
## Credits [](https://github.com/TezRomacH/python-package-template)
This project was generated with [`python-package-template`](https://github.com/TezRomacH/python-package-template)
Raw data
{
"_id": null,
"home_page": "https://github.com/websideproject/paddle-billing-client",
"name": "paddle-billing-client",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0.0,>=3.8.4",
"maintainer_email": null,
"keywords": null,
"author": "Benjamin Gervan",
"author_email": "bgervan@webstormit.com",
"download_url": "https://files.pythonhosted.org/packages/5f/6c/675cb48928b9cc3a57c6b527f8aee9de6b1f825b10c0afe3e6d0912117c3/paddle_billing_client-0.2.17.tar.gz",
"platform": null,
"description": "# paddle-billing-client\n\n<div align=\"center\">\n\n[](https://github.com/websideproject/paddle-billing-client/actions?query=workflow%3Abuild)\n[](https://pypi.org/project/paddle-billing-client/)\n[](https://github.com/websideproject/paddle-billing-client/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Aapp%2Fdependabot)\n\n[](https://github.com/psf/black)\n[](https://github.com/PyCQA/bandit)\n[](https://github.com/websideproject/paddle-billing-client/blob/main/.pre-commit-config.yaml)\n[](https://github.com/websideproject/paddle-billing-client/releases)\n[](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE)\n\n\n\n\n\nPython wrapper around the new Paddle Billing API\n\n</div>\n\n## Paddle Classic vs Paddle Billing\n\n- Paddle Classic is the original Paddle API, which is still in use by many merchants. More info can be found [here](https://developer.paddle.com/classic/api-reference/1384a288aca7a-api-reference)\n - If you are looking for the Paddle Classic API wrapper, please see [`paddle-client`](https://github.com/paddle-python/paddle-client)\n- Paddle Billing is the new API, which is just launched at 2023, August. Paddle Billing is a complete rewrite of the Paddle Classic API, and is designed to be more flexible and easier to use. More info can be found [here](https://developer.paddle.com/api-reference/overview)\n\n### Django Integration\n- For Paddle Classic, there is a Django integration available at [`dj-paddle`](https://github.com/paddle-python/dj-paddle) and [`django-paddle`](https://github.com/kennell/django-paddle)\n- For Paddle Billing, there is a Work In Progress Django integration available at [`django-paddle-billing`](https://github.com/websideproject/django-paddle-billing)\n---\n## \ud83d\udce6 Features\n\n- Pydantic models for all API requests and responses\n- Tests with [`pytest`](https://docs.pytest.org/en/latest/) and [`VCR.py`](https://vcrpy.readthedocs.io/en/latest/) for mocking HTTP requests\n- [`Website stalker`](https://github.com/EdJoPaTo/website-stalker) Github Action to monitor any API changes\n- Pagination support with generator to process pages one by one\n- Helper function for signature validation for webhooks\n\n### Tests\n\n- [x] Products\n- [x] Prices\n- [x] Discounts\n- [x] Customers\n - [ ] Customer Credit balances\n- [x] Addresses\n- [x] Businesses\n- [x] Transactions\n- [x] Subscriptions (except activate)\n - [x] Subscription Resume\n - [ ] Subscription Activate Trialing\n- [x] Adjustments\n- [x] Pricing Previews\n- [ ] Reports\n- [x] Event types\n- [x] Events\n- [x] Notification Settings\n- [x] Notifications\n- [ ] Notification logs\n\n## Installation\n\n```bash\npip install -U paddle-billing-client\n```\n\nor install with `Poetry`\n\n```bash\npoetry add paddle-billing-client\n```\n\n## Usage\n\n```python\nfrom paddle_billing_client.client import PaddleApiClient\nfrom apiclient import HeaderAuthentication\n\n\nclient = PaddleApiClient(\n base_url=\"https://sandbox-api.paddle.com\", \n authentication_method=HeaderAuthentication(token=\"your-paddle-token\")\n)\n\n# Create a product\nproduct = client.create_product(\n ProductRequest(\n name=\"Test Product New\",\n tax_category=\"standard\",\n description=\"Test Product Description\",\n image_url=\"https://example.com/image.png\",\n custom_data=dict(foo=\"bar\"),\n )\n )\n \n# Get all products\nproducts = client.list_products()\n\n# Get all prices\nplans = client.list_prices()\n\n# Pagination\nfrom paddle_billing_client.pagination import paginate\nfrom paddle_billing_client.models.notification import NotificationQueryParams\n\nfor notification in paginate(client.list_notifications, query_params=NotificationQueryParams(\n status=\"delivered\",\n after='ntf_01hb1n6nw8yx1wwts2cyh632s9',\n per_page=10\n )):\n # Process notifications page by page\n print(\"Notification:\")\n print(len(notification.data))\n print(notification.data[-1].id)\n```\n\n### Debugging\n\nTo print the raw exception response, you can use the `VerboseErrorHandler`:\n\n ```python\n from paddle_billing_client.client import PaddleApiClient\n from apiclient import HeaderAuthentication\n from paddle_billing_client.errors import VerboseErrorHandler\n \n client = PaddleApiClient(\n base_url=\"https://sandbox-api.paddle.com\", \n authentication_method=HeaderAuthentication(token=\"your-paddle-token\"),\n error_handler=VerboseErrorHandler\n )\n ```\n\n- Sandbox API url: `https://sandbox-api.paddle.com/`\n- Live API url: `https://api.paddle.com/`\n\nMore usage examples can be found in **tests**.\n\n### Helper functions\n\n```python\nfrom paddle_billing_client.helpers import validate_webhook_signature\n\n# Validate webhook signature\nis_valid = validate_webhook_signature(\n signature_header=request.headers.get(\"HTTP_PADDLE_SIGNATURE\"),\n raw_body=request.data,\n secret_key=\"your-paddle-secret-key\",\n)\n```\n\n### Makefile usage\n\n[`Makefile`](https://github.com/websideproject/paddle-billing-client/blob/main/Makefile) contains a lot of functions for faster development.\n\n<details>\n<summary>1. Download and remove Poetry</summary>\n<p>\n\nTo download and install Poetry run:\n\n```bash\nmake poetry-download\n```\n\nTo uninstall\n\n```bash\nmake poetry-remove\n```\n\n</p>\n</details>\n\n<details>\n<summary>2. Install all dependencies and pre-commit hooks</summary>\n<p>\n\nInstall requirements:\n\n```bash\nmake install\n```\n\nPre-commit hooks coulb be installed after `git init` via\n\n```bash\nmake pre-commit-install\n```\n\n</p>\n</details>\n\n<details>\n<summary>3. Codestyle</summary>\n<p>\n\nAutomatic formatting uses `pyupgrade`, `isort` and `black`.\n\n```bash\nmake codestyle\n\n# or use synonym\nmake formatting\n```\n\nCodestyle checks only, without rewriting files:\n\n```bash\nmake check-codestyle\n```\n\n> Note: `check-codestyle` uses `isort`, `black` and `darglint` library\n\nUpdate all dev libraries to the latest version using one comand\n\n```bash\nmake update-dev-deps\n```\n\n<details>\n<summary>4. Code security</summary>\n<p>\n\n```bash\nmake check-safety\n```\n\nThis command launches `Poetry` integrity checks as well as identifies security issues with `Safety` and `Bandit`.\n\n```bash\nmake check-safety\n```\n\n</p>\n</details>\n\n</p>\n</details>\n\n<details>\n<summary>5. Type checks</summary>\n<p>\n\nRun `mypy` static type checker\n\n```bash\nmake mypy\n```\n\n</p>\n</details>\n\n<details>\n<summary>6. Tests with coverage badges</summary>\n<p>\n\nRun `pytest`\n\n```bash\nmake test\n```\n\n</p>\n</details>\n\n<details>\n<summary>7. All linters</summary>\n<p>\n\nOf course there is a command to ~~rule~~ run all linters in one:\n\n```bash\nmake lint\n```\n\nthe same as:\n\n```bash\nmake test && make check-codestyle && make mypy && make check-safety\n```\n\n</p>\n</details>\n\n<details>\n<summary>8. Docker</summary>\n<p>\n\n```bash\nmake docker-build\n```\n\nwhich is equivalent to:\n\n```bash\nmake docker-build VERSION=latest\n```\n\nRemove docker image with\n\n```bash\nmake docker-remove\n```\n\nMore information [about docker](https://github.com/websideproject/paddle-billing-client/tree/main/docker).\n\n</p>\n</details>\n\n<details>\n<summary>9. Cleanup</summary>\n<p>\nDelete pycache files\n\n```bash\nmake pycache-remove\n```\n\nRemove package build\n\n```bash\nmake build-remove\n```\n\nDelete .DS_STORE files\n\n```bash\nmake dsstore-remove\n```\n\nRemove .mypycache\n\n```bash\nmake mypycache-remove\n```\n\nOr to remove all above run:\n\n```bash\nmake cleanup\n```\n\n</p>\n</details>\n\n## \ud83d\udcc8 Releases\n\nYou can see the list of available releases on the [GitHub Releases](https://github.com/websideproject/paddle-billing-client/releases) page.\n\nWe follow [Semantic Versions](https://semver.org/) specification.\n\nWe use [`Release Drafter`](https://github.com/marketplace/actions/release-drafter). As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you\u2019re ready. With the categories option, you can categorize pull requests in release notes using labels.\n\n### List of labels and corresponding titles\n\n| **Label** | **Title in Releases** |\n| :-----------------------------------: | :---------------------: |\n| `enhancement`, `feature` | \ud83d\ude80 Features |\n| `bug`, `refactoring`, `bugfix`, `fix` | \ud83d\udd27 Fixes & Refactoring |\n| `build`, `ci`, `testing` | \ud83d\udce6 Build System & CI/CD |\n| `breaking` | \ud83d\udca5 Breaking Changes |\n| `documentation` | \ud83d\udcdd Documentation |\n| `dependencies` | \u2b06\ufe0f Dependencies updates |\n\nYou can update it in [`release-drafter.yml`](https://github.com/websideproject/paddle-billing-client/blob/main/.github/release-drafter.yml).\n\nGitHub creates the `bug`, `enhancement`, and `documentation` labels for you. Dependabot creates the `dependencies` label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.\n\n### Building and releasing your package\n\nBuilding a new version of the application contains steps:\n\n- Bump the version of your package `poetry version <version>`. You can pass the new version explicitly, or a rule such as `major`, `minor`, or `patch`. For more details, refer to the [Semantic Versions](https://semver.org/) standard.\n- Make a commit to `GitHub`.\n- Create a `GitHub release`.\n- And... publish \ud83d\ude42 `poetry publish --build`\n\n## \ud83d\ude80 Package Template Features\n\n### Development features\n\n- Supports for `Python 3.7` and higher.\n- [`Poetry`](https://python-poetry.org/) as the dependencies manager. See configuration in [`pyproject.toml`](https://github.com/websideproject/paddle-billing-client/blob/main/pyproject.toml) and [`setup.cfg`](https://github.com/websideproject/paddle-billing-client/blob/main/setup.cfg).\n- Automatic codestyle with [`black`](https://github.com/psf/black), [`isort`](https://github.com/timothycrosley/isort) and [`pyupgrade`](https://github.com/asottile/pyupgrade).\n- Ready-to-use [`pre-commit`](https://pre-commit.com/) hooks with code-formatting.\n- Type checks with [`mypy`](https://mypy.readthedocs.io); docstring checks with [`darglint`](https://github.com/terrencepreilly/darglint); security checks with [`safety`](https://github.com/pyupio/safety) and [`bandit`](https://github.com/PyCQA/bandit)\n- Testing with [`pytest`](https://docs.pytest.org/en/latest/).\n- Ready-to-use [`.editorconfig`](https://github.com/websideproject/paddle-billing-client/blob/main/.editorconfig), [`.dockerignore`](https://github.com/websideproject/paddle-billing-client/blob/main/.dockerignore), and [`.gitignore`](https://github.com/websideproject/paddle-billing-client/blob/main/.gitignore). You don't have to worry about those things.\n\n### Deployment features\n\n- `GitHub` integration: issue and pr templates.\n- `Github Actions` with predefined [build workflow](https://github.com/websideproject/paddle-billing-client/blob/main/.github/workflows/build.yml) as the default CI/CD.\n- Everything is already set up for security checks, codestyle checks, code formatting, testing, linting, docker builds, etc with [`Makefile`](https://github.com/websideproject/paddle-billing-client/blob/main/Makefile#L89). More details in [makefile-usage](#makefile-usage).\n- [Dockerfile](https://github.com/websideproject/paddle-billing-client/blob/main/docker/Dockerfile) for your package.\n- Always up-to-date dependencies with [`@dependabot`](https://dependabot.com/). You will only [enable it](https://docs.github.com/en/github/administering-a-repository/enabling-and-disabling-version-updates#enabling-github-dependabot-version-updates).\n- Automatic drafts of new releases with [`Release Drafter`](https://github.com/marketplace/actions/release-drafter). You may see the list of labels in [`release-drafter.yml`](https://github.com/websideproject/paddle-billing-client/blob/main/.github/release-drafter.yml). Works perfectly with [Semantic Versions](https://semver.org/) specification.\n\n### Open source community features\n\n- Ready-to-use [Pull Requests templates](https://github.com/websideproject/paddle-billing-client/blob/main/.github/PULL_REQUEST_TEMPLATE.md) and several [Issue templates](https://github.com/websideproject/paddle-billing-client/tree/main/.github/ISSUE_TEMPLATE).\n- Files such as: `LICENSE`, `CONTRIBUTING.md`, `CODE_OF_CONDUCT.md`, and `SECURITY.md` are generated automatically.\n- [`Stale bot`](https://github.com/apps/stale) that closes abandoned issues after a period of inactivity. (You will only [need to setup free plan](https://github.com/marketplace/stale)). Configuration is [here](https://github.com/websideproject/paddle-billing-client/blob/main/.github/.stale.yml).\n- [Semantic Versions](https://semver.org/) specification with [`Release Drafter`](https://github.com/marketplace/actions/release-drafter).\n\n## \ud83d\udee1 License\n\n[](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE)\n\nThis project is licensed under the terms of the `MIT` license. See [LICENSE](https://github.com/websideproject/paddle-billing-client/blob/main/LICENSE) for more details.\n\n## \ud83d\udcc3 Citation\n\n```bibtex\n@misc{paddle-billing-client,\n author = {Benjamin Gervan},\n title = {Python wrapper around the new Paddle Billing API},\n year = {2023},\n publisher = {GitHub},\n journal = {GitHub repository},\n howpublished = {\\url{https://github.com/websideproject/paddle-billing-client}}\n}\n```\n\n## Credits [](https://github.com/TezRomacH/python-package-template)\n\nThis project was generated with [`python-package-template`](https://github.com/TezRomacH/python-package-template)\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Python wrapper around the new Paddle Billing API",
"version": "0.2.17",
"project_urls": {
"Homepage": "https://github.com/websideproject/paddle-billing-client",
"Repository": "https://github.com/websideproject/paddle-billing-client"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "16c21715528cba0a66bdbf31c5dee6400f2b0923091a728b97b7b978cb7550a1",
"md5": "0fa6e2d1b60d6520dca826ac11cebca3",
"sha256": "289c349b24b7034ba0ceeb92bd892e1ddba15f0e8eacf279fc16625ba9756eb8"
},
"downloads": -1,
"filename": "paddle_billing_client-0.2.17-py3-none-any.whl",
"has_sig": false,
"md5_digest": "0fa6e2d1b60d6520dca826ac11cebca3",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0.0,>=3.8.4",
"size": 29101,
"upload_time": "2024-11-04T07:56:40",
"upload_time_iso_8601": "2024-11-04T07:56:40.164898Z",
"url": "https://files.pythonhosted.org/packages/16/c2/1715528cba0a66bdbf31c5dee6400f2b0923091a728b97b7b978cb7550a1/paddle_billing_client-0.2.17-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "5f6c675cb48928b9cc3a57c6b527f8aee9de6b1f825b10c0afe3e6d0912117c3",
"md5": "5ce917f33db7fb7ad2afc36eafa7335b",
"sha256": "4e3127292c097cd903ea5a6f9c6c520992118a19f7ad362c0ad97cdd80e2344c"
},
"downloads": -1,
"filename": "paddle_billing_client-0.2.17.tar.gz",
"has_sig": false,
"md5_digest": "5ce917f33db7fb7ad2afc36eafa7335b",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0.0,>=3.8.4",
"size": 22852,
"upload_time": "2024-11-04T07:56:41",
"upload_time_iso_8601": "2024-11-04T07:56:41.712285Z",
"url": "https://files.pythonhosted.org/packages/5f/6c/675cb48928b9cc3a57c6b527f8aee9de6b1f825b10c0afe3e6d0912117c3/paddle_billing_client-0.2.17.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-04 07:56:41",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "websideproject",
"github_project": "paddle-billing-client",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "paddle-billing-client"
}