Saltar al contenido principal

Subnet WAGMI

La Subnet WAGMI ("Todos vamos a lograrlo") es un banco de pruebas de alto rendimiento para optimizaciones de la Máquina Virtual Ethereum (EVM). Está parametrizada para funcionar con una capacidad mayor que la C-Chain Fuji/Mainnet y se utiliza para experimentar con candidatos a versiones antes de incluirlos en una versión oficial de Coreth.

Resumen

Este es uno de los primeros casos de uso de las Subnets Avalanche como terreno de prueba para cambios en una VM de producción (Coreth). Muchos subestiman lo útil que es el aislamiento de las Subnets para realizar pruebas de VM complejas en una red viva (sin afectar la estabilidad de la red primaria).

Creamos un explorador básico de WAGMI https://subnets-test.avax.network/wagmi que muestra estadísticas de uso agregadas sobre la Subnet.

Parámetros de la Red

  • ID de Red: 11111
  • ID de Cadena: 11111
  • Límite de Gas de Bloque: 20,000,000 (2.5 veces la C-Chain)
  • Objetivo de Gas de 10s: 100,000,000 (~6.67 veces la C-Chain)
  • Tarifa Mínima: 1 Gwei (4% de la C-Chain)
  • Tasa de Bloques Objetivo: 2s (igual que la C-Chain)

El archivo génesis de WAGMI se puede encontrar aquí.

Agregando WAGMI a Core

