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 5
  2. Seguridad, Pruebas y Auditoría
  3. Seguridad

Una mentalidad distinta de diseño

El desarrollo de aplicaciones en un entorno blockchain tiene sus particularidades, como por ejemplo el hecho de que el costo de fallar es muy caro. En tal sentido, se parece más a la construcción de hardware que al desarrollo de software.

Se requiere una mentalidad de diseño particular, que implica tener en cuenta los siguientes principios:

Prepárate para que ocurran fallas: Tú código debe estar preparado para responder a escenarios de errores y vulnerabilidades, manejandolos adecuadamente.

  • Tener un “rompe-circuitos” que pause el contrato cuando las cosas se ponen mal.

  • Gestionar la cantidad de dinero en riesgo, limitando por ejemplo el número de transacciones que se hacen desde una misma dirección IP en un tiempo determinado (rate limiting).

  • Tener una ruta de upgrades para corregir errores e implementar mejoras.

Mantente actualizado: Conoce los avances más recientes en seguridad.

  • Tan pronto se identifica una nueva vulnerabilidad revisa tus contratos.

  • Actualiza Upgrade to the latest version of any tool or library as soon as possible

  • Adopta técnicas de seguridad que sean útiles.

Keep it simple: La complejidad aumenta la probabilidad de errores.

  • Asegura que la lógica de tus contratos sea simple.

  • Modulariza tu código para que los contratos y funciones sean pequeños.

  • Usa librerías que haya soportado el paso del tiempo.

  • Elige claridad sobre desempeño siempre que sea posible.

  • Usa blockchain sólo para los componentes donde tenga sentido la descentralización.

Pon a prueba tu código: Siempre es mejor detectar errores tempranamente.

  • Prueba tus contratos de forma exhaustiva y añade nuevas pruebas si aparecen nuevos vectores de ataque.

  • Si está entre tus posibilidades convoca bug bounties.

  • Haz un despliegue en fases, incrementado las pruebas y la actividad en cada pase.

Ten en cuenta las características de blockchain: Ethereum tiene sus particularidades y no hay que olvidarlas.

  • Ten sumo cuidado con las llamadas a contratos externos, ya que podrían ejecutar código malicioso y alterar el flujo de control.

  • Recuerda que tus funciones públicas son accesibles para todos y pueden ser llamadas de forma maliciosa y en cualquier orden. Además, los datos privados en los contratos inteligentes son visibles para cualquiera.

  • Ten en cuenta los costos de gas y el límite de gas por bloque.

  • La aleatoriedad no es algo resuelto en blockchain; la mayoría de los enfoques para la generación de números aleatorios son manipulables.

PreviousSeguridadNextPrincipales vulnerabilidades en smart contracts

Last updated 8 months ago

Was this helpful?