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 1
  2. Intro a Smart Contracts
  3. Fundamentos de Blockchain

Antecedentes

PreviousFundamentos de BlockchainNextBitcoin

Last updated 8 months ago

Was this helpful?

La historia de la blockchain es la de una tecnología que ha evolucionado y se ha utilizado en una variedad de aplicaciones más allá de las criptomonedas. Aunque el , publicado en 2008 por una persona o grupo de personas bajo el seudónimo de Satoshi Nakamoto, se considera el origen de la tecnología blockchain, en realidad es el resultado de la combinación de varias tecnologías previas, como la criptografía de clave pública y la teoría de juegos.

Antes de la blockchain, se hicieron intentos para crear monedas digitales, pero sin éxito.

A continuación algunas de las tecnologías que posibilitaron el surgimiento del concepto de blockchain:

  • 1979 - Merkle Tree : Ralph Merkle propuso una estructura de datos criptográfica llamada "Merkle Tree" o "Árbol de Merkle", que permite la verificación eficiente de grandes cantidades de datos. El árbol de Merkle divide los datos en bloques y los organiza en una estructura de árbol, donde cada bloque está vinculado a su bloque padre a través de una función de hash criptográfico.

  • 1989 - DigiCash : El sistema de DigiCash utilizaba una moneda digital llamada "eCash" que se podía comprar en un banco y luego usar para hacer pagos en línea. , se considera una de las primeras empresas en desarrollar una criptomoneda y sentó las bases para el desarrollo posterior de la tecnología blockchain y las criptomonedas como Bitcoin.

  • 1992 - Control de modificación de documentos digitales: Haber y Stornetta propusieron la marca temporal de documentos digitales en merkle trees. Publicaron proponiendo un sistema para asegurar que los bloques no sean modificables y puedan ser encadenados criptográficamente.

  • 1997 - Hashcash : que utiliza una función hash criptográfica para crear un token que prueba que se ha realizado un cierto esfuerzo computacional. Utilizado principalmente para combatir el spam en el correo electrónico.

  • 1998 - B-Money y Bit Gold : Fueron dos propuestas de criptomonedas previas a Bitcoin, con enfoques en la privacidad y la distribución justa () y en la criptografía y como moneda de respaldo (oro digital) de otras criptomonedas (). Wei Dai, creador de B-Money propuso que cada nodo participante en la red guarde una copia completa del registro de transacciones realizadas. Por otro lado, fue el famoso Nick Zsabo quien estuvo detrás de la creación de Bit Gold.

  • 1999 - P2P : Shawn Fanning creó una aplicación llamada "Napster" que permitía a los usuarios compartir archivos de música entre sí de forma descentralizada, sin necesidad de un servidor centralizado. Esto fue posible gracias a la tecnología P2P o "peer-to-peer", que permitía a los usuarios conectarse directamente entre sí y compartir archivos.

  • 2004 - RPoW : Hal Finney crea Reusable Proof of Work , una criptomoneda basada en la prueba de trabajo que utiliza tokens que se pueden reutilizar en lugar de generar nuevos tokens.

  • 2008 - Bitcoin : Una persona o grupo de personas que se hace llamar Satoshi Nakamoto publicó un documento titulado "Bitcoin: A Peer-to-Peer Electronic Cash System", que describía una nueva criptomoneda basada en la tecnología blockchain.

whitepaper de Bitcoin
Aunque DigiCash no tuvo éxito comercialmente
papers
Una tecnología de prueba de trabajo
B-Money
Bit Gold
(RPoW)