CursosEmpresasBlogLiveConfPrecios

Desplegando contrato en testnet con dev-accounts

Clase 21 de 24 • Curso de Desarrollo en NEAR Blockchain con Rust

Clase anteriorSiguiente clase

Contenido del curso

Introducción a NEAR

  • 1
    Bienvenida al desarrollo con NEAR

    Bienvenida al desarrollo con NEAR

    01:58 min
  • 2
    ¿Por qué NEAR?

    ¿Por qué NEAR?

    03:56 min
  • 3
    De la web2 a la web3 con NEAR

    De la web2 a la web3 con NEAR

    03:27 min
  • 4
    ¿Qué es una cuenta en NEAR?

    ¿Qué es una cuenta en NEAR?

    06:14 min
  • 5
    Access keys

    Access keys

    04:46 min
  • 6
    Conozcamos la NEAR Wallet

    Conozcamos la NEAR Wallet

    16:14 min
  • 7
    Data Storage y Storage Staking

    Data Storage y Storage Staking

    06:43 min

Gestión de contratos en NEAR

  • 8
    Métodos view y change

    Métodos view y change

    03:51 min
  • 9
    Gas

    Gas

    07:17 min
  • 10
    Redes en NEAR

    Redes en NEAR

    05:22 min
  • 11
    Runtime, transacciones y ciclo de una transacción

    Runtime, transacciones y ciclo de una transacción

    06:00 min

Ambiente de desarrollo en Rust para NEAR

  • 12
    Montar ambiente de WebAssembly en Rust

    Montar ambiente de WebAssembly en Rust

    05:48 min
  • 13
    Explorando la NEAR CLI

    Explorando la NEAR CLI

    11:55 min
  • 14
    Un vistazo al NEAR Explorer

    Un vistazo al NEAR Explorer

    09:58 min

Desarrollo en NEAR con Rust

  • 15
    Desplegar y testear el proyecto del curso

    Desplegar y testear el proyecto del curso

    05:58 min
  • 16
    Estructura de un contrato inteligente

    Estructura de un contrato inteligente

    08:20 min
  • 17
    Colecciones de datos en NEAR

    Colecciones de datos en NEAR

    08:00 min
  • 18
    Módulo env de NEAR

    Módulo env de NEAR

    05:25 min
  • 19
    Mutabilidad de un contrato

    Mutabilidad de un contrato

    16:12 min
  • 20
    Métodos payables y promises

    Métodos payables y promises

    17:44 min

Desplegando el contrato

  • 21
    Desplegando contrato en testnet con dev-accounts

    Desplegando contrato en testnet con dev-accounts

    Viendo ahora
  • 22
    Invocando al contrato con el NEAR CLI

    Invocando al contrato con el NEAR CLI

    13:22 min

