Полная документация по REST API для делегирования TronEnergy Energy . Конечные точки, параметры, форматы ответов и коды ошибок.
Базовый URL:https://api.tronnrg.comАвторизация: Никаких дополнительных требований не требуется. Все конечные точки являются общедоступными.
Лимит скорости: 20 запросов в секунду на IP-адрес
Адрес для оплаты:TFqUiCu1JwLHHnBNeaaVKH7Csm4aA3YhZx (Только API , не для ручной аренды)
Как это работает
Три шага. Никакого API ключа, никакой регистрации, никакого подключения к кошельку. Право собственности подтверждается криптографически.
Знак — Подпишите сообщение {tx_hash}:{delegate_to} Используя кошелек, из которого были отправлены TRX . Это доказывает, что вы авторизовали делегирование.
Требовать — POST /delegate с tx_hash, delegate_to, и signatureEnergy поступает примерно через 3 секунды.
Адрес для оплаты
TFqUiCu1JwLHHnBNeaaVKH7Csm4aA3YhZx
Только адрес для оплаты API . Этот адрес предназначен для программной интеграции через API . Не используйте его для ручной аренды электроэнергии. Адрес для ручной аренды отличается и доступен на сайте .tronnrg.com.
Отправьте TRX на этот адрес. Хэш транзакции вашего платежа — это ваш токен для запуска делегирования. Каждый хэш может быть использован только один раз.
TRX отправлен
Делегированный по Energy
Вариант использования
4 TRX
65,000
Стандартный перевод USDT на существующий кошелек (минимальная сумма заказа)
8 TRX
130,000
Перевод USDT получателю, получающему средства впервые.
16 TRX
260,000
Четыре стандартных перевода в одном заказе
40 TRX
650,000
Десять стандартных трансферов
100 TRX
1,625,000
~25 стандартных передач — типично для небольших платформ.
1,000 TRX
16,250,000
Максимальный заказ: ~250 стандартных переводов.
Любая сумма между ними
trx × 16,250
Полностью линейная система. Никаких уровней, пакетов и скидок.
Формула:energy = trxSent × 16,250. Границы: Минимальное значение: 4 TRX (65 000 энергии), максимальное: 1000 TRX (16 250 000 энергии). Оба значения применяются на уровне API — суммы ниже минимального значения отклоняются с помощью параметра below_minimum и возвращаются; суммы выше максимального значения отклоняются до делегирования. Всегда считывайте текущие значения из запроса GET /supply перед тем, как жестко задать их в продакшене — см. ниже.
GET /supply
GET/supply
Получите информацию о ценах и адрес для оплаты. Это информационный ресурс — электроэнергия всегда доступна, проверять наличие перед отправкой платежа не нужно.
curl https://api.tronnrg.com/supply
const supply = awaitfetch('https://api.tronnrg.com/supply')
.then(r => r.json());
// Energy is always available. Use supply.pay_to for the payment address.
console.log('Pay to:', supply.pay_to);
import requests
supply = requests.get('https://api.tronnrg.com/supply').json()
# Energy is always available. Use supply['pay_to'] for the payment address.print(supply['pay_to'])
$supply = json_decode(
file_get_contents('https://api.tronnrg.com/supply'),
true
);
// if less than you require, wait and retry// Energy is always available. Use $supply['pay_to'] for the payment address.echo$supply['pay_to'];
var client = newHttpClient();
var json = await client.GetStringAsync("https://api.tronnrg.com/supply");
var supply = JsonSerializer.Deserialize<JsonElement>(json);
// Energy is always available. Use pay_to for the payment address.var payTo = supply.GetProperty("pay_to").GetString();
Запросите делегирование энергии. Вы должны были предварительно отправить TRX на платежный адрес в блокчейне. Передайте хеш транзакции, адрес получателя и подпись, подтверждающую, что вы являетесь отправителем.
Parameter
Type
Description
tx_hash
string
required
64-символьный шестнадцатеричный хеш платежа TRX
delegate_to
string
required
Адрес Tron для получения энергии
signature
string
required
Sign {tx_hash}:{delegate_to} using tronWeb.trx.signMessageV2(). Proves you are the payment sender.
Идентификатор ссылки TronNRG . Запишите его для запросов в службу поддержки.
energy
number
Общий объем делегированной энергии
cost
number
TRX заряжен
status
string
«Делегируется» в случае успеха
delegations
array
On-chain delegation transaction hashes. Each tx is verifiable on TronScan. This is your receipt.
GET /health
GET/health
Liveness check for monitoring and uptime tools. Returns 200 OK when the API process is up. Does not check upstream nodes or providers.
Response 200
{ "status": "ok" }
Коды ошибок
Every error response has error (stable, machine-readable) and message (human-readable). Always switch on error.
Code
HTTP
Meaning
invalid_tx_hash
400
Это не шестнадцатеричная строка из 64 символов.
invalid_address
400
Недействительный адрес Tron
missing_signature
400
Подпись не предоставлена.
invalid_signature
401
Подпись не удалось подтвердить.
signature_mismatch
403
Адрес подписавшего лица не совпадает с адресом отправителя платежа.
hash_already_used
409
Хэш транзакции уже получен
payment_verification_failed
404 / 400
On-chain verification of the payment failed. Read the message field for the specific cause: tx not found yet (404, retry in a few seconds), wrong recipient, not a TRX transfer, or below the 4 TRX minimum.
delegation_failed
400 / 500
Provider could not deliver energy. If the failure happened after the payment was verified, an automatic refund is queued. The error response includes a refund object when this happens.
rate_limited
429
Слишком много запросов в секунду с этого IP-адреса. Лимит — 20 запросов в секунду.
server_error
500
Непредвиденная внутренняя ошибка. Повторите попытку через несколько секунд.
const result = awaitfetch('https://api.tronnrg.com/delegate', { ... })
.then(r => r.json());
if (result.error) {
switch (result.error) {
case'payment_verification_failed':
// Most common cause: tx not yet indexed. Wait 3s and retry.// Read result.message for the specific cause.break;
case'hash_already_used':
// Already claimed. Don't retry.break;
case'signature_mismatch':
// Signer != payment sender. Sign with the same key that sent TRX.break;
case'delegation_failed':
// Refund queued automatically if payment was verified.if (result.refund) console.log('Refund queued:', result.refund);
break;
}
}
result = requests.post('https://api.tronnrg.com/delegate', json=data).json()
if'error'in result:
if result['error'] == 'payment_verification_failed':
# Most common cause: tx not yet indexed. Wait 3s and retry.passelif result['error'] == 'hash_already_used':
# Already claimed. Don't retry.passelif result['error'] == 'signature_mismatch':
# Signer != payment sender. Sign with the same key.passelif result['error'] == 'delegation_failed':
# Refund queued automatically if payment was verified.pass
if (isset($result['error'])) {
switch ($result['error']) {
case'payment_verification_failed':
// Most common cause: tx not yet indexed. Wait 3s and retry.break;
case'hash_already_used':
// Already claimed. Don't retry.break;
case'signature_mismatch':
// Signer != payment sender. Sign with the same key.break;
case'delegation_failed':
// Refund queued automatically if payment was verified.break;
}
}
Refunds
Если после подтверждения платежа делегирование не удается, возврат средств TRX автоматически ставится в очередь и отправляется обратно на адрес отправителя в блокчейне. Найдите объект возврата в ответе об ошибке.
Error with refund
{
"error": "delegation_failed",
"message": "Energy delegation failed. Your payment will be refunded.",
"ref": "nrg_d_43",
"refund": {
"type": "queued",
"to": "TSenderAddress",
"amount": 4
}
}
Полный пример
Полный сквозной процесс: отправка TRX , подписание, подтверждение с повторной попыткой. Копирование и запуск.
const API = 'https://api.tronnrg.com';
const ADDR = 'TFqUiCu1JwLHHnBNeaaVKH7Csm4aA3YhZx';
async functionrentEnergy(delegateTo, trxAmount = 4) {
// 1. Send TRX to the payment addressconst payment = await tronWeb.trx.sendTransaction(ADDR, trxAmount * 1e6);
// 2. Sign: proves you are the senderconst message = `${payment.txid}:${delegateTo}`;
const signature = await tronWeb.trx.signMessageV2(message);
// 3. Claim delegation (retry if tx not indexed yet)let result;
for (let i = 0; i < 3; i++) {
result = awaitfetch(`${API}/delegate`, {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
tx_hash: payment.txid,
delegate_to: delegateTo,
signature,
}),
}).then(r => r.json());
if (!result.error) break;
if (result.error !== 'payment_verification_failed') throw newError(result.message);
await newPromise(r => setTimeout(r, 3000));
}
if (result.error) throw newError(result.message);
return result;
}
// Usage — send any amount between 4 and 1,000 TRXconst result = awaitrentEnergy('TWalletThatNeedsEnergy', 4); // 4 TRX → 65k energy// rentEnergy(addr, 8) // → 130,000 energy (new-wallet transfer)// rentEnergy(addr, 40) // → 650,000 energy (10 transfers)// rentEnergy(addr, 1000) // → 16,250,000 energy (max)
console.log(result.energy); // trxAmount × 16,250
console.log(result.delegations[0].tx); // on-chain tx hash
console.log(result.ref); // "nrg_d_42"
import requests
import time
API = 'https://api.tronnrg.com'
ADDR = 'TFqUiCu1JwLHHnBNeaaVKH7Csm4aA3YhZx'defrent_energy(delegate_to, trx_amount=4):
# 1. Send TRX to ADDR (via your Tron library)
tx_hash = send_trx(ADDR, trx_amount) # your TRX send function# 2. Sign: proves you are the sender
message = f'{tx_hash}:{delegate_to}'
signature = tron.trx.sign_message_v2(message)
# 3. Claim delegation (retry if tx not indexed yet)for attempt inrange(3):
result = requests.post(f'{API}/delegate', json={
'tx_hash': tx_hash,
'delegate_to': delegate_to,
'signature': signature,
}).json()
if'error'not in result:
return result
if result['error'] != 'payment_verification_failed':
raiseException(result['message'])
time.sleep(3)
raiseException('Transaction not found after retries')
# Usage
result = rent_energy('TWalletThatNeedsEnergy', 4)
print(f"Delegated: {result['energy']} energy")
print(f"Delegation tx: {result['delegations'][0]['tx']}")
print(f"Ref: {result['ref']}")
# 1. Send TRX to TFqUiCu1JwLHHnBNeaaVKH7Csm4aA3YhZx# Pricing is linear at 16,250 energy per TRX.# Min 4 TRX (65,000 energy), max 1,000 TRX (16.25M energy).# (use your wallet or tronweb CLI)# 2. Sign the message {tx_hash}:{delegate_to} (proves you are the sender)# (use tronWeb.trx.signMessageV2 in your code)# 3. Claim delegation with tx hash + signature
curl -X POST https://api.tronnrg.com/delegate \
-H "Content-Type: application/json" \
-d '{
"tx_hash": "YOUR_PAYMENT_TX_HASH",
"delegate_to": "TWalletThatNeedsEnergy",
"signature": "YOUR_SIGNATURE"
}'# Response includes delegations[].tx — the on-chain hash you can verify on TronScan