Desplegar tu servidor de transacciones
Proporciona a los usuarios transacciones sin costo
El transactions-server es un servidor proxy que retransmite transacciones a Gelato. Recibe una transacción firmada del cliente que a su vez se envía a la red apropiada entre bastidores. Esto permite al propietario del servidor facilitar a sus usuarios transacciones sin coste
El servidor de transacciones se utiliza para ayudar con la experiencia de usuario al usar múltiples redes y para evitar que cambien de proveedor de red sobre la marcha. Los usuarios pueden seguir conectados a Ethereum e interactuar con Polygon solo firmando transacciones
La DAO de Decentraland ha configurado un servidor usado por nuestras dapps, cubriendo el coste hasta cierto límite con algunas restricciones. Este documento explica cómo puedes desplegar este servidor para permitir que tus usuarios retransmitan transacciones con las restricciones que necesites, si las hay.
Restricciones
Todas las restricciones son por transacción que el usuario intente enviar. Lo que, en la práctica, se traduce en una solicitud POST al servidor.
Las restricciones configurables que tiene el servidor son:
Comprueba una cuota de transacciones máximas por día. Ver la sección de colecciones para más información.
Comprueba contratos en la lista blanca, así que si una transacción intenta interactuar con un contrato que no está reconocido fallará. Para hacer esto utiliza
Los contratos desplegados y colecciones. Ver la sección de contratos y colecciones para más información
El precio de las ventas, restringiéndolo si está por debajo de un umbral. Ver sección de valor mínimo de venta para más información
Configuración de Gelato
Gelato es un Protocolo Relayer Multichain. Usamos su infraestructura para permitir transacciones sin coste. Esto efectivamente significa que, cuando vas a enviar una transacción, en su lugar estás firmando un mensaje y enviándolo a Gelato. El servicio se encargará de enviar la transacción por ti y devolverte una respuesta (hash de la transacción).
Necesita un contrato para reenviar las transacciones, pero afortunadamente podemos reutilizar el que está siendo usado por Decentraland (ver más abajo)
Gelato funciona como una API para el servidor. Para configurar lo necesitarás primero una API KEY que usaremos más adelante. Para obtenerlas:
Regístrate en el servicio
Crea una nueva dapp para la red que pretendes dirigir. Para imitar lo que configuró Decentraland:
Selecciona la
MainnetsopcionesEstablece un
Nombre de la appapropiado para tu dAppelige
Polygoncomo la red para elSmart ContractHabilita el
Any Contractopción de alternar
Copia la API KEY desde la
API Keysección
Por último, necesitarás financiar tu dapp recién creada. Puedes hacer esto conectando tu wallet en la 1Balance sección en la barra lateral izquierda. Una vez conectado, te permitirá depositar tu USDC para financiar las transacciones que enviarán tus usuarios. Si necesitas obtener MATIC, revisa este artículo.
Testnet
Si quieres probar tu aplicación antes de lanzarla y estás usando Polygon puedes hacerlo en Polygon Amoy, la testnet de Polygon.
Para hacerlo simplemente repite el proceso pero eligiendo Matic Testnet (Amoy) en el campo de red.
Necesitarás financiar tu dapp, pero puedes hacerlo fácilmente obteniendo tokens Sepolia ETH desde el faucet.
Descargando el servidor de transacciones
Primero, necesitarás una copia del código de transactions-server de Decentraland. Puedes encontrarlo en github. A partir de ahí, tienes dos opciones:
Descargando el código: Para descargar el código, primero tienes que hacer clic en el botón verde
Codey luego o bien
Haz clic en
Download ZIPCopia la URL bajo el
Clonetítulo y luego ejecuta$ git clone THE_URL_HERE
Haciendo un fork del código: Puedes hacer clic en el botón
forken la esquina superior derecha de la página. Una vez completado el proceso, podrás descargar tu código de la misma manera que en la primera opción. Necesitarás una cuenta de Github para esto; para más información sobre cómo forkear repositorios consulta aquí
Configurando el servidor
El servidor de transactions está escrito en NodeJS usando Typescript. Antes de ejecutarlo necesitarás configurar algunas variables de entorno.
Para hacer esto:
Copia el
.env.examplearchivo y pégalo renombrado a.envAbre el
.envarchivo. Verás que algunas variables tienen un valor por defecto, comoHTTP_SERVER_PORT=5000(en qué puerto ejecutar el servidor)Puedes dejar la mayoría de los valores tal como están, pero hay algunos valores importantes a considerar:
Gelato
Usa la API KEY que obtuvimos cuando configurando gelato.
Transacciones
Cuando llega una nueva solicitud de transacción comprobará la cantidad una dirección ha enviado ese día. Si está por encima del valor establecido la transacción fallará.
Para eliminar completamente esta comprobación, puedes ir al código y eliminar el
método de async function checkData(transactionData: TransactionData): Promise<void> { en src/ports/transactions/component.ts
Contratos y colecciones
El servidor recuperará la URL de Contract addresses y las almacenará localmente y consultará el subgraph. Cuando llegue una nueva solicitud de transacción comprobará si el contrato con el que interactúa la transacción pertenece ya sea a los contratos desplegados en la URL o a las colecciones desplegadas en el subgraph.
Si quieres proporcionar tus propios contratos cambia la URL y conserva la misma estructura que la actual https://contracts.decentraland.org/addresses.json tiene. La red utilizada se determina por COLLECTIONS_CHAIN_ID, y el intervalo con el que se vuelve a obtener la caché es COLLECTIONS_CHAIN_ID
Si tienes tus propias colecciones también puedes cambiar la URL del subgraph.
Para eliminar completamente estas comprobaciones, puedes ir al código y eliminar el
método de async function checkData(transactionData: TransactionData): Promise<void> { en src/ports/transactions/component.ts
Valor mínimo de venta
Cuando llega una nueva solicitud de transacción primero analizará los datos que intenta retransmitir. Si detecta una venta (compra en marketplace, oferta, etc.), comprobará el valor frente a MIN_SALE_VALUE_IN_WEI. Si es inferior, la transacción fallará.
Para comprobar los métodos de venta relevantes, puedes ver src/ports/transaction/validation/checkSalePrice.ts y para eliminar completamente esta comprobación, puedes ir al código y eliminar el
método de async function checkData(transactionData: TransactionData): Promise<void> { en src/ports/transactions/component.ts
Ejecutando el servidor
Ahora que toda la configuración está lista, lo que queda es ejecutar el servidor. Puedes seguir su README pero en resumen, tendrás que:
Tener NodeJS instalado
Abre tu terminal preferida
Ejecuta los siguientes comandos:
Por supuesto, probablemente querrás desplegar esto en el servicio de tu elección, como AWS por ejemplo. Puedes usar el Dockerfile del Proyecto para hacerlo.
Usando el servidor
Ahora que todo está configurado y en funcionamiento, es hora de usar realmente el servidor.
Para enviar realmente una transacción, necesitas hacer un POST a /transactions. El esquema requerido para la solicitud está definido por transactionSchema en src/ports/transaction/types.ts.
Si, en cambio, quieres usar nuestras bibliotecas preconstruidas para facilitarte la vida puedes probar decentraland-transactions. Se usa a través de decentraland-dapps en nuestras dapps como el Marketplace, con las utilidades sendTransaction. Consulta este código para un ejemplo.
Última actualización