Nesta postagem, aprenderemos como aceitar pagamentos no bot do Telegram usando a API Yoomoney.
Introdução
Para começar, recentemente eu queria criar uma loja de produtos eletrônicos no Telegram. E me deparei com o problema de que na hora do trabalho não havia soluções prontas. Queria aceitar pagamentos sem empreendedores individuais e todo esse movimento. Portanto, minha escolha era entre Qiwi e Yoomoney (anteriormente Yandex Money). Eu mesmo sou da Bielorrússia ... Portanto, é mais fácil obter uma conta "Identificada" do Yoomoney.
Como resultado, criei a biblioteca yoomoney para Python.
Se esta postagem ajudou você, por favor, estrela no GitHub . Ficarei muito satisfeito!
Descrição
Pegamos o token
Verificando o token
Como emitir uma fatura para pagamento
Verificação de pagamento
Pegamos o token
Para usar a API Yoomoney, você precisa obter um token especial. Em primeiro lugar, registramos o aplicativo:
1. Vá para a carteira YuMoney. Se não houver carteira, crie uma .
2. Vá para a página Registro do aplicativo .
3. Especifique os parâmetros do aplicativo:
4. Clique no botão Confirmar .
, , (client_id) , , (client_secret).
!
client_id redirect_uri, .
: . .
pip install yoomoney
from yoomoney import Authorize
Authorize(
client_id="YOUR_CLIENT_ID",
redirect_uri="YOUR_REDIRECT_URI",
scope=["account-info",
"operation-history",
"operation-details",
"incoming-transfers",
"payment-p2p",
"payment-shop",
]
)
! !
YOUR_TOKEN :
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")
:
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
! .
Quickpay.
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)
:
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
. . .
, .
: , ?
label - , . , .
:
from yoomoney import Quickpay
quickpay = Quickpay(
receiver="410019014512803",
quickpay_form="shop",
targets="Sponsor this project",
paymentType="SB",
sum=150,
lebel="a1b2c3d4e5"
)
print(quickpay.base_url)
print(quickpay.redirected_url)
.
Client.
Conhecendo o rótulo da transação, podemos filtrar o histórico de transações da carteira. Basta colocar um rótulo em client.operation_history ():
from yoomoney import Client
token = "YOUR_TOKEN"
client = Client(token)
history = client.operation_history(label="a1b2c3d4e5")
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)
Como resultado, obtemos uma lista de todas as operações para nosso filtro:
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 --> 150.0
Label --> a1b2c3d4e5
Type --> deposition
Agora sabemos se o pagamento foi bem-sucedido.
Tudo! Nada mais é necessário para receber pagamentos.
Conclusão
Se esta postagem ajudou você, por favor, estrela no GitHub . Ficarei muito satisfeito!