🇧🇷
Ethereum Developer Pack - PT
  • Ethereum Developer Pack - PT
  • Módulo 1
    • Introdução a Smart Contracts
      • Fundamentos de Blockchain
        • Histórico
        • Bitcoin
        • O que é Blockchain
        • Conceitos-chave em Blockchain
        • Como funciona a Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • A nova Internet
        • Web 3
        • Elementos Fundamentais
        • Impacto do Ethereum em Diversos Setores
      • Wallets
        • Componentes de uma wallet
        • Tipos de Wallet
        • Códigos Mnemônicos
      • Ethereum 101
        • Smart Contracts
        • Contas
          • Tipos de contas
          • Conteúdo das contas
        • Transações
          • Componentes
          • Ciclo de vida
        • Gás
        • Solidity
        • EVM
          • A máquina de estados
          • Opcodes
          • Como funciona a EVM
          • Clientes de execução
          • DApps
      • Blockchain Explorer
        • Funções de um blockchain explorer
        • Beneficios de utilizar um blockchain explorer
      • Remix
        • Características do Remix
        • Workspaces ou espaços de trabalho
        • Carregar e compilar um contrato
        • Implantar na máquina virtual do Remix (Remix VM)
        • Interagindo com funções
        • Deployar em uma rede pública
      • Crie seu primeiro Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Dados
      • Funções
      • Variáveis
        • Exercício 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Exercício 3
      • Convenções de nomenclatura
      • Tipos de armazenamento para variáveis
      • Estruturas de Controle
        • Exercício 4
      • Modificadores
      • Eventos
        • Exercício 5
      • Tipos de Referencia
        • Arrays
          • Exercício 6
        • Mappings
          • Exercício 7
        • Structs
          • Exercício 8
      • Address Payable
      • Como os contratos e funções recebem Ether.
      • Transferências de Ether
      • Conceitos Avançados
        • Codificação de ABI
        • Hashing
        • This
        • Herança
        • Abstract
        • Interface
        • Chamada entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • ERCs, Bibliotecas e Padrões de Desenvolvimento
      • Boas Práticas de Desenvolvimento
      • Padrões de Desenvolvimento
      • EIP & ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crie um Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Kit de ferramentas para desenvolvimento na Ethereum
      • Requisitos para o módulo 4
        • Terminal
        • Git e Github
        • Node.js e npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Exercício
        • Hardhat
          • Implantação de um contrato no Hardhat
          • Implantação de um contrato em uma rede pública
        • Scaffold-ETH
          • Características do Scaffold-ETHCaracterísticas
          • Como instalar o Scaffold-ETH
  • Módulo 5
    • Segurança, Testes e Auditorias
      • Testes
        • Importância de realizar testes
        • Métodos para testar contratos inteligentes
          • Testes automatizados
          • Testes manuais
        • Conceitos importantes em testes
        • Ferramentas para testes
        • Testes com Hardhat
        • Recursos adicionais
      • Segurança
        • Uma mentalidade diferente de design
        • Principais vulnerabilidades em contratos inteligentes
          • 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 (Quebra de Invariantes)
          • Mishandling of ETH (Má gestão de ETH)
          • Denial of Service (DoS - Negação de Serviço)
          • Integer overflow and underflow (Overflow e Underflow de inteiros)
          • Phishing y Typosquatting
        • Recursos adicionais
      • Auditoria de smart contracts
        • Processo de Auditoria
        • Ferramentas
        • Como se preparar para uma auditoria
        • O teste Rekt
        • Desafios
        • Recursos adicionais
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page
  1. Módulo 1
  2. Introdução a Smart Contracts
  3. Ethereum 101
  4. Contas

Tipos de contas

Há dois tipos de contas:

  • EOA (Externally Owned Account). Uma conta de um usuário do Ethereum, controlada por qualquer pessoa que possua as chaves privadas.

  • Contract Account. Uma conta que contém código executável de contrato inteligente e é controlada pela lógica de seu código. Não possui chaves privadas.

Ambos tipos de contas podem:

  • Receber, manter e enviar ETH e tokens.

  • Interagir com smart contracts existentes.

No entanto, possuem diferenças importantes.

Há dois tipos de contas:

  1. EOA (Externally Owned Account). Uma conta de um usuário do Ethereum, controlada por qualquer pessoa que possua as chaves privadas.

  2. Contract Account. Uma conta que possui código executável de smart contract e é controlada pela lógica do seu código. Não possui chaves privadas.

Ambos os tipos de contas podem:

  • Receber, manter e enviar ETH e tokens.

  • Interagir com smart contracts existentes.

No entanto, eles possuem diferenças importantes.

Conta EOA
Contract Account

Custo de criação

Nenhum

Tem custo porque utiliza armazenamento da blockchain

Transações possíveis

Pode iniciar qualquer transação

Só pode enviar transações em resposta a uma transação recebida

Interação com EOAs

Só transferências de ETH

Uma EOA pode enviar transações que disparem a execução de seu código

O endereço Ethereum (address) de uma EOA é gerado a partir de sua chave privada. Primeiro, a chave pública é criada com um primeiro ciframento, e depois o endereço é gerado aplicando um hash à chave pública (veja chaves públicas e privadas na aula anterior).

Os endereços das contract accounts também possuem 42 caracteres e começam com «0x», mas são gerados criptograficamente a partir do endereço da conta do criador do contrato e do número de transações enviadas a partir desse endereço (nonce).

O endereço Ethereum (address) de uma EOA é gerada a partir de sua chave privada. Primeiro, cria-se a chave pública com uma primeira criptografia e, em seguida, o endereço é gerado, aplicando um hash à chave pública (veja sobre chaves públicas e privadas na aula anterior).

Os endereços das contract accounts também têm 42 caracteres e começam com "0x", mas são geradas criptograficamente a partir do endereço da conta do criador do contrato e do número de transações enviadas a partir desse endereço (nonce).

PreviousContasNextConteúdo das contas

Last updated 23 days ago