Unofficial YooMoney API python library
Project description
This is an unofficial YooMoney API python library.
Summary
Introduction
This repository is based on the official documentation of YooMoney.
Features
Implemented methods:
Access token - Getting an access token
Account information - Getting information about the status of the user account.
Operation history - This method allows viewing the full or partial history of operations in page mode. History records are displayed in reverse chronological order (from most recent to oldest).
Operation details - Provides detailed information about a particular operation from the history.
Quickpay forms - The YooMoney form is a set of fields with information about a transfer. You can embed payment form into your interface (for instance, a website or blog). When the sender pushes the button, the details from the form are sent to YooMoney and an order for a transfer to your wallet is initiated.
Installation
You can install with:
pip install yoomoney --upgrade
You can install from source with:
git clone https://github.com/AlekseyKorshuk/yoomoney-api --recursive
cd yoomoney-api
python setup.py install
Quick start
Access token
First of all we need to receive an access token.
Log in to your YooMoney wallet with your username. If you do not have a wallet, create it.
Go to the App registration page.
Set the application parameters. Save CLIENT_ID and YOUR_REDIRECT_URI for net steps
Click the Confirm button.
Paste CLIENT_ID, REDIRECT_URI and CLIENT_SECRET insted of YOUR_CLIENT_ID, YOUR_REDIRECT_URI and YOUR_CLIENT_SECRET. Choose scopes and run code.
Follow all steps from the program.
from yoomoney import Authorize
Authorize(
client_id="YOUR_CLIENT_ID",
redirect_uri="YOUR_REDIRECT_URI",
client_secret="YOUR_CLIENT_SECRET",
scope=["account-info",
"operation-history",
"operation-details",
"incoming-transfers",
"payment-p2p",
"payment-shop",
]
)
You are done with the most difficult part!
Account information
Paste YOUR_TOKEN and run this code:
from yoomoney import Client
token = "YOUR_TOKEN"
client = Client(token)
user = client.account_info()
print("Account number:", user.account)
print("Account balance:", user.balance)
print("Account currency code in ISO 4217 format:", user.currency)
print("Account status:", user.account_status)
print("Account type:", user.account_type)
print("Extended balance information:")
for pair in vars(user.balance_details):
print("\t-->", pair, ":", vars(user.balance_details).get(pair))
print("Information about linked bank cards:")
cards = user.cards_linked
if len(cards) != 0:
for card in cards:
print(card.pan_fragment, " - ", card.type)
else:
print("No card is linked to the account")
Output:
Account number: 410019014512803
Account balance: 999999999999.99
Account currency code in ISO 4217 format: 643
Account status: identified
Account type: personal
Extended balance information:
--> total : 999999999999.99
--> available : 999999999999.99
--> deposition_pending : None
--> blocked : None
--> debt : None
--> hold : None
Information about linked bank cards:
No card is linked to the account
Operation history
Paste YOUR_TOKEN and run this code:
from yoomoney import Client
token = "YOUR_TOKEN"
client = Client(token)
history = client.operation_history()
print("List of operations:")
print("Next page starts with: ", history.next_record)
for operation in history.operations:
print()
print("Operation:",operation.operation_id)
print("\tStatus -->", operation.status)
print("\tDatetime -->", operation.datetime)
print("\tTitle -->", operation.title)
print("\tPattern id -->", operation.pattern_id)
print("\tDirection -->", operation.direction)
print("\tAmount -->", operation.amount)
print("\tLabel -->", operation.label)
print("\tType -->", operation.type)
Output:
List of operations:
Next page starts with: None
Operation: 670278348725002105
Status --> success
Datetime --> 2021-10-10 10:10:10
Title --> Пополнение с карты ****4487
Pattern id --> None
Direction --> in
Amount --> 100500.0
Label --> 3784030974
Type --> deposition
Operation: 670244335488002313
Status --> success
Datetime --> 2021-10-10 10:10:10
Title --> Перевод от 410019014512803
Pattern id --> p2p
Direction --> in
Amount --> 100500.0
Label --> 7920963969
Type --> incoming-transfer
Operation details
Paste YOUR_TOKEN with an OPERATION_ID (example: 670244335488002312) from previous example output and run this code:
from yoomoney import Client
token = "YOUR_TOKEN"
client = Client(token)
details = client.operation_details(operation_id="OPERATION_ID")
properties = [i for i in details.__dict__.keys() if i[:1] != '_']
max_size = len(max(properties, key=len))
for prop in properties:
print(prop, " " * (max_size - len(prop)), "-->", str(details.__getattribute__(prop)).replace('\n', ' '))
Output:
operation_id --> 670244335488002312
status --> success
pattern_id --> p2p
direction --> in
amount --> 100500.0
amount_due --> None
fee --> None
datetime --> 2021-10-10 10:10:10
title --> Перевод от 410019014512803
sender --> 410019014512803
recipient --> None
recipient_type --> None
message --> Justtext
comment --> None
codepro --> False
protection_code --> None
expires --> None
answer_datetime --> None
label --> 7920963969
details --> Justtext
type --> incoming-transfer
digital_goods --> None
Quickpay forms
Run this code:
from yoomoney import Quickpay
quickpay = Quickpay(
receiver="410019014512803",
quickpay_form="shop",
targets="Sponsor this project",
paymentType="SB",
sum=150,
)
print(quickpay.base_url)
print(quickpay.redirected_url)
Output:
https://yoomoney.ru/quickpay/confirm.xml?receiver=410019014512803&quickpay-form=shop&targets=Sponsor%20this%20project&paymentType=SB&sum=150
https://yoomoney.ru/transfer/quickpay?requestId=343532353937313933395f66326561316639656131626539326632616434376662373665613831373636393537613336383639
Project details
Release history Release notifications | RSS feed
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 yoomoney-0.1.1.tar.gz
.
File metadata
- Download URL: yoomoney-0.1.1.tar.gz
- Upload date:
- Size: 21.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 32a2e1669169fa1373bee7c6ce9702674f619458e9072a92fb4833fa2680d891 |
|
MD5 | 8f87a822d8c7ec2ce234e10b29bc6c70 |
|
BLAKE2b-256 | 359121f23f895943a14108e7d1ba07d4d72a132a117e696217041086ac7621f8 |
File details
Details for the file YooMoney-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: YooMoney-0.1.1-py3-none-any.whl
- Upload date:
- Size: 26.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3f819bded7b838410113b14d51ed4e3eaaa9bbef712f04654a2d5be19001a6ae |
|
MD5 | bd605286edf132e7df4c8f37bfa0dbd7 |
|
BLAKE2b-256 | 14b30fff3228a481ba2c040590e629149f13ad39f9577d83298a1fb5571405ba |