Skip to main content

An unofficial Python API Wrapper for the Revolut Business API

Project description

Pyrevolut: A Revolut Business API Wrapper

pyrevolut is an un-official wrapper around the Revolut Business API.

Installation

pip install pyrevolut

Usage

Basic Usage

from pyrevolut.client import Client

CREDS_JSON_LOC = "path/to/creds.json"

client = Client(
    creds_loc=CREDS_JSON_LOC,
    sandbox=True,
)

# Initialize the client
client.open()

# List all accounts for the authenticated user
accounts = client.Accounts.get_all_accounts()

# Close the client
client.close()

# You can also use the client as a context manager
with Client(
    creds_loc=CREDS_JSON_LOC,
    sandbox=True
) as client:
    accounts = client.Accounts.get_all_accounts()

Advanced Usage

It is possible to use the client library asynchronously by using the AsyncClient object.

import asyncio
from pyrevolut.client import AsyncClient

CREDS_JSON_LOC = "path/to/creds.json"

client = AsyncClient(
    creds_loc=CREDS_JSON_LOC,
    sandbox=True,
)

# Run without context manager
async def run():
    await client.open() 
    accounts = await client.Accounts.get_all_accounts()
    await client.close() 
    return accounts

# Run with context manager
async def run_context_manager():
    async with client:
        accounts = await client.Accounts.get_all_accounts() 
    return accounts

# List all accounts for the authenticated user
accounts = asyncio.run(run())
accounts_context_manager = asyncio.run(run_context_manager())

Authentication

In order to make use of the Revolut Business API, you will need to go through several steps to authenticate your application. The basic guide can be found here. We have provided a simple CLI tool to help you generate the necessary credentials. This tool follows the steps outlined in the guide.

pyrevolut auth-manual

Alternatively, you can use call the CLI via Python.

python -m pyrevolut auth-manual

Upon completion, you will have a .json file that you can use to authenticate your application.

API Support Status

The SDK currently supports the following APIs:

  • Accounts
    • Retrieve all accounts
    • Retrieve an account
    • Retrieve account's full bank details
  • Cards (Live only)
    • Retrieve a list of cards
    • Create a card
    • Retrieve card details
    • Update card details
    • Terminate a card
    • Freeze a card
    • Unfreeze a card
    • Retrieve sensitive card details
  • Counterparties
    • Retrieve a list of counterparties
    • Retrieve a counterparty
    • Delete a counterparty
    • Create a counterparty (Personal)
    • Create a counterparty (Business)
    • Validate an account name (CoP)
  • Foreign exchange
    • Get an exchange rate
    • Exchange money
  • Payment drafts
    • Retrieve all payments drafts
    • Create a payment draft
    • Retrieve a payment draft
    • Delete a payment draft
  • Payout links
    • Retrieve a list of payout links
    • Retrieve a payout link
    • Create a payout link
    • Cancel a payout link
  • Simulations (Sandbox only)
    • Simulate a transfer state update
    • Simulate an account top-up
  • Team members (Live only)
    • Retrieve a list of team members
    • Invite a new memebr to your business
    • Retrieve team roles
  • Transactions
    • Retrieve a list of transactions
    • Retrieve a transaction
  • Transfers
    • Move money between your accounts
    • Create a transfer to another account
    • Get transfer reasons
  • Webhooks (v2)
    • Create a new webhook
    • Retrieve a list of webhooks
    • Retrieve a webhook
    • Update a webhook
    • Delete a webhook
    • Rotate a webhook signing secret
    • Retrieve a list of failed webhook events

Contributing

In order to facilitate a streamlined development process, we have a few guidelines that we would like to follow. Please refer to the CONTRIBUTING.md file for more information.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Disclaimer: pyrevolut is an un-official API wrapper. It is in no way endorsed by or affiliated with Revolut or any associated organization. Make sure to read and understand the terms of service of the underlying API before using this package. The authors accept no responsiblity for any damage that might stem from use of this package.

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

pyrevolut-0.6.1.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

pyrevolut-0.6.1-py3-none-any.whl (158.0 kB view details)

Uploaded Python 3

File details

Details for the file pyrevolut-0.6.1.tar.gz.

File metadata

  • Download URL: pyrevolut-0.6.1.tar.gz
  • Upload date:
  • Size: 68.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.9 Linux/6.5.0-1021-azure

File hashes

Hashes for pyrevolut-0.6.1.tar.gz
Algorithm Hash digest
SHA256 12cc95337a598523a2e55a73f89fbdcb03d81f959d5478f859a76c2c6f700c0c
MD5 bd3804d496f63bef98ea57b03de096c5
BLAKE2b-256 aca6c3b2a4defbe5c974e651a8f8b472806c0cf564d48ecaa9004f1df344b041

See more details on using hashes here.

File details

Details for the file pyrevolut-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: pyrevolut-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 158.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.9 Linux/6.5.0-1021-azure

File hashes

Hashes for pyrevolut-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 406359a70a6baeb3a83f1e1a27a7f5d0cf17730a903ee6a0220e7344da9194fc
MD5 ab95ca67fd0eed3ddb4b513700767b5c
BLAKE2b-256 6071517712e5f42f326be531c62fcbf295f6ababf636401dd100e364e9087c79

See more details on using hashes here.

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