Ve mas allá

  • 23
    Aurora la EVM de NEAR

    Aurora la EVM de NEAR

    08:31 min
  • 24
    Conclusión

    Conclusión

    01:10 min
  • Tomar el examen del curso
    • Fernando Piñango

      Fernando Piñango

      student•
      hace 3 años

      si al hacer el comando

      cargo build --target wasm32-unknown-unknown --release

      no se les genera el archivo .wasm

      sino solo archivos .d y .rlib

      intenten esto:

      primero el comando solito: cargo build

      luego el comando completo con el target: cargo build --target wasm32-unknown-unknown --release

      Nicolás Montanari

      Nicolás Montanari

      student•
      hace 2 años

      No compila, el compilador me dice "no matching pakage named 'parity-secp256k1' found". Estoy buscando soluciones. A alguien mas le pasó?

        Yilson Contreras

        Yilson Contreras

        student•
        hace un año

        yo probé usando estas dependencias

        [dependencies]near-sdk = "5.4" [dev-dependencies]near-sdk = { version = "5.5", features = ["unit-testing"] }near-workspaces = { version = "0.14.1", features = ["unstable"] }tokio = { version = "1.12.0", features = ["full"] }serde_json = "1"

      Eber Laurente Lliuyacc

      Eber Laurente Lliuyacc

      student•
      hace 3 años

      Profesor, después de la compilación no se genera el archivo .wasm. Se genera le .d y .rlib, pero no el .wasm

      Uso las siguientes dependencias

      [lib] create-type = ["cdylib", "rlib"] [dependencies] near-sdk = "4.0.0" ``` Código: ``` use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; use near_sdk::collections::UnorderedMap; use near_sdk::serde::{Deserialize, Serialize}; use near_sdk::{near_bindgen, env, Promise, AccountId}; // near_sdk::setup_alloc!(); /**************** Estructura de Meme **************** Implementamos serde cuando necesitamos retornar la estructura serializada a JSON, util en NEAR, CLI y frontend. En este caso se utiliza ambas serializaciones (JSON y Borsh), usamos Borsh en la serialización de la blockchain de NEAR */ #[derive(Serialize, Deserialize, BorshSerialize, BorshDeserialize)] #[serde(crate = "near_sdk::serde")] pub struct Meme{ pub id: u64, pub creado_por: AccountId, pub titulo: String, pub museo: String, pub url: String, pub donaciones: u128, } // Implementación del trait default para inicializar la estructura de Meme impl Default for Meme { fn default() -> Self { Meme { id: 0, creado_por: "".parse().unwrap(),//String::from(""), titulo: String::from(""), museo: String::from(""), url: String::from(""), donaciones: 0, } } } // Implementación del metodo new que permite crear nuevos memes impl Meme { pub fn new(titulo: String, url: String, museo: String) -> Self { Self { // id y creado_por necesitan ser obtenidos desde la blockchain // id: 0, // creado_por: String::from(""), id: env::block_height(), creado_por: env::signer_account_id(), titulo, museo, url, donaciones: 0, } } } // State del contrato e inicialización de los valores por defacult #[near_bindgen] #[derive(BorshDeserialize, BorshSerialize)] pub struct SimpleMemeMuseum{ // Guardamos solo los ID para evitar editar en ambos lados museos: UnorderedMap<String, Vec<u64>>, memes: UnorderedMap<u64, Meme>, } // Inicialización de state del contrato impl Default for SimpleMemeMuseum { fn default() -> Self { Self { museos: UnorderedMap::new(b"u".to_vec()), memes: UnorderedMap::new(b"e".to_vec()) } } } #[near_bindgen] impl SimpleMemeMuseum { pub fn crear_meme(&mut self, titulo: String, url: String, nombre_museo: String){ let meme = Meme::new( String::from(&titulo), String::from(&url), String::from(&nombre_museo), ); //guardamos en una coleccion de memes self.memes.insert(&meme.id,&meme); //buscamos si el museo existe para despues añadir el meme en este. let museo = self.museos.get(&nombre_museo); if museo.is_some(){ //m almacena el valor de some() del option<> o panic let mut m = museo.unwrap(); m.push(meme.id); //insertamos en la colección de museos el museo y meme ligado a este self.museos.insert(&nombre_museo, &m); } else { let mut nuevo_museo = Vec::new(); nuevo_museo.push(meme.id); self.museos.insert(&nombre_museo, &nuevo_museo); } //manda un mensaje a la terminal al ejecutar el método env::log_str( format!( "Nuevo meme añadido con éxito. Museo: {}, Id Meme: {}", &nombre_museo, meme.id ) .as_ref(), ); } pub fn obtener_meme(&self, id: u64) -> Option<Meme>{ self.memes.get(&id) } pub fn obtener_lista_memes(&self) -> Vec<(u64, Meme)> { self.memes.to_vec() } pub fn obtener_lista_museos(&self) -> Vec<String> { self.museos.keys_as_vector().to_vec() } pub fn obtener_memes_museo(&self, nombre_museo: String) -> Vec<Meme> { let museo = self.museos.get(&nombre_museo); if museo.is_some(){ let mut lista_memes = Vec::new(); for meme_id in &museo.unwrap() { let meme = self.memes.get(meme_id); if meme.is_some() { lista_memes.push(meme.unwrap()); } } return lista_memes; }else{ // env::log_str("No existe el museo ingresado").as_bytes(); return Vec::new(); } } #[payable] pub fn donar_a_meme(&mut self, id: u64) -> bool { assert!( env::attached_deposit() > 0, "Debes de agregar NEAR para hacer una donación" ); //buscamos meme match self.memes.get(&id) { Some(mut meme) => { //si existe guardamos la donación en el registro meme.donaciones += env::attached_deposit(); self.memes.insert(&meme.id, &meme); //Y transferimos la donación al creador del meme Promise::new(meme.creado_por) .transfer(env::attached_deposit()); true } None => false, } } } ```
        Juan David Díaz Pastrana

        Juan David Díaz Pastrana

        student•
        hace 3 años

        Eso puede ocurrir al no ponerle el target a cargo

        Fernando Piñango

        Fernando Piñango

        student•
        hace 3 años

        me pasa lo mismo,

        cargo build --target wasm32-unknown-unknown --release

        alguna solucion?

      Edward Rodriguez

      Edward Rodriguez

      student•
      hace 2 años

      Para el problema del balance al momento de hacer el deploy, pueden usar un faucet:

      https://jelilat.github.io/near-faucet/

    Escuelas

    • Desarrollo Web
      • Fundamentos del Desarrollo Web Profesional
      • Diseño y Desarrollo Frontend
      • Desarrollo Frontend con JavaScript
      • Desarrollo Frontend con Vue.js
      • Desarrollo Frontend con Angular
      • Desarrollo Frontend con React.js
      • Desarrollo Backend con Node.js
      • Desarrollo Backend con Python
      • Desarrollo Backend con Java
      • Desarrollo Backend con PHP
      • Desarrollo Backend con Ruby
      • Bases de Datos para Web
      • Seguridad Web & API
      • Testing Automatizado y QA para Web
      • Arquitecturas Web Modernas y Escalabilidad
      • DevOps y Cloud para Desarrolladores Web
    • English Academy
      • Inglés Básico A1
      • Inglés Básico A2
      • Inglés Intermedio B1
      • Inglés Intermedio Alto B2
      • Inglés Avanzado C1
      • Inglés para Propósitos Específicos
      • Inglés de Negocios
    • Marketing Digital
      • Fundamentos de Marketing Digital
      • Marketing de Contenidos y Redacción Persuasiva
      • SEO y Posicionamiento Web
      • Social Media Marketing y Community Management
      • Publicidad Digital y Paid Media
      • Analítica Digital y Optimización (CRO)
      • Estrategia de Marketing y Growth
      • Marketing de Marca y Comunicación Estratégica
      • Marketing para E-commerce
      • Marketing B2B
      • Inteligencia Artificial Aplicada al Marketing
      • Automatización del Marketing
      • Marca Personal y Marketing Freelance
      • Ventas y Experiencia del Cliente
      • Creación de Contenido para Redes Sociales
    • Inteligencia Artificial y Data Science
      • Fundamentos de Data Science y AI
      • Análisis y Visualización de Datos
      • Machine Learning y Deep Learning
      • Data Engineer
      • Inteligencia Artificial para la Productividad
      • Desarrollo de Aplicaciones con IA
      • AI Software Engineer
    • Ciberseguridad
      • Fundamentos de Ciberseguridad
      • Hacking Ético y Pentesting (Red Team)
      • Análisis de Malware e Ingeniería Forense
      • Seguridad Defensiva y Cumplimiento (Blue Team)
      • Ciberseguridad Estratégica
    • Liderazgo y Habilidades Blandas
      • Fundamentos de Habilidades Profesionales
      • Liderazgo y Gestión de Equipos
      • Comunicación Avanzada y Oratoria
      • Negociación y Resolución de Conflictos
      • Inteligencia Emocional y Autogestión
      • Productividad y Herramientas Digitales
      • Gestión de Proyectos y Metodologías Ágiles
      • Desarrollo de Carrera y Marca Personal
      • Diversidad, Inclusión y Entorno Laboral Saludable
      • Filosofía y Estrategia para Líderes
    • Diseño de Producto y UX
      • Fundamentos de Diseño UX/UI
      • Investigación de Usuarios (UX Research)
      • Arquitectura de Información y Usabilidad
      • Diseño de Interfaces y Prototipado (UI Design)
      • Sistemas de Diseño y DesignOps
      • Redacción UX (UX Writing)
      • Creatividad e Innovación en Diseño
      • Diseño Accesible e Inclusivo
      • Diseño Asistido por Inteligencia Artificial
      • Gestión de Producto y Liderazgo en Diseño
      • Diseño de Interacciones Emergentes (VUI/VR)
      • Desarrollo Web para Diseñadores
      • Diseño y Prototipado No-Code
    • Contenido Audiovisual
      • Fundamentos de Producción Audiovisual
      • Producción de Video para Plataformas Digitales
      • Producción de Audio y Podcast
      • Fotografía y Diseño Gráfico para Contenido Digital
      • Motion Graphics y Animación
      • Contenido Interactivo y Realidad Aumentada
      • Estrategia, Marketing y Monetización de Contenidos
    • Desarrollo Móvil
      • Fundamentos de Desarrollo Móvil
      • Desarrollo Nativo Android con Kotlin
      • Desarrollo Nativo iOS con Swift
      • Desarrollo Multiplataforma con React Native
      • Desarrollo Multiplataforma con Flutter
      • Arquitectura y Patrones de Diseño Móvil
      • Integración de APIs y Persistencia Móvil
      • Testing y Despliegue en Móvil
      • Diseño UX/UI para Móviles
    • Diseño Gráfico y Arte Digital
      • Fundamentos del Diseño Gráfico y Digital
      • Diseño de Identidad Visual y Branding
      • Ilustración Digital y Arte Conceptual
      • Diseño Editorial y de Empaques
      • Motion Graphics y Animación 3D
      • Diseño Gráfico Asistido por Inteligencia Artificial
      • Creatividad e Innovación en Diseño
    • Programación
      • Fundamentos de Programación e Ingeniería de Software
      • Herramientas de IA para el trabajo
      • Matemáticas para Programación
      • Programación con Python
      • Programación con JavaScript
      • Programación con TypeScript
      • Programación Orientada a Objetos con Java
      • Desarrollo con C# y .NET
      • Programación con PHP
      • Programación con Go y Rust
      • Programación Móvil con Swift y Kotlin
      • Programación con C y C++
      • Administración Básica de Servidores Linux
    • Negocios
      • Fundamentos de Negocios y Emprendimiento
      • Estrategia y Crecimiento Empresarial
      • Finanzas Personales y Corporativas
      • Inversión en Mercados Financieros
      • Ventas, CRM y Experiencia del Cliente
      • Operaciones, Logística y E-commerce
      • Gestión de Proyectos y Metodologías Ágiles
      • Aspectos Legales y Cumplimiento
      • Habilidades Directivas y Crecimiento Profesional
      • Diversidad e Inclusión en el Entorno Laboral
      • Herramientas Digitales y Automatización para Negocios
    • Blockchain y Web3
      • Fundamentos de Blockchain y Web3
      • Desarrollo de Smart Contracts y dApps
      • Finanzas Descentralizadas (DeFi)
      • NFTs y Economía de Creadores
      • Seguridad Blockchain
      • Ecosistemas Blockchain Alternativos (No-EVM)
      • Producto, Marketing y Legal en Web3
    • Recursos Humanos
      • Fundamentos y Cultura Organizacional en RRHH
      • Atracción y Selección de Talento
      • Cultura y Employee Experience
      • Gestión y Desarrollo de Talento
      • Desarrollo y Evaluación de Liderazgo
      • Diversidad, Equidad e Inclusión
      • AI y Automatización en Recursos Humanos
      • Tecnología y Automatización en RRHH
    • Finanzas e Inversiones
      • Fundamentos de Finanzas Personales y Corporativas
      • Análisis y Valoración Financiera
      • Inversión y Mercados de Capitales
      • Finanzas Descentralizadas (DeFi) y Criptoactivos
      • Finanzas y Estrategia para Startups
      • Inteligencia Artificial Aplicada a Finanzas
      • Domina Excel
      • Financial Analyst
      • Conseguir trabajo en Finanzas e Inversiones
    • Startups
      • Fundamentos y Validación de Ideas
      • Estrategia de Negocio y Product-Market Fit
      • Desarrollo de Producto y Operaciones Lean
      • Finanzas, Legal y Fundraising
      • Marketing, Ventas y Growth para Startups
      • Cultura, Talento y Liderazgo
      • Finanzas y Operaciones en Ecommerce
      • Startups Web3 y Blockchain
      • Startups con Impacto Social
      • Expansión y Ecosistema Startup
    • Cloud Computing y DevOps
      • Fundamentos de Cloud y DevOps
      • Administración de Servidores Linux
      • Contenerización y Orquestación
      • Infraestructura como Código (IaC) y CI/CD
      • Amazon Web Services
      • Microsoft Azure
      • Serverless y Observabilidad
      • Certificaciones Cloud (Preparación)
      • Plataforma Cloud GCP

    Platzi y comunidad

    • Platzi Business
    • Live Classes
    • Lanzamientos
    • Executive Program
    • Trabaja con nosotros
    • Podcast

    Recursos

    • Manual de Marca

    Soporte

    • Preguntas Frecuentes
    • Contáctanos

    Legal

    • Términos y Condiciones
    • Privacidad
    • Tyc promociones
    Reconocimientos
    Reconocimientos
    Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
    Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
    Logo reconocimientoPrimera Startup EdTech · 2018
    Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
    Logo reconocimientoCEO Mejor Emprendedor del año · 2024
    De LATAM conpara el mundo
    YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads