Como aceitar pagamentos no Telegram | API Yoomoney Python

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
      
      



. . .





Formulário de pagamento

, .





: , ?

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!








All Articles