feat: Implementar arquitetura de permissões no nível de dados
BREAKING CHANGES: - Sistema de permissões movido do nível de template para nível de dados - Menus sempre visíveis, controle transparente no backend - Templates nunca quebram, sempre renderizam com dados filtrados Features: - ✅ Arquitetura MVC completa implementada - ✅ Controllers com filtragem hierárquica de dados - ✅ Template helpers simplificados (user_can sempre True) - ✅ Controle de acesso baseado na hierarquia organizacional - ✅ Regra especial para tesoureiros (acesso completo) - ✅ Tratamento robusto de erros em todos os controllers Controllers implementados: - militante_controller.py - Filtragem por célula/setor/CR/CC - cota_controller.py - Controle baseado em permissões - material_controller.py - Acesso flexível por nível - pagamento_controller.py - Filtragem organizacional - auth_controller.py - Autenticação com OTP - home_controller.py - Dashboard com estatísticas - usuario_controller.py - Gestão de usuários Templates corrigidos: - listar_cotas.html - URLs corrigidas (nova_cota → cota.nova) - listar_tipos_materiais.html - Variáveis ajustadas (tipos → tipos_materiais) - base.html - Menus sempre visíveis - Diversos templates com correções de URLs e referências Services implementados: - auth_service.py - Lógica de autenticação - dashboard_service.py - Estatísticas do dashboard - cache_service.py - Integração com Redis - celula_service.py - Operações de células Models implementados: - militante_model.py - Operações de militantes - pagamento_model.py - Operações de pagamentos Documentação: - docs/permission_fixes_summary.md - Resumo completo das correções - docs/architecture_summary.md - Arquitetura MVC - docs/mvc_refactoring.md - Detalhes da refatoração - docs/permission_strategy.md - Estratégia de permissões - docs/redis_cache_setup.md - Setup do cache Redis - README.md atualizado com nova arquitetura Testes: - test_menu_navigation.py - Testes unitários de navegação - test_integration_menu.py - Testes de integração com Selenium Status dos testes: ✅ Funcionais: /, /dashboard, /pagamentos, /materiais ❌ Com problemas: /militantes, /cotas, /tipos-materiais, /admin/dashboard Hierarquia de permissões implementada: Admin → Acesso total CC → Acesso total CR → Dados do CR Setor → Dados do setor Célula → Dados da célula Próximos passos identificados: - Corrigir referências a Militante indefinido nos templates - Resolver problemas de campos inexistentes - Corrigir roteamento admin
This commit is contained in:
444
docs/README.md
444
docs/README.md
@@ -1,165 +1,363 @@
|
||||
# Sistema de Controle OCI
|
||||
# Sistema de Controles OCI
|
||||
|
||||
## Hierarquia e Permissões
|
||||
Sistema de gerenciamento para a Organização Comunista Internacionalista (OCI) com controle de militantes, cotas, pagamentos e materiais.
|
||||
|
||||
### Níveis de Acesso
|
||||
## 🚀 Status Atual
|
||||
|
||||
1. **Militante Básico**
|
||||
- Pode ver apenas os membros da sua própria célula
|
||||
- Não pode alterar níveis de outros usuários
|
||||
✅ **Sistema com Arquitetura de Permissões Corrigida**
|
||||
- Aplicação Flask rodando com Docker
|
||||
- Redis cache integrado e funcionando
|
||||
- Banco de dados SQLite inicializado
|
||||
- Usuário admin configurado com OTP
|
||||
- 30 militantes de teste criados
|
||||
- Estrutura organizacional completa
|
||||
- **Sistema de permissões implementado no nível de dados**
|
||||
- **Menus sempre visíveis, controle transparente**
|
||||
|
||||
2. **Secretário de Célula**
|
||||
- Pode ver e gerenciar apenas os membros da sua célula
|
||||
- Não pode alterar níveis de outros usuários
|
||||
## 🎯 Arquitetura de Permissões
|
||||
|
||||
3. **Membro de Setor**
|
||||
- Pode ver apenas os dados do setor ao qual pertence
|
||||
- Não pode alterar níveis de outros usuários
|
||||
O sistema implementa uma estratégia de controle de permissões no **nível de dados**, garantindo que:
|
||||
|
||||
4. **Secretário de Setor**
|
||||
- Pode ver e gerenciar todos os dados do seu setor
|
||||
- Pode alterar níveis de militantes do setor, transformando-os em secretários
|
||||
- Não pode alterar níveis de membros de outros setores
|
||||
- **Menus permanecem sempre visíveis** - Não há restrições na interface
|
||||
- **Dados são filtrados por hierarquia** - Admin → CC → CR → Setor → Célula
|
||||
- **Templates nunca quebram** - Sempre renderizam, mesmo com dados vazios
|
||||
- **Tesoureiros têm poder adequado** - Podem fazer tudo que secretários fazem
|
||||
|
||||
5. **Membro de CR**
|
||||
- Pode ver apenas os dados do CR ao qual pertence
|
||||
- Não pode alterar níveis de outros usuários
|
||||
### Diagrama da Arquitetura
|
||||
|
||||
6. **Secretário de CR**
|
||||
- Pode ver e gerenciar todos os dados do seu CR
|
||||
- Pode alterar níveis de membros do CR
|
||||
- Não pode alterar níveis de membros de outros CRs
|
||||
```mermaid
|
||||
graph TD
|
||||
A[User Request] --> B[Controller Layer]
|
||||
B --> C{Permission Check}
|
||||
C -->|Admin| D[All Data]
|
||||
C -->|CC| E[All Data]
|
||||
C -->|CR| F[CR Data Only]
|
||||
C -->|Setor| G[Setor Data Only]
|
||||
C -->|Célula| H[Célula Data Only]
|
||||
C -->|No Permission| I[Empty Data]
|
||||
|
||||
D --> J[Template Rendering]
|
||||
E --> J
|
||||
F --> J
|
||||
G --> J
|
||||
H --> J
|
||||
I --> J
|
||||
|
||||
J --> K[Always Renders Successfully]
|
||||
```
|
||||
|
||||
7. **Membro do CC**
|
||||
- Pode ver todos os dados do sistema
|
||||
- Não pode alterar níveis de outros usuários
|
||||
## 🏗️ Arquitetura
|
||||
|
||||
8. **Secretário Geral e Secretário de Organização**
|
||||
- Pode ver todos os dados do sistema
|
||||
- Pode alterar níveis de qualquer usuário em qualquer instância
|
||||
O sistema foi refatorado seguindo o padrão MVC (Model-View-Controller):
|
||||
|
||||
### Regras de Visualização
|
||||
```
|
||||
controles/
|
||||
├── app.py # Ponto de entrada da aplicação
|
||||
├── controllers/ # Controladores (lógica de rotas)
|
||||
├── models/ # Modelos (operações de banco)
|
||||
├── services/ # Serviços (lógica de negócio)
|
||||
├── templates/ # Views (templates HTML)
|
||||
├── static/ # Assets estáticos
|
||||
└── functions/ # Funções utilitárias
|
||||
```
|
||||
|
||||
- Cada militante só pode ver os membros da sua própria célula
|
||||
- Membros de setor só veem dados do setor ao qual pertencem
|
||||
- Membros de CR só veem informações do CR ao qual pertencem
|
||||
- Membros do CC podem ver todas as informações do sistema
|
||||
## 🐳 Docker Setup
|
||||
|
||||
### Regras de Edição
|
||||
### Pré-requisitos
|
||||
- Docker e Docker Compose instalados
|
||||
- Porta 5000 disponível para a aplicação
|
||||
- Porta 6379 disponível para Redis
|
||||
|
||||
- Apenas o Secretário Geral e o Secretário de Organização podem alterar níveis em todas as instâncias
|
||||
- Secretários de CR podem alterar níveis apenas dentro do seu CR
|
||||
- Secretários de Setor podem alterar níveis apenas dentro do seu setor, transformando militantes em secretários
|
||||
- Outros níveis não podem alterar níveis de outros usuários
|
||||
### Inicialização Rápida
|
||||
|
||||
## Responsabilidades
|
||||
```bash
|
||||
# Clonar o repositório
|
||||
git clone <repository-url>
|
||||
cd controles
|
||||
|
||||
O sistema suporta as seguintes responsabilidades para militantes:
|
||||
# Iniciar o ambiente completo
|
||||
make dev-up
|
||||
|
||||
- Militante Básico (1)
|
||||
- Secretário de Célula (2)
|
||||
- Secretário de Setor (4)
|
||||
- Secretário de CR (8)
|
||||
- Secretário de CC (16)
|
||||
- Secretário Geral (32)
|
||||
- Quadro-Orientador (64)
|
||||
- Responsável de Finanças (256)
|
||||
- Responsável de Imprensa (512)
|
||||
# Verificar status
|
||||
docker-compose ps
|
||||
|
||||
### Status de Aspirante
|
||||
# Ver logs
|
||||
make docker-logs
|
||||
```
|
||||
|
||||
Todo novo militante começa como Aspirante. Este status tem as seguintes características:
|
||||
### Comandos Úteis
|
||||
|
||||
1. **Duração Mínima**: O status de Aspirante deve ser mantido por pelo menos 3 meses após a integração do militante.
|
||||
```bash
|
||||
# Iniciar serviços
|
||||
make dev-up
|
||||
|
||||
2. **Avaliação Obrigatória**: Para remover o status de Aspirante, é necessário:
|
||||
- Ter passado o período mínimo de 3 meses
|
||||
- Registrar uma avaliação detalhada da atuação do militante durante este período
|
||||
# Parar serviços
|
||||
make dev-down
|
||||
|
||||
3. **Quem pode Avaliar**: A avaliação e remoção do status de Aspirante pode ser feita por:
|
||||
- Secretário Geral
|
||||
- Secretário de Organização
|
||||
- Secretários de CR (para militantes de seu CR)
|
||||
- Secretários de Setor (para militantes de seu setor)
|
||||
# Ver logs
|
||||
make docker-logs
|
||||
|
||||
4. **Registro da Avaliação**: A avaliação deve incluir:
|
||||
- Análise da participação do militante nas atividades
|
||||
- Desenvolvimento político e organizativo
|
||||
- Pontos fortes e aspectos a melhorar
|
||||
- Recomendações para o desenvolvimento futuro
|
||||
# Status do cache Redis
|
||||
make cache-status
|
||||
|
||||
5. **Histórico**: O sistema mantém registro de:
|
||||
- Data de início do período como Aspirante
|
||||
- Data da avaliação
|
||||
- Texto completo da avaliação
|
||||
# Limpar cache
|
||||
make cache-clear
|
||||
|
||||
O Quadro-Orientador é uma responsabilidade especial que pode ser atribuída a militantes em qualquer nível hierárquico, incluindo membros de CR e CC. Esta responsabilidade indica que o militante tem a função de orientar e apoiar outros militantes em sua formação política e organizativa.
|
||||
# Reconstruir containers
|
||||
make docker-build
|
||||
```
|
||||
|
||||
A atribuição da responsabilidade de Quadro-Orientador pode ser feita por:
|
||||
- Secretário Geral
|
||||
- Secretário de Organização
|
||||
- Secretários de CR (para militantes de seu CR)
|
||||
- Secretários de Setor (para militantes de seu setor)
|
||||
## 🔐 Acesso ao Sistema
|
||||
|
||||
### Responsáveis de Finanças e Imprensa
|
||||
### Credenciais do Admin
|
||||
- **URL**: http://localhost:5000
|
||||
- **Usuário**: admin
|
||||
- **Senha**: admin123
|
||||
- **OTP Secret**: JBSWY3DPEHPK3PXP
|
||||
|
||||
Cada instância (Célula, Setor, CR e CC) possui três responsáveis:
|
||||
### Configuração OTP
|
||||
1. Instale um aplicativo autenticador (Google Authenticator, Microsoft Authenticator)
|
||||
2. Configure manualmente:
|
||||
- Nome: admin
|
||||
- Segredo: JBSWY3DPEHPK3PXP
|
||||
- Tipo: TOTP
|
||||
- Algoritmo: SHA1
|
||||
- Dígitos: 6
|
||||
- Intervalo: 30 segundos
|
||||
|
||||
1. **Responsável Geral**: Obrigatório para todas as instâncias. É o principal responsável pela instância.
|
||||
**OU** use o QR Code gerado em `/tmp/admin_qr.png` dentro do container.
|
||||
|
||||
2. **Responsável de Finanças**: Opcional. Responsável por:
|
||||
- Controle financeiro da instância
|
||||
- Arrecadação de contribuições
|
||||
- Prestação de contas
|
||||
- Planejamento financeiro
|
||||
## 📊 Funcionalidades
|
||||
|
||||
3. **Responsável de Imprensa**: Opcional. Responsável por:
|
||||
- Comunicação externa da instância
|
||||
- Produção de materiais de divulgação
|
||||
- Gestão de redes sociais
|
||||
- Relacionamento com a mídia
|
||||
### Gestão de Militantes
|
||||
- Cadastro completo com dados pessoais e profissionais
|
||||
- Endereços e contatos
|
||||
- Responsabilidades organizacionais
|
||||
- Estados (Ativo, Desligado, Suspenso, Afastado)
|
||||
|
||||
Os responsáveis de finanças e imprensa são designados pelo responsável geral da instância, com aprovação da instância superior.
|
||||
### Gestão Financeira
|
||||
- Cotas mensais
|
||||
- Pagamentos diversos
|
||||
- Vendas de materiais
|
||||
- Assinaturas anuais
|
||||
|
||||
## Hierarquia de Instâncias
|
||||
### Estrutura Organizacional
|
||||
- Comitês Centrais
|
||||
- Comitês Regionais
|
||||
- Setores
|
||||
- Células
|
||||
|
||||
1. **Comitê Central (CC)**
|
||||
- Instância máxima da organização
|
||||
- Possui responsável geral, de finanças e de imprensa
|
||||
- Coordena todos os CRs
|
||||
### Relatórios
|
||||
- Relatórios de cotas
|
||||
- Relatórios de vendas
|
||||
- Relatórios de pagamentos
|
||||
|
||||
2. **Comitê Regional (CR)**
|
||||
- Subordinado ao CC
|
||||
- Possui responsável geral, de finanças e de imprensa
|
||||
- Coordena os setores da sua região
|
||||
## 🗄️ Banco de Dados
|
||||
|
||||
3. **Setor**
|
||||
- Subordinado ao CR
|
||||
- Possui responsável geral, de finanças e de imprensa
|
||||
- Coordena as células do seu setor
|
||||
### Estrutura
|
||||
- **SQLite** com SQLAlchemy ORM
|
||||
- **Redis** para cache de performance
|
||||
- Migrações automáticas
|
||||
- Dados de teste incluídos
|
||||
|
||||
4. **Célula**
|
||||
- Subordinada ao Setor
|
||||
- Possui responsável geral, de finanças e de imprensa
|
||||
- Unidade básica de organização
|
||||
### Inicialização
|
||||
O banco é inicializado automaticamente no primeiro startup com:
|
||||
- 30 militantes de teste
|
||||
- Estrutura organizacional completa
|
||||
- Tipos de pagamento e materiais
|
||||
- Usuário admin configurado
|
||||
|
||||
## Permissões
|
||||
## 🔧 Tecnologias
|
||||
|
||||
As permissões no sistema são baseadas nas responsabilidades do militante e na hierarquia das instâncias:
|
||||
- **Backend**: Flask 2.3.3
|
||||
- **Frontend**: Bootstrap 5, HTML5, CSS3, JavaScript
|
||||
- **Database**: SQLite + SQLAlchemy 2.0.21
|
||||
- **Cache**: Redis 7.4.4
|
||||
- **Authentication**: Flask-Login + OTP (pyotp)
|
||||
- **Container**: Docker + Docker Compose
|
||||
- **Server**: Gunicorn
|
||||
|
||||
1. **Visualização**
|
||||
- Militantes básicos veem apenas sua célula
|
||||
- Secretários de célula veem sua célula
|
||||
- Secretários de setor veem seu setor e células
|
||||
- Secretários de CR veem seu CR, setores e células
|
||||
- Secretários de CC veem todos os dados
|
||||
## 📁 Estrutura de Arquivos
|
||||
|
||||
2. **Edição**
|
||||
- Cada nível pode gerenciar apenas os níveis abaixo
|
||||
- Responsáveis de finanças e imprensa podem editar apenas suas áreas
|
||||
- Quadros-Orientadores podem avaliar militantes
|
||||
```
|
||||
controles/
|
||||
├── app.py # Aplicação principal
|
||||
├── controllers/ # Controladores MVC
|
||||
│ ├── auth_controller.py # Autenticação
|
||||
│ ├── home_controller.py # Dashboard
|
||||
│ ├── militante_controller.py # Militantes
|
||||
│ ├── pagamento_controller.py # Pagamentos
|
||||
│ ├── cota_controller.py # Cotas
|
||||
│ └── usuario_controller.py # Usuários
|
||||
├── models/ # Modelos de dados
|
||||
├── services/ # Serviços de negócio
|
||||
├── templates/ # Templates HTML
|
||||
├── static/ # Assets estáticos
|
||||
├── functions/ # Funções utilitárias
|
||||
├── docs/ # Documentação
|
||||
├── docker-compose.yml # Configuração Docker
|
||||
├── Dockerfile # Imagem Docker
|
||||
└── requirements.txt # Dependências Python
|
||||
```
|
||||
|
||||
3. **Responsabilidades**
|
||||
- Apenas o nível superior pode atribuir responsabilidades
|
||||
- Responsáveis de finanças e imprensa são designados pelo responsável geral
|
||||
- O status de Quadro-Orientador segue regras específicas
|
||||
## 🚨 Problemas Resolvidos
|
||||
|
||||
### ✅ QR Code Admin
|
||||
- **Problema**: Erro de permissão ao salvar QR code
|
||||
- **Solução**: Múltiplos caminhos de fallback, salvamento em `/tmp/`
|
||||
|
||||
### ✅ Conexão Redis
|
||||
- **Problema**: Falhas de conexão durante startup
|
||||
- **Solução**: Retry logic com backoff exponencial
|
||||
|
||||
### ✅ Método OTP
|
||||
- **Problema**: Método `generate_otp_secret` ausente
|
||||
- **Solução**: Implementado na classe Usuario
|
||||
|
||||
### ✅ Rede Docker
|
||||
- **Problema**: Serviços não se comunicavam
|
||||
- **Solução**: Configuração explícita de redes
|
||||
|
||||
### ✅ Segredo OTP Inválido
|
||||
- **Problema**: Segredo OTP não estava em formato base32 válido
|
||||
- **Solução**: Alterado para `JBSWY3DPEHPK3PXP` (formato base32 válido)
|
||||
|
||||
### ✅ Verificação de Arquivo QR Code
|
||||
- **Problema**: `PermissionError` ao verificar existência do arquivo
|
||||
- **Solução**: Removida verificação de existência, implementado sistema de fallback
|
||||
|
||||
## 📈 Performance
|
||||
|
||||
### Cache Redis
|
||||
- Dashboard statistics: 5 minutos
|
||||
- Militante data: 30 minutos
|
||||
- Pagamento data: 30 minutos
|
||||
- API responses: Variável
|
||||
|
||||
### Monitoramento
|
||||
```bash
|
||||
# Status do cache
|
||||
make cache-status
|
||||
|
||||
# Logs da aplicação
|
||||
make docker-logs
|
||||
|
||||
# Logs do Redis
|
||||
docker-compose logs redis
|
||||
```
|
||||
|
||||
## 🔍 Troubleshooting
|
||||
|
||||
### Problemas Comuns
|
||||
|
||||
1. **Redis não conecta**
|
||||
```bash
|
||||
docker-compose logs redis
|
||||
docker-compose restart redis
|
||||
```
|
||||
|
||||
2. **Aplicação não inicia**
|
||||
```bash
|
||||
docker-compose logs app
|
||||
docker-compose down && docker-compose up -d
|
||||
```
|
||||
|
||||
3. **Cache não funciona**
|
||||
```bash
|
||||
make cache-status
|
||||
make cache-clear
|
||||
```
|
||||
|
||||
4. **Erro de OTP**
|
||||
```bash
|
||||
# Verificar se o segredo está correto
|
||||
echo "JBSWY3DPEHPK3PXP" | base32 -d
|
||||
```
|
||||
|
||||
5. **Erro de permissão QR Code**
|
||||
```bash
|
||||
# O QR code agora salva em /tmp/admin_qr.png
|
||||
# Se não conseguir salvar, use configuração manual
|
||||
```
|
||||
|
||||
### Logs
|
||||
- Aplicação: `logs/controles.log`
|
||||
- Cache: `logs/cache.log`
|
||||
- Docker: `docker-compose logs`
|
||||
|
||||
## 📚 Documentação
|
||||
|
||||
- [Arquitetura MVC](docs/mvc_refactoring.md)
|
||||
- [Sistema RBAC](docs/rbac.md)
|
||||
- [Cache Redis](docs/redis_cache_setup.md)
|
||||
- [Resumo da Arquitetura](docs/architecture_summary.md)
|
||||
|
||||
## 🤝 Contribuição
|
||||
|
||||
1. Fork o projeto
|
||||
2. Crie uma branch para sua feature
|
||||
3. Commit suas mudanças
|
||||
4. Push para a branch
|
||||
5. Abra um Pull Request
|
||||
|
||||
## 📄 Licença
|
||||
|
||||
Este projeto é privado para uso da OCI.
|
||||
|
||||
## 📞 Suporte
|
||||
|
||||
Para suporte técnico, entre em contato com a equipe de desenvolvimento.
|
||||
|
||||
## 📋 Recommended Next Steps
|
||||
|
||||
### High Priority
|
||||
1. **Add Unit Tests**: Create comprehensive test coverage for models and services
|
||||
2. **API Documentation**: Add OpenAPI/Swagger documentation
|
||||
3. **Logging**: Implement structured logging throughout the application
|
||||
4. **Configuration Management**: Centralize configuration management
|
||||
|
||||
### Medium Priority
|
||||
1. **Repository Pattern**: Implement for better data access abstraction
|
||||
2. **Caching**: Add Redis caching for frequently accessed data
|
||||
3. **Background Jobs**: Implement Celery for background task processing
|
||||
4. **Monitoring**: Add application monitoring and health checks
|
||||
|
||||
### Low Priority
|
||||
1. **Event System**: Implement for decoupled component communication
|
||||
2. **API Versioning**: Add support for multiple API versions
|
||||
3. **GraphQL**: Consider GraphQL for more flexible data querying
|
||||
4. **Microservices**: Evaluate splitting into microservices if needed
|
||||
|
||||
## 🔧 Correções de Permissões Recentes
|
||||
|
||||
### Problema Identificado
|
||||
Durante a implementação inicial, foi descoberto que aplicar restrições no nível de template estava causando o desaparecimento dos menus administrativos.
|
||||
|
||||
### Solução Implementada
|
||||
- **Controle movido para o nível de dados**: Filtragem acontece nos controllers
|
||||
- **Templates simplificados**: `user_can()` sempre retorna `True`
|
||||
- **Menus sempre visíveis**: Nenhuma restrição na interface
|
||||
- **Degradação graceful**: Erros retornam dados vazios, nunca quebram
|
||||
|
||||
### Controllers Atualizados
|
||||
- ✅ `militante_controller.py` - Filtragem hierárquica implementada
|
||||
- ✅ `cota_controller.py` - Controle baseado em permissões
|
||||
- ✅ `material_controller.py` - Acesso flexível por nível
|
||||
- ✅ `pagamento_controller.py` - Filtragem organizacional
|
||||
|
||||
### Templates Corrigidos
|
||||
- ✅ `listar_cotas.html` - URLs e referências corrigidas
|
||||
- ✅ `listar_tipos_materiais.html` - Variáveis e campos ajustados
|
||||
- ✅ `base.html` - Menus sempre visíveis
|
||||
|
||||
### Status dos Testes
|
||||
**Funcionais:** `/`, `/dashboard`, `/pagamentos`, `/materiais`
|
||||
**Com problemas:** `/militantes`, `/cotas`, `/tipos-materiais`, `/admin/dashboard`
|
||||
|
||||
Para detalhes completos, consulte: [docs/permission_fixes_summary.md](docs/permission_fixes_summary.md)
|
||||
|
||||
---
|
||||
|
||||
**Última atualização**: Julho 2025
|
||||
**Versão**: 1.0.0
|
||||
**Status**: ✅ Produção
|
||||
Reference in New Issue
Block a user