Интеграция UPI в Paytm Payment Gateway в Python backend - PullRequest
0 голосов
/ 27 мая 2020

Я пытаюсь интегрировать платежный шлюз Paytm на свой веб-сайт только для транзакций UPI, поэтому после просмотра документации я смог интегрировать Инициировать платеж API, но когда я пытаюсь интегрировать проверка VPA API, он всегда дает VPA недействительный, я добавляю код для справки, я заменяю my_mid правильным MID, my_key правильным ключом, а также 7777777777@paytm действительным VPA

import requests
import json
paytmParams = dict()
paytmParams["body"] = {
    "vpa" : "7777777777@paytm"
}
paytmParams["head"] = {
    "txnToken" : "4f7197de6840450e9162ddb5c067eb221590561957267"
}
post_data = json.dumps(paytmParams)
url = "https://securegw-stage.paytm.in/theia/api/v1/vpa/validate?mid=my_mid&orderId=123abcd"
response = requests.post(url, data = post_data, headers = {"Content-type": "application/json"}).json()
print(response)

Выполнение этого всегда возвращает,

{
  "head": {
    "requestId": None,
    "responseTimestamp": "1590561981014",
    "version": "v1"
  },
  "body": {
    "extraParamsMap": None,
    "resultInfo": {
      "resultStatus": "F",
      "resultCode": "501",
      "resultMsg": "Sorry! We could not verify the VPA."
    },
    "vpa": "7777777777@paytm",
    "valid": False
  }
}

txnToken получается из приведенного ниже кода независимо от VPA,

import requests
import json
import hashlib
import base64
import string
import random
from Crypto.Cipher import AES

IV = "@@@@&&&&####$$$$"
BLOCK_SIZE = 16

def __pad__(s): return s + (BLOCK_SIZE - len(s) %
                            BLOCK_SIZE) * chr(BLOCK_SIZE - len(s) % BLOCK_SIZE)

def __encode__(to_encode, iv, key):
    to_encode = __pad__(to_encode)
    c = AES.new(key, AES.MODE_CBC, iv)
    to_encode = c.encrypt(to_encode)
    to_encode = base64.b64encode(to_encode)
    return to_encode.decode("UTF-8")

def __id_generator__(size=6, chars=string.ascii_uppercase + string.digits + string.ascii_lowercase):
    return ''.join(random.choice(chars) for _ in range(size))

def generate_checksum_by_str(param_str, merchant_key, salt=None):
    params_string = param_str
    salt = salt if salt else __id_generator__(4)
    final_string = '%s|%s' % (params_string, salt)
    hasher = hashlib.sha256(final_string.encode())
    hash_string = hasher.hexdigest()
    hash_string += salt
    return __encode__(hash_string, IV, merchant_key)

paytmParams = dict()
paytmParams["body"] = {
    "requestType": "Payment",
    "mid": "my_mid",
    "websiteName": "WEBSTAGING",
    "orderId": "123abcd",
    "txnAmount": {
        "value": "500",
        "currency": "INR",
    },
    "userInfo": {
        "custId": "1234567",
    },
    "enablePaymentMode":  [{"mode": "UPI", "channels": ["UPIPUSH"]}]
}
checksum = generate_checksum_by_str(
    json.dumps(paytmParams["body"]), "my_key")
paytmParams["head"] = {
    "signature" : checksum
}
post_data = json.dumps(paytmParams)
url = "https://securegw-stage.paytm.in/theia/api/v1/initiateTransaction?mid=my_mid&orderId=123abcd"
response = requests.post(url, data=post_data, headers={
                         "Content-type": "application/json"}).json()
print(response)

Пожалуйста, дайте мне знать если требуются какие-либо дополнительные сведения, так как я провел все виды исследований, но мне не повезло.

1 Ответ

0 голосов
/ 30 июня 2020

Похоже, с вашим кодом проблем нет. Может быть, вы можете попробовать еще раз. если проблема не исчезнет, ​​обратитесь в службу поддержки разработчика Paytm.

...