Files
dejo-node/docs/planning.md
2025-05-23 10:44:32 -03:00

4.2 KiB
Raw Permalink Blame History

🏗️ Plano de Desenvolvimento - DEJO Node

📌 Visão Geral

Este documento define o planejamento das tarefas para o desenvolvimento do DEJO Node, garantindo um roadmap estruturado para a implementação dos componentes essenciais.


1 Criação da Estrutura do Projeto

  • 1.1 - Definir arquitetura de diretórios e módulos [OK]
  • 1.2 - Criar estrutura base do projeto (pastas e arquivos principais) [OK]
  • 1.3 - Configurar Makefile para build, testes e deploy [OK]
  • 1.4 - Criar Dockerfile otimizado para execução do nó [OK]
  • 1.5 - Configurar variáveis de ambiente e arquivos YAML de configuração [OK]
  • 1.6 - Criar script de inicialização do nó (cmd/main.go) [OK]

2 Desenvolvimento do Processamento de Transações

🔹 Dependência: Nenhuma (autocontido, pode ser feito primeiro)

  • 2.1 - Criar estrutura de transação (remetente, destinatário, assinatura, gas, etc.)
  • 2.2 - Implementar validação de transações
  • 2.3 - Criar sistema de Mempool para transações pendentes
  • 2.4 - Criar mecanismo de inclusão de transações nos blocos

3 Armazenamento e Persistência de Dados

🔹 Dependência: Processamento de Transações finalizado

  • 3.1 - Definir banco de dados e estrutura de armazenamento (LevelDB/BadgerDB)
  • 3.2 - Criar estrutura de indexação de blocos e transações
  • 3.3 - Implementar recuperação rápida de estados da blockchain

4 Comunicação P2P entre Nós da Rede

🔹 Dependência: Armazenamento e Transações finalizados

  • 4.1 - Definir protocolo de comunicação (libp2p, WebSockets)
  • 4.2 - Implementar descoberta de peers e inicialização da rede
  • 4.3 - Criar sistema de sincronização de blocos entre nós
    • 4.3.1 - Criar estrutura do módulo SyncManager
    • 4.3.2 - Implementar troca de altura (RequestHeight / ResponseHeight)
    • 4.3.3 - Implementar solicitação de blocos ausentes via stream
    • 4.3.4 - Implementar envio de blocos em resposta a solicitações
    • 4.3.5 - Validar blocos recebidos e aplicar no storage local
    • 4.3.6 - Testes automatizados de sincronização entre dois nós

5 Implementação do Mecanismo de Consenso

🔹 Dependência: Comunicação P2P pronta

  • 5.1 - Definir e implementar o algoritmo de consenso (PoS ou BFT)
  • 5.2 - Criar mecanismo de finalização de blocos
  • 5.3 - Implementar auditoria e métricas para análise de consenso

6 Desenvolvimento da API RPC/WebSockets

🔹 Dependência: Processamento de Transações e Consenso implementados

  • 6.1 - Criar endpoints para consulta de blocos e transações
  • 6.2 - Implementar envio de novas transações via RPC
  • 6.3 - Criar suporte para eventos via WebSockets
  • 6.4 - Adicionar estrutura de resposta JSON detalhada na documentação

7 Implementação da Governança e Staking

🔹 Dependência: Consenso implementado

  • 7.1 - Criar sistema de staking para eleição de validadores
  • 7.2 - Implementar contratos de votação on-chain para governança
  • 7.3 - Criar API para registro e consulta de propostas de governança

8 Implementação dos Oráculos e Integração com Dados Externos

🔹 Dependência: API RPC/WebSockets implementada

  • 8.1 - Criar integração com provedores de dados externos (ex.: Chainlink, API3)
  • 8.2 - Implementar mecanismo de consenso para validação de dados oraculares
  • 8.3 - Criar sistema de auditoria para dados recebidos de oráculos

9 Sistema de Segurança e Proteção contra Ataques

🔹 Dependência: Consenso implementado

  • 9.1 - Implementar proteção contra ataques Sybil e DDoS
  • 9.2 - Criar auditoria e monitoramento de atividades suspeitas
  • 9.3 - Implementar criptografia pós-quântica para segurança futura

📌 Este documento será atualizado conforme a evolução do projeto.

🚀 DEJO Node: Rumo à construção de uma blockchain robusta e escalável! 🔥