Skip to main content

Django SAAS Framework

Project description

🚀 django_resaas

django_resaas é um framework modular para construção de aplicações SaaS multi-tenant em Django, com:

  • 🔐 Controle de permissões (RBAC)
  • 🏢 Multi-tenant (Entidade / Sucursal)
  • 🧩 Módulos ativáveis por cliente
  • 💰 Billing por plano (SaaS ready)
  • ♻️ Soft delete + restore
  • 🔎 Busca dinâmica automática
  • ⚡ BaseAPIView inteligente (DRF)

🧠 Arquitetura

User
 ↓
Pessoa
 ↓
Funcionario (RH)
 ↓
Entidade (tenant)
 ↓
Sucursal
 ↓
Grupos + Permissões

🧩 Conceitos principais

🏢 Entidade (Tenant)

Representa o cliente (empresa)

🏬 Sucursal

Unidade da entidade

👤 Pessoa

Dados humanos (nome, email, etc.)

🔐 User

Autenticação

👥 SucursalUserGroup

Relaciona:

  • User
  • Sucursal
  • Grupo (Django)

👉 Permite múltiplos grupos por sucursal


🔐 Sistema de Permissões (RBAC)

Baseado em:

User + Group + Permission (Django)
+ contexto (Entidade + Sucursal)

Headers obrigatórios:

ET → tipo_entidade
E  → entidade
S  → sucursal
G  → grupo
L  → idioma

🧱 BaseModel

Todos os models herdam:

from django_resaas import BaseModel

Inclui:

  • entidade
  • sucursal
  • created_at / updated_at
  • soft delete
  • created_by / updated_by

🔁 Soft Delete

obj.delete()        # soft delete
obj.restore()       # restore
obj.hard_delete()   # delete real

Managers disponíveis:

Model.objects          # ativos
Model.deleted_objects  # apagados
Model.all_objects      # todos

⚡ BaseAPIView

CRUD automático com:

  • multi-tenant automático
  • permissões automáticas
  • search dinâmica
  • soft delete
  • restore
  • hard delete

Uso:

from django_resaas import BaseAPIView, register_view

@register_view(module="rh")
class FuncionarioView(BaseAPIView):
    queryset = Funcionario.objects.all()
    serializer_class = FuncionarioSerializer

🔍 Busca dinâmica

GET /api/funcionarios/?search=joao

Busca automaticamente em:

  • nome
  • email
  • código
  • relações (FK)

🧩 Sistema de Módulos

Permite ativar/desativar funcionalidades por cliente.

Modelos:

  • Modulo
  • EntidadeModulo

Exemplo:

Entidade Módulo Estado
Empresa A RH
Empresa A CRM

🔐 Proteção automática por módulo

@register_view(module="rh")
class FuncionarioView(BaseAPIView):
    ...

👉 Se módulo não estiver ativo → acesso bloqueado


💰 Billing (SaaS)

Modelos:

  • Plano
  • PlanoModulo
  • EntidadePlano

Fluxo:

Plano → módulos → EntidadePlano → ativa módulos automaticamente

🔄 Sync automático de módulos

Ao mudar plano:

sync_modulos_entidade(entidade)

📦 BaseSerializer

Proteção automática de arquivos:

{
  "file": {
    "url": "...",
    "name": "...",
    "ext": "pdf",
    "size": 12345
  }
}

🌐 Middleware

TenantContextMiddleware

Captura headers:

request.entidade_id
request.sucursal_id
request.group_id

FrontEndMiddleware

Protege acesso por:

  • chave frontend (FEK/FEP)
  • permissões por URL
  • permissões por método HTTP

🧪 Exemplo completo

Model

from django_resaas import BaseModel

class Funcionario(BaseModel):
    pessoa = models.ForeignKey('django_resaas.Pessoa', on_delete=models.CASCADE)
    cargo = models.CharField(max_length=100)

Serializer

from django_resaas import BaseSerializer

class FuncionarioSerializer(BaseSerializer):
    class Meta:
        model = Funcionario
        fields = "__all__"

View

from django_resaas import BaseAPIView, register_view

@register_view(module="rh")
class FuncionarioView(BaseAPIView):
    queryset = Funcionario.objects.all()
    serializer_class = FuncionarioSerializer

⚙️ Instalação

pip install django_resaas

ou local:

pip install -e .

🔧 Configuração

INSTALLED_APPS

INSTALLED_APPS = [
    "django_resaas",
    "rh",
]

Middleware

MIDDLEWARE = [
    "django_resaas.core.middleware.tenant.TenantContextMiddleware",
    "django_resaas.core.middleware.frontend.FrontEndMiddleware",
]

🚀 Roadmap

  • Integração com Stripe
  • Dashboard de billing
  • Auto-router
  • Auditoria de ações
  • Logs multi-tenant
  • Cache de permissões (Redis)

🧠 Filosofia

"Construir SaaS não deve ser repetitivo."

django_resaas resolve:

  • multi-tenant
  • permissões
  • módulos
  • billing

👉 para você focar no negócio


🤝 Contribuição

PRs são bem-vindos 🚀


📄 Licença

MIT License


👨‍💻 Autor

Metano Chavana

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_resaas-0.0.69.tar.gz (93.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_resaas-0.0.69-py3-none-any.whl (149.0 kB view details)

Uploaded Python 3

File details

Details for the file django_resaas-0.0.69.tar.gz.

File metadata

  • Download URL: django_resaas-0.0.69.tar.gz
  • Upload date:
  • Size: 93.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_resaas-0.0.69.tar.gz
Algorithm Hash digest
SHA256 bd021d673a4971f74932a42e486b43ec25b62798c95f458fc840096eb613f703
MD5 ddcf0dc07b48cf7b59d1238003446fb0
BLAKE2b-256 0130ab186874d9d89ccf0d523e8486ccd92f72b3b344f7f5971ba887e3236dc6

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_resaas-0.0.69.tar.gz:

Publisher: publish_pypi.yml on metanochava/django_resaas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_resaas-0.0.69-py3-none-any.whl.

File metadata

  • Download URL: django_resaas-0.0.69-py3-none-any.whl
  • Upload date:
  • Size: 149.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_resaas-0.0.69-py3-none-any.whl
Algorithm Hash digest
SHA256 e94f8d80f1eaf90a8c2a12cb9e9be21f2ba0973c6c1e7bd7bc624934cf5a9bde
MD5 120a12500e4397de5b76ca2fbbb4a334
BLAKE2b-256 81a458b019f5c30114769b8ff90948282d2774dc1259374bc69f03ba3446815b

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_resaas-0.0.69-py3-none-any.whl:

Publisher: publish_pypi.yml on metanochava/django_resaas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page