ETH Kipu
  • Ethereum Developer Pack
  • Módulo 1
    • Intro a Smart Contracts
      • Fundamentos de Blockchain
        • Antecedentes
        • Bitcoin
        • Qué es Blockchain
        • Conceptos Clave en Blockchain
        • Cómo funciona la Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • El nuevo Internet
        • Web 3
        • Elementos Fundamentales
        • Impacto de Ethereum en Diversos Sectores
      • Wallets
        • Componentes de una wallet
        • Tipos de Wallet
        • Códigos mnemónicos
      • Ethereum 101
        • Smart Contracts
        • Cuentas
          • Tipos de cuentas
          • Contenido de cuentas
        • Transacciones
          • Componentes
          • Ciclo de vida
        • Gas
        • Solidity
        • EVM
          • La máquina de estados
          • Opcodes
          • Cómo funciona la EVM
          • Clientes de ejecución
          • DApps
      • Blockchain Explorer
        • Funciones de un blockchain explorer
        • Beneficios de utilizar un blockchain explorer
      • Remix
        • Características de Remix
        • Workspaces o espacios de trabajo
        • Cargar y compilar un contrato
        • Desplegar en la máquina virtual de Remix (Remix VM)
        • Interactuando con funciones
        • Desplegar en una red pública
      • Crea tu primer Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Datos
      • Funciones
      • Variables
        • Ejercicio 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Ejercicio 3
      • Convenciones de nomenclatura
      • Tipos de almacenamiento para variables
      • Estructuras de Control
        • Ejercicio 4
      • Modificadores
      • Eventos
        • Ejercicio 5
      • Tipos de Referencia
        • Arrays
          • Ejercicio 6
        • Mappings
          • Ejercicio 7
        • Structs
          • Ejercicio 8
      • Address Payable
      • Cómo reciben Ether los contratos y funciones
      • Transferencias de Ether
      • Conceptos Avanzados
        • Codificación ABI
        • Hashing
        • This
        • Herencia
        • Abstract
        • Interface
        • Llamadas entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • Estándares, Librerías y Patrones
      • Buenas Prácticas de Diseño
      • Patrones de Diseño
      • EIP y ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crea un Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Toolkit para desarrollo en Ethereum
      • Requisitos para el módulo 4
        • Terminal
        • Git y Github
        • Node.js y npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Ejercicio
        • Hardhat
          • Despliegue de un contrato en Hardhat
          • Despliegue de un contrato en una red pública
        • Scaffold-ETH
          • Características
          • Cómo instalar Scaffold-ETH
  • Módulo 5
    • Seguridad, Pruebas y Auditoría
      • Pruebas
        • Importancia de realizar pruebas
        • Métodos para probar contratos inteligentes
          • Pruebas automatizadas
          • Pruebas manuales
        • Conceptos importantes en testing
        • Herramientas para testing
        • Testing con Hardhat
        • Recursos adicionales
      • Seguridad
        • Una mentalidad distinta de diseño
        • Principales vulnerabilidades en smart contracts
          • Reentrancy attack (ataque de reentrada)
          • Replay attack (ataque de repetición)
          • Price Oracle Manipulation (Manipulación de Oráculos de Precios)
          • Missing Access Control (Pérdida de Control de Acceso)
          • Reward Manipulation (Manipulación de Recompensas)
          • Failure to Initialize (Falla al Inicializar)
          • Front-running
          • Invariant Breaks (Ruptura de invariantes)
          • Mishandling of ETH (Mal manejo de ETH)
          • Denial of Service (DoS - Denegación de Servicio)
          • Integer overflow and underflow (desbordamiento y subdesbordamiento de enteros)
          • Phishing y Typosquatting
        • Recursos adicionales
      • Auditoría de smart contracts
        • Proceso de Auditoría
        • Herramientas
        • Cómo prepararse para una auditoría
        • El test Rekt
        • Retos
        • Recursos adicionales
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page

Was this helpful?

  1. Módulo 2
  2. Fundamentos de Solidity
  3. Conceptos Avanzados

ABI

El Application Binary Interface (ABI) en Ethereum es un estándar crucial para interactuar con los contratos inteligentes en la blockchain de Ethereum. Es esencialmente un formato de interfaz que permite a los contratos inteligentes comunicarse con aplicaciones externas y con otros contratos en la blockchain. El ABI define cómo se pueden llamar las funciones de un contrato inteligente, incluidos los parámetros que se requieren y los tipos de datos de retorno, lo que facilita la interacción entre el código binario de bajo nivel que se ejecuta en la Ethereum Virtual Machine (EVM) y el código de alto nivel escrito por desarrolladores y usuarios.

