Este proyecto utiliza Protostar como marco de desarrollo. Para comenzar con Protostar, siga las guías contenidas en los documentos oficiales.
Una vez instalado y clonado este repositorio no hará falta iniciar el proyecto con protostar
, nos dirijimos directamente al archivo protostar.toml
para revisar su información. Como ven estan añadidos todos los contratos y la configuración de testnet2
para el deploy, así que nos han dejado el trabajo para hacer los MINIMOS esfuerzos Min-Starknet
, así que intentaré seguir en esa línea para esta guía.
En esta nueva version de protostar 0.9.1
tendremos que crear un perfil que añadirermos en protostar.toml en el que defineremos el usuario de cuenta que pagará el fee. Usaremos los ajustes PARA TESTNET
aunque también estan preparados para TESTNET2
. La cuenta de ArgentX para la guía será 0x03F878C94De81906ba1A016aB0E228D361753536681a776ddA29674FfeBB3CB0
(EN SU CASO AÑADIR LA VUESTRA) para el deploy del Ens.cairo. Tendremos que exportar nuestra PRIVATE KEY
de esa cuenta de ArgentX. En la versión 0.9.0 protostar
teniamos que pasarlo a hexa
usando Stark-utils.
Recordar que tenemos OPCIONES A - B
para TESTNET o TESNET2 y no usar ni compartir ninguna PRIVATE KEY NUNCA, todo ello es provisional hasta la versión de CAIRO 1.0
. Al reiniciar el pc o terminal tendrá que volver a exportar la clave.
En la versión 0.9.0 protostar
teniamos que pasarlo a hexa
usando Stark-utils. En la 0.9.1
pasaremos nuestra private key directamente para exportarla, usando el siguiente comando. (SUSITITUIR 0x1234 por vuestro hexa).
export PROTOSTAR_ACCOUNT_PRIVATE_KEY=0x1234
Otra opción es este método, añadimos en un archivo .env
nuestra private key. También tendremos que ajustar el protostar.toml para indicar la ruta de nuestra Private Key, aunque prefiero esta opción. Nunca mostrar tu clave privada. Nunca subir a Git tu archivo .env
.
Si queremos realizar el deploy de nuestro contrato en la testnet 2, debemos seguir los mismos pasos que en la testnet. La única diferencia es que necesitaremos utilizar una wallet que esté en la testnet 2 y agregar un perfil específico al archivo de configuración de Protostar. Además, cuando ejecutemos los comandos de Protostar, debemos utilizar el parámetro -p testnet2
en lugar de -p testnet
para que la configuración se aplique a la testnet 2. Con estos pasos, podremos realizar el deploy de nuestro contrato en la testnet 2 de manera efectiva.
Ahora para compilar Ens
y el resto de contratos sólo deberemos pasar el siguiente comando y obtendremos también cada uno de sus Class Hash
.
protostar build
Ahora nos quedaremos con el class hash del ens
para hacer el deploy
. En el caso del declare
la mayoría ya los tenían realizados creados por otros usuarios, igualmente los declare
para esta guía. También comprobaremos que todo este bien, así que pasaremos el comando.
protostar -p testnet declare ./build/ens.json --max-fee auto
Usaremos por comodidad para el Min-Starknet
el contrato Universal para los deploy UDC. En este caso pasaremos sólo con añadir en calldata_len = 1
sera suficiente, podemos dejar en calldata = 0
.
De la cuenta de ArgentX y el nombre de NadaiEns
pasado a felt con Stark-utils y usaremos nuestro contrato recién deployado ens y pasaremos a escribir store_name
que hemos obtenido en felt
antes, así probaremos si se guarda con nuestra cuenta el dominio.
Y podemos verificar pasando en get_name
la cuenta con la que hemos creado NadaiEns
y verificar que todo ha sido guardado y realizado con exito.
Como tarea extra podemos dejar verificado nuestro contrato en Starkscan
, para ello debemos de tener instalada y guardado el contrato que acabamos de hacer el Deploy
. Ejecutamos el siguiente comando, escogemos el ens.cairo
y vamos siguiendo los pasos.
starkscan