Головна
Ласкаво просимо на форум спільноти Move
Нові статті
- Sui Sponsored Transactions - Basic Integrations ExamplesСтаттяOct 31, 2023
Traditionally, users engaging with decentralized aplications (dApps) face a common hurdle: gas fees. These Sui gas fees in our case, required to execute transactions on the blockchain, often deter new users from fully embracing the potential of Web3. However, Sui innovative sponsored transaction feature eliminates this obstacle, empowering builders to cover the gas fees for their app transactions. This revolutionary functionality paves the way for a seamless user experience, encouraging broader adoption of decentralized applications. TheMoveDev GitHub; SuiQL GitHub Repository; If you have any questions, you can ask them here. Sponsored Transaction Workflow Sui's sponsored transaction workflow is a well-orchestrated process that ensures smooth and gas fee-free transactions for end-users. Here's a breakdown of the steps involved. User Initiates an Action The process kicks off when a user initializes a GasLessTransactionData transaction, indicating their intent to perform a specific action within a dApp. dApp Creates a Sui Transaction Block At the heart of the sponsored transaction workflow lies the dApp's ability to create a Transaction Block. This block encapsulates all the necessary data, including the user's intent, the action to be performed, and any associated parameters. Transmission of GasLessTransactionData The GasLessTransactionData is sent to the sponsor, a key participant in the sponsored transaction framework, with a signature request. This data serves as the foundation for the upcoming transaction. Validation and Transaction Data Construction The sponsor validates the received transaction and constructs TransactionData, incorporating the necessary gas fees. This step ensures that the transaction is properly funded for execution on the Sui blockchain. Transaction Signing The sponsor signs the TransactionData, indicating their approval and commitment to the transaction. The private key required for this signature is securely stored in AWS Secrets Manager, ensuring the utmost security. Verification and Dual Signing by the User The signed TransactionData, along with the sponsor's signature, is sent back to the user. The user verifies the transaction details and signs the TransactionData once more, creating a dual-signed transaction ready for execution. Transaction Execution on Sui The dual-signed transaction is submitted to the Sui network via a Sui node (full node) or the sponsor. Sui processes the transaction, executing the specified action within the dApp, all without requiring the user to pay any gas fees. User Notification Finally, the user is notified by a dApp that the transaction is sponsored and sent. Implementing Sui Sponsored Transactions: A Developer's Perspective To implement sponsored transactions, developers interact with the Sui API or Sponsored Transaction API, making use of the sui-sign-sponsored-transaction Lambda function. Here's a glimpse of the client-side code that facilitates this process: const response = await fetch('http://localhost:5000/blockchain/sui-sign-sponsored-transaction', { method: 'POST', headers: { Accept: 'application/json', 'Content-Type': 'application/json', }, body: JSON.stringify({ sender: wallet.address, module: libName, action, arguments: data, }), }); const sponsorSignedTransaction = await response.json(); const transactionBlock = TransactionBlock.from(sponsorSignedTransaction?.transactionBlockBytes); const senderSignedTransaction = await wallet.signTransactionBlock({ transactionBlock, }); const executeResponse = await provider.executeTransactionBlock({ transactionBlock: sponsorSignedTransaction?.transactionBlockBytes, signature: [sponsorSignedTransaction?.signatureBytes, senderSignedTransaction.signature], options: { showEffects: true }, requestType: 'WaitForLocalExecution', }); This client-side code acts as a bridge between the user, the sponsor, and the Sui blockchain, enabling the seamless execution of gas fee-free transactions. Conclusion Sui's sponsored transaction feature represents a paradigm shift in the world of decentralized applications, removing a significant barrier to entry for users. Through our exploration of this innovative functionality, we've gained valuable insights that have shaped our approach to building user-friendly dApps. Feel free to leave your questions here.
0 - Sui Move Events Listeners and Webhooks - Basic Integrations ExamplesСтаттяOct 31, 2023
For businesses and developers, integrating with chains like Sui offers a unique opportunity to innovate and create transformative solutions. In this series, we delve into our journey of building on Sui, shedding light on the intricacies of integrations, focusing on event listeners and webhooks, which have been integral components of TheMoveDev and SuiQL, Sui indexing GraphQL Event API made by Peeranha. TheMoveDev GitHub; SuiQL GitHub Repository; If you have any questions, you can ask them here. The code is implemented in TypeScript and runs within the AWS Cloud environment using serverless technologies. Serverless is used for deployments. Serverless Offline is used to run the code locally. Sui Events Listeners and Webhooks: A Brief Overview Blockchain networks are inherently decentralized, making real-time data integration a challenging feat. This is where event listeners and webhooks come into play. Event Listeners are mechanisms that constantly monitor blockchain activity, identifying and capturing specific events of interest. Webhooks, on the other hand, are HTTP callbacks triggered by these events, allowing seamless communication between different applications. The Sui Integration Architecture Our integration journey with Sui involved a comprehensive architecture comprising several key components. Events Listener The Events Listener, a robust ECS Fargate task, plays a pivotal role in our integration setup. It continuously polls new events from the Sui nodes (Sui full node), ensuring that our system stays up-to-date with the latest blockchain activities. Sui Events Listener Queue Events identified by the Events Listener are added to the Sui Listener Queue, a FIFO SQS queue. This queue acts as an intermediary storage, enabling efficient event processing and management. Webhook Invoker Responsible for invoking webhooks, the Webhook Invoker is a Lambda function that ensures seamless communication between our system and external applications. It acts as a bridge, facilitating the transmission of event data to the designated endpoints. Event Bridge The Event Bridge, a pivotal component of our architecture, invokes the Webhook Invoker Lambda whenever new items are added to the Sui Listener Queue. This real-time triggering mechanism ensures prompt webhook invocations. Webhook The Webhook, implemented as an AWS Lambda function, processes individual events received from the Sui blockchain. This component plays a crucial role in interpreting the event data and executing specific actions based on the event type. Workflow: How It All Comes Together Understanding the workflow is essential to grasp the seamless operation of our integration architecture. Events Listener Operation The Events Listener operates in a continuous loop, making RPC API calls to suix_queryEvents to retrieve new events associated with a configured package ID. The Events Listener maintains a cursor value in DynamoDB, ensuring it reads events chronologically. Adding Events to Sui Listener Queue Whenever the Events Listener identifies new events, it adds them to the Sui Listener Queue for further processing. Event Bridge Trigger The AWS Event Bridge monitors the Sui Listener Queue and triggers the Webhook Invoker Lambda as soon as new items are added. This ensures real-time event processing. Webhook Invocation The Webhook Invoker, once triggered, invokes the Webhook Lambda function for each event present in the queue. Running Locally - Dev Playground Serverless offline plugin is used to run the solution locally. Listener runs in ECS task in the cloud. ECS is not available for serverless offline. For that reason, uncomment the sui-events-listener lambda function in serverless.yml. This function will read new events from the blockchain once per minute. Install dependencies: npm install Install DynamoDb: npm run dynamodb:install If you are getting an error Error getting DynamoDb local latest tar.gz location undefined: 403 on this step then it means that there is still a known issue in serverless-dynamodb-local. It is discussed here or you can leave your question on Sui Move Q&A. In node_modules/dynamodb-localhost/dynamodb/config.json URL to https://s3.us-west-2.amazonaws.com/dynamodb-local/dynamodb_local_latest.tar.gz (add s to http); In node_modules/dynamodb-localhost/dynamodb/installer.j change http to https; To start services run: npm run dev Event Listener Deployment to AWS Install AWS CLI; Configure AWS CLI; aws configure Modify values in stages\test.yml and stages\prod.yml; Start deployment; npm run deploy:test or npm run deploy:prod To be continued... In this first part of our series on Sui integrations, we've explored the foundational concepts of event listeners and webhooks, unraveling the intricate architecture behind our integration with the Sui blockchain. Stay tuned for the upcoming parts, where we'll delve deeper into our journey, sharing insights, challenges, and innovative solutions that have shaped our experience. Feel free to leave your questions here.
1
Пости
148- Питання та відповіді експертівApr 11, 2025
Як створити читабельний байтовий код для переміщення за допомогою збірки Miden?
Я намагаюся експериментувати з написанням компілятора Move, використовуючи Miden Assembly як ціль компілятора. Я хочу створити читабельний байтовий код для компільованої програми Move. Чи є простий спосіб досягти цього?
- Move CLI
01 - Питання та відповіді експертівelfDani139Apr 11, 2025
Чи можуть модулі створювати кілька монет на ланцюжку без проблем?
Я працюю над модулем для ринків прогнозування, і він потрібен для створення монет на ланцюжку через заводський клас бездозвольним і перевіреним способом. В даний час модулі мають обмеження, як-от лише одна монета на модуль через One Time Witness, а це означає, що мені довелося створити еквівалентний стандарт монет, який гаманці користувачів не визнають як монету. Чи можемо ми вирішити це в наступному оновленні?
- Move CLI
- Move Module
01 - Питання та відповіді експертівskywinder271Apr 10, 2025
Що таке рідна функція і чи можемо ми називати їх безпосередньо?
Я натрапив на термін «рідна функція» у Move, але не можу знайти детальної інформації про це. Я чув, що вони оголошені в Move, але визначені зовні, часто в Rust. Чи означає це, що це внутрішні функції, які не можна викликати безпосередньо гаманцями чи іншими модулями?
- Move CLI
- Move
01 - Питання та відповіді експертівApr 10, 2025
Як передати об'єкт, що належить іншому об'єкту?
Я стикаюся з проблемою з передачею об'єкта А, який належить об'єкту B, а об'єкт B належить мені. Я отримую помилку, що повідомляє, що транзакція не була підписана правильним відправником. Хтось знає, як це вирішити і правильно отримати об'єкт А?
- Move CLI
- Move
01 - Питання та відповіді експертівPluto Dev👽141Apr 10, 2025
Перетворення відкритого ключа на адресу Sui в Sui Move
Я намагаюся перетворити відкритий ключ у адресу Sui за допомогою Sui Move, але не можу знайти жодної вбудованої функції. Я розумію, що це дуже важливо для моєї роботи. Чи міг би хтось пояснити, як саме зробити це перетворення?
- Move CLI
01 - Обговорення1 Luca31Apr 10, 2025
Чи підтримує Суй контракт на самознищення?
Мені було цікаво, чи є спосіб знищити чи самознищити смарт-контракт в рамках Sui. Я почув щось про механізм «самознищення» і хотів знати, чи існує він у Суї. Крім того, що станеться, якщо контракт розірваний таким чином?
- Move
- Smart Contract
01 - Питання та відповіді експертівyhant3251Apr 07, 2025
Як переконатися, що лише власник NFT може передати його в контракті?
Привіт усім! Я працюю над реалізацією контракту NFT і хочу переконатися, що передати його може лише законний власник NFT. У мене є така функція для перенесення: public fun transfer( nft: DevNetNFT, recipient: address, _: &mut TxContext ) { transfer::public_transfer(nft, recipient) } Чи виконується ця перевірка в рамках public_transferметоду, чи мені потрібно додати додаткову логіку?
- Move CLI
03 - Питання та відповіді експертівBritain92Apr 07, 2025
Як отримати значення з ObjectTable за допомогою динамічних полів?
dynamicFieldObjectЯ намагаюся отримати значення з ObjectTable за допомогою динамічних полів з інтерфейсу, але стикаюся з помилкою. Помилка говоритьUnexpected arg String("gms") for the expected type Struct(MoveStructLayout...). Як я можу отримати правильний тип значення і уникнути цієї помилки?
- Move CLI
- Move
03 - Питання та відповіді експертівRaju158Apr 06, 2025
Як перевірити функцію з параметром отримання в Sui?
Я намагаюся протестувати receive_objectфункцію з Receivingпараметром у Sui на основі документів за цим посилання. Спочатку я створив тест на прикладі, але я боюся з тим, як змусити надісланий аргумент бути ти Receivingпом. Я також намагався позначити тип прийому, але зіткнувся з помилками. Чи може хтось допомогти мені правильно перевірити цю функцію?
- Move CLI
- Move
04 - Питання та відповіді експертівApr 06, 2025
Як я можу скопіювати вектор <u64>для використання кілька разів?
Я намагаюся скопіювати вектор у локальну змінну, тому що мені потрібні два екземпляри одного і того ж вектора для мого проекту. Я бачив деякі методи, але не зовсім впевнений, як їх правильно реалізувати. Хтось може допомогти мені щодо найкращих практик або методів досягнення цього на мові програмування Move?
- Move CLI
- Move
04
Move is an executable bytecode language used to implement custom transactions and smart contracts.
Зароби свою частку з 1000 Sui
Заробляй бали репутації та отримуй винагороди за допомогу в розвитку спільноти Sui.
- Move CLI
- Move
- Move Module
- Move Bug
- Smart Contract
- Move Script
- Move Prover
- Feature Request