• tsTON на кошелек TON

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    71 Просмотры
  • Пожалуйста, найдите мой Тонкоин

    TON Overflow на русском
    0 Голоса
    2 Сообщения
    51 Просмотры

    Если вы только что отправили ton на адрес gate.io, вам следует обратиться в службу поддержки gate io. Они должны помочь

  • Dedust sdk заменяет jetton на ton

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    100 Просмотры

    https://docs.dedust.io/docs/swaps

    Здравствуйте, это работает, когда я меняю ton на jetton. Но не jetton -> ton.

    В документах "VaultJetton.createSwapPayload({ poolAddress })", откуда берется VaultJetton?

    Это из-за этого?

    const tokenVault = tonClient.open(await factory.getJettonVault(Address.parse(tokenAddress)));

    но в данном случае у него нет функции createSwapPayload

    Спасибо

    Оригинал вопроса

  • Как сгенерировать адрес из начальной фразы в Python?

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    29 Просмотры

    Как сгенерировать адрес из исходной фразы в Python? Как сгенерировать адрес из исходной фразы на python?

    Оригинал вопроса

  • Generate address/генерация адреса Python

    Main (Questions and answers)
    1 Голоса
    1 Сообщения
    48 Просмотры

    как Вы генерируете адреса по seed фразе на Python?
    не получается вообще, использую библиотеку tonclient
    очередная ошибка которую получил

    how generate address from seed phrase? Python

    bf139e9f-7dd2-4a0c-8fe0-6ee815fdb2d8-image.png

  • 0 Голоса
    2 Сообщения
    34 Просмотры

    устал от этой сети

  • Как добавить ton raffes в кошелек safepal

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    51 Просмотры

    Я хочу добавить токен ton raffes в safepal, но кошелек safepal не поддерживает пользовательскую сеть ton. Как вручную добавить сеть ton в кошелек safepal

    Оригинал вопроса

  • Тема для ТонТейк #2

    TonTake
    0 Голоса
    2 Сообщения
    31 Просмотры

    Ну какой конкурс на крипто приложение и крипто канал😅
    Накину завтра 0.05 TAKE за активность, но давай без GPT)

  • Идея для конкурсов ТонТейк

    TonTake
    1 Голоса
    6 Сообщения
    57 Просмотры

    @tonpie Да,задействовал когда идей совсем не было)

  • ШУМ 21 ВЕКА

    Перенесена Оффтоп
    0 Голоса
    2 Сообщения
    40 Просмотры

    *~~```
    [ Жирный текст](Адрес ссылки)

  • Тема для конкурса

    TonTake
    1 Голоса
    4 Сообщения
    64 Просмотры

    Закрывать предмет на картинке думаю интересно) +0.2 TAKE

  • Идеи для конкурсов TonTake (Конкурсы в ТонТейк играх)

    TonTake
    1 Голоса
    3 Сообщения
    34 Просмотры

    +0.2TAKE за идеи и мысли про расширение формата конкурсов)

  • Тема для ТонТейка

    TonTake
    1 Голоса
    3 Сообщения
    30 Просмотры

    +0.1 TAKE

  • Идея для конкурса TonTake (Рисунок посвящённый ТонТейку)

    TonTake
    1 Голоса
    4 Сообщения
    54 Просмотры

    +0.2 TAKE за хорошую идею и самый первый топик)

  • Переход с Trust Wallet на другие кошельки Ton

    TON Overflow на русском
    0 Голоса
    2 Сообщения
    76 Просмотры

    @Answers, сеть тон и сеть erc-20 не могут быть совмещены. Тебе нужно использовать несколько приложений, чтобы хранить биткоины и тоны(к примеру).

  • на некоторые вопросы нужна помощь в ответе

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    16 Просмотры

    Основано ли подтверждение депозита на номере подтверждения или пакете

    Оригинал вопроса

  • на некоторые вопросы нужна помощь в ответе

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    17 Просмотры

    Привет, сообщество TON, у меня есть несколько вопросов, на которые мне нужна ваша помощь, чтобы ответить

    Существуют ли какие-либо специальные советы по пополнению счета, такие как lunc, списать 1 Lunc со счета при первом пополнении, 2. К какому типу цепочек относится ton chain, evm? Или другие типы? 3. Основано ли подтверждение пополнения счета на номере подтверждения или пакете?

    Оригинал вопроса

  • 0 Голоса
    3 Сообщения
    336 Просмотры

    Вероятно, вам следует добавить параметр "archival=true" в ваш запрос транзакций.

  • Серийная/массовая чеканка NFT

    TON Overflow на русском
    0 Голоса
    1 Сообщения
    32 Просмотры

    Привет, сообщество TON,

    Я создаю игру на основе TON, которая использует некоторые NFT. В моем коде в основном используется код из этого туториала и библиотеки ton/ton-core/ton-crypto:

    Мой код развертывания NFT:

    public async deploy( wallet: OpenedWallet, collectionAddress: Address, params: mintParams ): Promise<number> { const seqno = await wallet.contract.getSeqno(); await wallet.contract.sendTransfer({ seqno, secretKey: wallet.keyPair.secretKey, messages: [ internal({ value: "0.05", to: collectionAddress, body: this.createMintBody(params), }), ], sendMode: SendMode.IGNORE_ERRORS + SendMode.PAY_GAS_SEPARATELY, }); return seqno; }

    И после того, как я снова буду ждать:

    export async function waitSeqno(seqno: number, wallet: OpenedWallet): Promise<number> { for (let attempt = 0; attempt < 20; attempt++) { await sleep(2000); const seqnoAfter = await wallet.contract.getSeqno(); if (seqnoAfter == seqno + 1) { return Promise.resolve(seqno) } } return Promise.reject(`Seqno ${seqno} timeout`) } export function sleep(ms: number): Promise<void> { return new Promise((resolve) => setTimeout(resolve, ms)); }

    Затем я получаю подтверждение с помощью seqno, я запрашиваю адрес элемента NFT по индексу NFT:

    static async getAddressByIndex( collectionAddress: Address, itemIndex: number, tonCenterApiKey: string ): Promise<Address> { const client = new TonClient({ endpoint: "https://toncenter.com/api/v2/jsonRPC", apiKey: tonCenterApiKey, }); const response = await client.runMethod( collectionAddress, "get_nft_address_by_index", [{ type: "int", value: BigInt(itemIndex) }] ); return response.stack.readAddress(); }

    Весь процесс занимает до 30 секунд на 1 NFT. Мне интересно, есть ли лучший вариант для чеканки, например, 10 NFT, или лучший способ - чеканить один за другим и ждать подтверждения? В этом случае у меня есть некоторые опасения по поводу количества NFT, которых я могу достичь в течение 1 часа. Прямо сейчас я должен отчеканить все элементы последовательно, потому что для команды отчеканки требуется параметр индекса nft, и перед отчеканкой следующего элемента я должен получить подтверждение того, что предыдущий отчеканен правильно.

    Оригинал вопроса

  • 0 Голоса
    1 Сообщения
    43 Просмотры

    Я пытался повторно использовать кошелек, удаленный с помощью флага DESTROY_ACCOUNT_IF_ZERO (32). Способ, которым я осуществляю перевод:

    Представьте, что у нас есть 2 кошелька: A и B.

    Мы переводим N1 тонну из "A" в "B". Например, с помощью веб-кошелька, скрипта, не имеет значения. 2. B неинициализирован - его еще нет в блокчейне. Имея это в виду, мы хотели бы отправить все деньги из B обратно в A. Для этого мы собираемся использовать прилагаемый скрипт. 3. Теперь мы идем дальше и переносим N2 ТОННЫ из A в B ** снова **. Не имеет значения, сколько.

    Ожидаемое поведение: мы получаем транзакции: A->B (N1), B->A (все), A->B (N2); в конечном итоге в кошельке B содержится N2 тонн.

    Фактическое поведение: мы получаем транзакции A->B (N1), B->A (все), A->B (N2), B->A (все); в кошельке B в итоге 0 тонн.

    Сценарий для передачи B->A (all), который вызывает такое поведение:

    import TonWeb from 'tonweb'; import tonwebMnemonic from 'tonweb-mnemonic'; const apiKey = "" || undefined; // WALLET B const mnemonic = "..."; const walletVersion = "v4R2"; // WALLET A const toAddress = "..."; const SendMode = { CARRY_ALL_REMAINING_BALANCE: 128, CARRY_ALL_REMAINING_INCOMING_VALUE: 64, DESTROY_ACCOUNT_IF_ZERO: 32, PAY_GAS_SEPARATELY: 1, IGNORE_ERRORS: 2, NONE: 0 } const sleep = ms => new Promise(resolve => setTimeout(resolve, ms)); (async () => { const provider = new TonWeb.HttpProvider('https://toncenter.com/api/v2/jsonRPC', {apiKey}); const WalletClass = TonWeb.Wallets.all[walletVersion]; const mnemonicArray = mnemonic.split(" "); let { publicKey, secretKey } = await tonwebMnemonic.mnemonicToKeyPair(mnemonicArray); publicKey = Buffer.from(publicKey); secretKey = Buffer.from(secretKey); console.log(`PUBLIC KEY: ${publicKey.toString('hex')}`); const wallet = new WalletClass(provider, { publicKey }); const seqno = await wallet.methods.seqno().call() || 0; console.log(`SEQNO: ${seqno}`); await sleep(2000); const transferParams = { secretKey, toAddress, amount: 0, seqno, sendMode: SendMode.CARRY_ALL_REMAINING_BALANCE | SendMode.IGNORE_ERRORS | SendMode.DESTROY_ACCOUNT_IF_ZERO, payload: "test bug" }; console.log(JSON.stringify({...transferParams, secretKey: transferParams.secretKey.toString('hex')}, null, 2)); const response = await wallet.methods.transfer(transferParams).send(); console.log(`transfer sent to blockchain: ${JSON.stringify(response, null, 2)}`); })();

    Странная вещь: если вы отправите A->B (N) снова, он автоматически создаст новую передачу B->A (all) снова и снова. Иногда она останавливается на 2 повторениях, иногда на 4.

    Я использую недоступный адрес: UQAPqRlewultl8xHCKGsrenb4PZaQ0QDfPYoK1fwVUODdZRd.

    Я также попробовал отправить TON с кошелька "C (C->B). И деньги ДЕЙСТВИТЕЛЬНО остались на B`. НО как только я снова сделал перевод "A->B", все деньги, включая тонны, отправленные с "C", автоматически перешли на "A"!

    Пример проявления этой ошибки (это ошибка??) находится здесь:

    https://tonviewer.com/EQAySjlsHUY2EEedO5GTenzFvAnR5E-4ptwfeox6OZYnNvGF

    Это кошелек B. Скрипт отправил только первое сообщение с текстом "тестовая ошибка". Остальные сообщения отправлялись автоматически при любом входящем переводе с A.

    В этом взаимодействии:

    A is UQAPqRlewultl8xHCKGsrenb4PZaQ0QDfPYoK1fwVUODdZRd * B is EQAySjlsHUY2EEedO5GTenzFvAnR5E-4ptwfeox6OZYnNvGF * C is UQBwpXsIVrij8UQ2OpPK2EyeVBrlN6mnOkmThb3k6K-UHZyL

    Я хочу понять, почему это происходит. Это задумано разработчиками блокчейна TON? Это не ошибка? Как обойти это и повторно использовать удаленные кошельки?

    Оригинал вопроса