- Nombre de Red: WAGMI
- URL RPC: [https://subnets.avax.network/wagmi/wagmi-chain-testnet/rpc]
- URL WS: wss://subnets.avax.network/wagmi/wagmi-chain-testnet/ws
- ID de Cadena: 11111
- Símbolo: WGM
- Explorador: [https://subnets.avax.network/wagmi/wagmi-chain-testnet/explorer]
info

Esto también se puede usar con otras billeteras, como MetaMask.

Estudio de caso: Actualización de WAGMI

Este estudio de caso utiliza la actualización de la Subnet WAGMI para mostrar cómo se puede hacer una actualización de red en una Subnet basada en EVM (Máquina Virtual Ethereum) de manera sencilla, y cómo la actualización resultante se puede utilizar para controlar dinámicamente la estructura de tarifas en la Subnet.

Introducción

Subnet-EVM tiene como objetivo proporcionar una caja de herramientas fácil de usar para personalizar la EVM para tu blockchain. Está diseñado para funcionar sin problemas para muchas Subnets sin necesidad de ninguna modificación. Pero, ¿qué sucede cuando quieres agregar una nueva característica actualizando las reglas de tu EVM?

En lugar de codificar en duro el momento de las actualizaciones de red en el código del cliente como la mayoría de las cadenas EVM, que requieren implementaciones coordinadas de nuevo código, Subnet-EVM v0.2.8 introduce la esperada característica de realizar actualizaciones de red utilizando solo unas pocas líneas de JSON en un archivo de configuración.

Actualizaciones de Red: Habilitar/Deshabilitar Precompilaciones

Una descripción detallada de cómo hacer esto se puede encontrar en el tutorial Personalizar una Subnet. Aquí tienes un resumen:

  • La actualización de red utiliza precompilaciones existentes en Subnet-EVM:
    • ContractDeployerAllowList, para restringir a los desplegadores de contratos inteligentes
    • TransactionAllowList, para restringir quién puede enviar transacciones
    • NativeMinter, para acuñar monedas nativas
    • FeeManager, para configurar tarifas dinámicas
    • RewardManager, para habilitar recompensas de bloque
  • Cada una de estas precompilaciones se puede habilitar o deshabilitar individualmente en un momento dado como una actualización de red, o cualquiera de los parámetros que rigen su comportamiento se puede cambiar.
  • Estas actualizaciones deben especificarse en un archivo llamado upgrade.json ubicado en el mismo directorio donde se encuentra el archivo config.json de la cadena: {directorio-de-configuración-de-cadena}/{ID-de-blockchain}/upgrade.json.

Preparación

Para prepararnos para la primera actualización de red de WAGMI, el 15 de agosto de 2022, lo anunciamos en Twitter y lo compartimos en otras redes sociales como Discord.

Para la segunda actualización, el 24 de febrero de 2024, hicimos otro anuncio en X.

Desplegando upgrade.json

El contenido de upgrade.json es:

{
"precompileUpgrades": [
{
"feeManagerConfig": {
"adminAddresses": ["0x6f0f6DA1852857d7789f68a28bba866671f3880D"],
"blockTimestamp": 1660658400
}
},
{
"contractNativeMinterConfig": {
"blockTimestamp": 1708696800,
"adminAddresses": ["0x6f0f6DA1852857d7789f68a28bba866671f3880D"],
"managerAddresses": ["0xadFA2910DC148674910c07d18DF966A28CD21331"]
}
}
]
}

Con el upgrade.json anterior, pretendemos realizar dos actualizaciones de red:

  1. La primera actualización es activar la precompilación de FeeManager:
    • 0x6f0f6DA1852857d7789f68a28bba866671f3880D es nombrado como el nuevo Admin de la precompilación de FeeManager.
    • 1660658400 es el timestamp Unix para el mar. 16 ago. 2022 14:00:00 GMT+0000 (hora futura en la que hicimos el anuncio) cuando el cambio de FeeManager entraría en efecto.
  2. La segunda actualización es activar la precompilación de NativeMinter:
    • 0x6f0f6DA1852857d7789f68a28bba866671f3880D es nombrado como el nuevo Admin de la precompilación de NativeMinter.
    • 0xadFA2910DC148674910c07d18DF966A28CD21331 es nombrado como el nuevo Manager de la precompilación de NativeMinter. Las direcciones de Manager están habilitadas después de las actualizaciones de Durango que ocurrieron el 13 de feb. 2024.
    • 1708696800 es el timestamp Unix para el vie. 23 feb. 2024 14:00:00 GMT+0000 (hora futura en la que hicimos el anuncio) cuando el cambio de NativeMinter entraría en efecto.

Las explicaciones detalladas de feeManagerConfig se pueden encontrar aquí, y para contractNativeMinterConfig en aquí.

Colocamos el archivo upgrade.json en el directorio de configuración de la cadena, que en nuestro caso es ~/.avalanchego/configs/chains/2ebCneCbwthjQ1rYT41nhd7M76Hc6YmosMAQrTFhBq8qeqh6tt/. Después de eso, reiniciamos el nodo para que se cargue el archivo de actualización.

Cuando el nodo se reinicia, AvalancheGo lee el contenido del archivo JSON y lo pasa a Subnet-EVM. Vemos un registro de la configuración de la cadena que incluye la actualización de precompilación. Se ve así:

INFO [02-22|18:27:06.473] <2ebCneCbwthjQ1rYT41nhd7M76Hc6YmosMAQrTFhBq8qeqh6tt Chain> github.com/ava-labs/subnet-evm/core/blockchain.go:335: Upgrade Config: {"precompileUpgrades":[{"feeManagerConfig":{"adminAddresses":["0x6f0f6da1852857d7789f68a28bba866671f3880d"],"blockTimestamp":1660658400}},{"contractNativeMinterConfig":{"adminAddresses":["0x6f0f6da1852857d7789f68a28bba866671f3880d"],"managerAddresses":["0xadfa2910dc148674910c07d18df966a28cd21331"],"blockTimestamp":1708696800}}]}

Observamos que precompileUpgrades muestra correctamente las próximas actualizaciones de precompilación. La actualización está bloqueada y lista.

Activaciones

Cuando pasó el tiempo de las 10:00 AM EDT del 16 de agosto de 2022 (timestamp Unix 1660658400), el upgrade.json había sido ejecutado según lo planeado y la nueva dirección de administrador de FeeManager ha sido activada. A partir de ahora, no necesitamos emitir ningún código nuevo o desplegar nada en los nodos WAGMI para cambiar la estructura de tarifas. ¡Veamos cómo funciona en la práctica!

Para la segunda actualización el 23 de febrero de 2024, se siguió el mismo proceso. El upgrade.json había sido ejecutado después de Durango, según lo planeado, y las nuevas direcciones de administrador y manager de NativeMinter han sido activadas.

Uso del Fee Manager

El propietario 0x6f0f6DA1852857d7789f68a28bba866671f3880D ahora puede configurar las tarifas en la Subnet como consideren adecuado. Para hacer eso, todo lo que se necesita es acceso a la red, la clave privada de la dirección de administrador recién establecida y realizar llamadas al contrato precompilado.

Usaremos Remix un IDE de Solidity en línea y la Extensión del Navegador Core. Core viene con la red WAGMI incorporada. MetaMask también servirá, pero deberá agregar WAGMI usted mismo.

Primero, usando Core, abrimos la cuenta como propietario 0x6f0f6DA1852857d7789f68a28bba866671f3880D.

Luego conectamos Core a WAGMI, activamos el Modo Testnet en la página Avanzado en el menú de hamburguesa:

Modo Testnet de Core

Y luego abrimos el menú Manage Networks en el menú desplegable de redes. Seleccionamos WAGMI allí haciendo clic en el icono de estrella:

Selección de red de Core

Luego cambiamos a WAGMI en el menú desplegable de redes. Estamos listos para pasar a Remix ahora, así que lo abrimos en el navegador. Primero, verificamos que Remix vea la extensión y hable correctamente con ella. Seleccionamos el icono Deploy & run transactions en el borde izquierdo, y en el menú desplegable de Entorno, seleccionamos Injected Provider. Necesitamos aprobar el acceso de la red Remix en la extensión del navegador Core. Cuando eso esté hecho, se muestra Custom (11111) network:

Proveedor inyectado

¡Bien, estamos hablando con la Subnet WAGMI! A continuación, necesitamos cargar los contratos en Remix. Usando la opción 'load from GitHub' desde la pantalla de inicio de Remix, cargamos dos contratos:

IFeeManager es nuestro precompilado, pero hace referencia a IAllowList, así que también necesitamos ese. Compilamos IFeeManager.sol y lo desplegamos en la dirección de precompilación 0x0200000000000000000000000000000000000003 utilizada en la Subnet.

Contrato desplegado

Ahora podemos interactuar con el precompilado FeeManager desde Remix a través de Core. Por ejemplo, podemos usar el método getFeeConfig para verificar la configuración de tarifas actual. Cualquiera puede realizar esta acción, ya que es solo una operación de lectura.

Una vez que tengamos la nueva configuración deseada para las tarifas en la Subnet, podemos usar setFeeConfig para cambiar los parámetros. ¡Esta acción solo puede ser realizada por el propietario 0x6f0f6DA1852857d7789f68a28bba866671f3880D como la adminAddress especificada en el upgrade.json anterior.

setFeeConfig

Cuando llamamos a ese método presionando el botón transact, se publica una nueva transacción en la Subnet, y podemos verla en el explorador:

transacción

Inmediatamente después de que se acepta la transacción, la nueva configuración de tarifas entra en efecto. Podemos verificar con getFeeCofig que los valores se reflejan en la configuración de tarifas activa (una vez más, esta acción puede ser realizada por cualquier persona):

getFeeConfig

¡Eso es todo, tarifas cambiadas! Sin actualizaciones de red, sin despliegues complejos y arriesgados, solo haciendo una simple llamada de contrato y ¡la nueva configuración de tarifas está en su lugar!

Usando NativeMinter

Para el NativeMinter, podemos usar el mismo proceso para conectarnos a la Subnet e interactuar con el precompilado. Podemos cargar la interfaz INativeMinter usando la opción 'load from GitHub' desde la pantalla de inicio de Remix con los siguientes contratos:

Podemos compilarlos e interactuar con el contrato desplegado en la dirección de precompilado 0x0200000000000000000000000000000000000001 utilizada en la Subnet.

Contrato desplegado

El precompilado del minter nativo se utiliza para acuñar monedas nativas a direcciones especificadas. Las monedas acuñadas se agregan a la oferta actual y pueden ser utilizadas por el receptor para pagar las tarifas de gas. Para obtener más información sobre el precompilado del minter nativo, consulte aquí.

El método mintNativeCoin solo puede ser llamado por direcciones habilitadas, de administrador y de gerente. Para esta actualización, hemos agregado tanto una dirección de administrador como una de gerente en upgrade.json arriba. La dirección del gerente estuvo disponible después de las actualizaciones de Durango que ocurrieron el 13 de febrero de 2024. Usaremos la dirección del gerente 0xadfa2910dc148674910c07d18df966a28cd21331 para acuñar monedas nativas.

mintNativeCoin

Cuando llamamos a ese método presionando el botón transact, se publica una nueva transacción en la Subnet, y podemos verla en el explorador:

tx

Como resultado de esta transacción, el precompilado del minter nativo acuñó una nueva moneda nativa (1 WGM) a la dirección del receptor 0xB78cbAa319ffBD899951AA30D4320f5818938310. La página de la dirección en el explorador aquí no muestra ninguna transacción entrante; esto se debe a que el 1 WGM fue acuñado directamente por la EVM misma, sin ningún remitente.

Conclusión

Las actualizaciones de red pueden ser procedimientos complejos y peligrosos de llevar a cabo de manera segura. Nuestros continuos esfuerzos con Subnets son hacer que las actualizaciones sean lo más sencillas y simples posible. Con la poderosa combinación de precompilados estatales y actualizaciones de red a través de archivos de configuración de actualización, hemos logrado simplificar en gran medida tanto las actualizaciones de red como los cambios de parámetros de red. Esto, a su vez, permite una experimentación mucho más segura y muchos nuevos casos de uso que eran demasiado arriesgados y complejos de llevar a cabo con los esfuerzos de alta coordinación requeridos con los mecanismos tradicionales de actualización de red.

Esperamos que este estudio de caso ayude a inspirar ideas para nuevas cosas que puedas probar por ti mismo. ¡Estamos ansiosos por ver qué has construido y cómo las actualizaciones fáciles te ayudan a gestionar tus Subnets! Si tienes alguna pregunta o problema, no dudes en contactarnos en nuestro Discord. ¡O simplemente acércate para contarnos qué cosas emocionantes has construido!

Was this page helpful?