Características principales del ABI

  1. Definición de funciones: El ABI especifica las funciones del contrato inteligente, incluyendo nombres, tipos de parámetros de entrada y salida, y si son funciones de vista o funciones que alteran el estado en la blockchain.

  2. Codificación de datos: Proporciona reglas para la codificación (transformación de datos de alto nivel a su representación binaria) y decodificación (el proceso inverso) de los argumentos de las funciones y los valores devueltos. Esto asegura que las llamadas a funciones y las transacciones puedan ser correctamente interpretadas por los contratos inteligentes.

  3. Eventos: El ABI también define eventos que los contratos inteligentes pueden emitir. Estos eventos permiten que las aplicaciones externas reciban notificaciones sobre cambios o acciones específicas que ocurren dentro de los contratos inteligentes.

A continuación, veamos un ejemplo de un ABI de ejemplo para un contrato inteligente. Imagina que este contrato inteligente tiene como propósito gestionar una lista simple de tareas, permitiendo a los usuarios añadir tareas y marcarlas como completadas. El contrato podría incluir funciones como addTask, que añade una nueva tarea, y markTaskCompleted, que marca una tarea como completada.

El código Solidity del contrato podría verse algo así:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract TodoList {
    struct Task {
        string description;
        bool isCompleted;
    }

    Task[] public tasks;

    function addTask(string memory _description) public {
        tasks.push(Task(_description, false));
    }

    function markTaskCompleted(uint _taskId) public {
        tasks[_taskId].isCompleted = true;
    }

    function getTask(uint _taskId) public view returns (string memory, bool) {
        Task storage task = tasks[_taskId];
        return (task.description, task.isCompleted);
    }
}

Para este contrato, un ABI de ejemplo que describa las funciones disponibles podría verse así:

[
    {
        "inputs": [
            {
                "internalType": "string",
                "name": "_description",
                "type": "string"
            }
        ],
        "name": "addTask",
        "outputs": [],
        "stateMutability": "nonpayable",
        "type": "function"
    },
    {
        "inputs": [
            {
                "internalType": "uint256",
                "name": "_taskId",
                "type": "uint256"
            }
        ],
        "name": "markTaskCompleted",
        "outputs": [],
        "stateMutability": "nonpayable",
        "type": "function"
    },
    {
        "inputs": [
            {
                "internalType": "uint256",
                "name": "_taskId",
                "type": "uint256"
            }
        ],
        "name": "getTask",
        "outputs": [
            {
                "internalType": "string",
                "name": "",
                "type": "string"
            },
            {
                "internalType": "bool",
                "name": "",
                "type": "bool"
            }
        ],
        "stateMutability": "view",
        "type": "function"
    }
]

Este ABI describe las tres funciones del contrato TodoList, incluyendo los tipos de los parámetros de entrada y salida. La propiedad stateMutability indica si la llamada a la función modifica el estado del contrato (nonpayable para addTask y markTaskCompleted, que no aceptan ETH pero modifican el estado) o simplemente lee datos (view para getTask, que no modifica el estado del contrato).

Este ABI permite a las aplicaciones cliente saber cómo interactuar con el contrato inteligente, invocando sus funciones y leyendo sus respuestas. Al integrar este ABI en una aplicación (por ejemplo, usando Web3.js o ethers.js), los desarrolladores pueden realizar llamadas a funciones del contrato de manera sencilla, pasando los argumentos necesarios y procesando los valores devueltos.

Uso del ABI

Para interactuar con un contrato inteligente, una aplicación externa necesita conocer su ABI. Este requisito se debe a que el código de los contratos inteligentes se compila en bytecode antes de ser desplegado en la blockchain, y el bytecode por sí solo no es suficiente para determinar cómo interactuar con el contrato de manera efectiva.

Cuando un desarrollador utiliza herramientas como Remix o Hardhat para compilar y desplegar contratos inteligentes, estas herramientas generan automáticamente el ABI basándose en el código fuente del contrato. Luego, el desarrollador puede integrar este ABI en aplicaciones cliente (por ejemplo, una aplicación web que interactúa con el contrato) para facilitar la comunicación.

Ejemplo de Uso del ABI

Imagina que tienes un contrato inteligente en Solidity que incluye una función para obtener el nombre de un usuario. Para llamar a esta función desde una aplicación web, necesitarías el ABI del contrato. Con el ABI, puedes utilizar una librería de Ethereum como web3.js o ethers.js para crear una instancia del contrato en tu aplicación y hacer llamadas a sus funciones como si fueran funciones JavaScript.

const contractABI = /* ABI del contrato inteligente aquí */;
const contractAddress = '0x...'; // La dirección del contrato desplegado
const web3 = new Web3('<http://localhost:8545>');
const myContract = new web3.eth.Contract(contractABI, contractAddress);

// Llamando a una función del contrato
myContract.methods.nombreDeLaFuncion().call()
    .then(result => {
        console.log(result);
    });
PreviousEVMNextBytecode

Last updated 8 months ago

Was this helpful?