Документация по взаимодействию с API tegro.money на языке python
API ключ для доступа к REST сервису Tegro.money можно сгенерировать на странице настроек магазина https://tegro.money/my/shop-settings/
Все данные в запросах к сервису Tegro.money передаются методом POST по протоколу HTTP на адрес https://tegro.money/api/method. Параметры сообщения упаковываются в JSON-объект.
Вместе с запросом необходимо передавать подпись. Подписывать необходимо тело запроса целиком, в том виде, в котором оно отправляется на сервер Банка (после сериализации тела запроса в JSON для отправки по HTTP).
url = "https://tegro.money/api/shops/"
#Задаем параметры запроса (его тело)
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880
}
#Кодируем тело запроса + секретный ключ API алгоритмом SHA-256
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
В каждом запросе необходимо передавать параметр nonce, отличный от предыдущего! Например, можно использовать текущее время в секундах
Используйте для подписи ваш секретный ключ. Сформируйте подпись с алгоритмом SHA-256.
Используйте этот метод для получения прямой ссылки на оплату заказа
POST https://tegro.money/api/createOrder/
url = 'https://tegro.money/api/createOrder/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"currency": "RUB",
"amount": 100,
"order_id": "1",
"payment_system": 1,
"fields": {
"email": "[email protected]",
"phone": "79111231212"
},
"receipt": {
"items": [
{
"name": "test item 1",
"count": 1,
"price": 600
},
{
"name": "test item 2",
"count": 1,
"price": 600
}
]
}
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
{
"type": "success",
"desc": "",
"data": {
"id": 755555,
"url": "https://tegro.money/pay/complete/755555/7f259f856e7682a6e98179036a623696/"
}
}
Получение списка ваших магазинов
POST https://tegro.money/api/shops/
url = "https://tegro.money/api/shops/"
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
{
"type": "success",
"desc": "",
"data": {
"user_id": 1,
"shops": [
{
"id": 1,
"date_added": "2020-11-03 18:04:07",
"name": "DEMO1",
"url": "https://demo1",
"status": 1,
"public_key": "D0F98E7DD86BB7500914",
"desc": "DEMO1 SHOP"
},
{
"id": 2,
"date_added": "2020-11-03 22:38:58",
"name": "DEMO2",
"url": "https://demo2",
"status": 0,
"public_key": "1913EA935149B1E5D852A",
"desc": "DEMO2 SHOP"
}
]
}
}
Получение баланса всех кошельков
POST https://tegro.money/api/balance/
url = "https://tegro.money/api/balance/"
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
{
"type": "success",
"desc": "",
"data": {
"user_id": 1,
"balance": {
"RUB": "1396.68",
"USD": "0.00",
"EUR": "1.23",
"UAH": "0.00"
}
}
}
Получение информации о заказе
POST https://tegro.money/api/order/
url = 'https://tegro.money/api/order/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"order_id": 755555,
"payment_id": "test order"
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
{
"type": "success",
"desc": "",
"data": {
"id": 1232,
"date_created": "2020-11-14 23:32:37",
"date_payed": "2020-11-14 23:33:39",
"status": 1,
"payment_system_id": 10,
"currency_id": 1,
"amount": "64.18000000",
"fee": "4.00000000",
"email": "[email protected]",
"test_order": 0,
"payment_id": "Order #17854"
}
}
Получение информации о заказах
POST https://tegro.money/api/orders/
url = 'https://tegro.money/api/orders/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"page": 1
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
{
"type": "success",
"desc": "",
"data": [
{
"id": 123,
"date_created": "2020-11-14 23:32:37",
"date_payed": "2020-11-14 23:33:39",
"status": 1,
"payment_system_id": 10,
"currency_id": 1,
"amount": "64.18000000",
"fee": "4.00000000",
"email": "user@somesite",
"test_order": 0,
"payment_id": "Order #4175"
},
{
"id": 124,
"date_created": "2020-11-14 23:30:05",
"date_payed": null,
"status": 0,
"payment_system_id": 10,
"currency_id": 1,
"amount": "64.18000000",
"fee": "4.00000000",
"email": "user2@somesite",
"test_order": 0,
"payment_id": "Order #4174"
}
]
}
Создание выплаты
POST https://tegro.money/api/createWithdrawal/
url = 'https://tegro.money/api/createWithdrawal/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"currency": "RUB",
"account": "123",
"amount": 100,
"payment_id": 1124235,
"payment_system": 1
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
Список выплат
POST https://tegro.money/api/withdrawals/
url = 'https://tegro.money/api/withdrawals/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"page": 1
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)
Проверка выплаты
POST https://tegro.money/api/withdrawal/
url = 'https://tegro.money/api/withdrawal/'
params = {
"shop_id": "1913EA935149B1E5D852A",
"nonce": 1613435880,
"order_id": 755555,
"payment_id": "test order"
}
body = json.dumps(params)
sign = hmac.new(config.api_key.encode(), body.encode(), sha256).hexdigest()
headers = {
"Authorization": f"Bearer {sign}",
"Content-Type": "application/json"
}
response = requests.post(url=url, headers=headers, params=params)