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.116.tar.gz (98.3 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.116-py3-none-any.whl (154.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for django_resaas-0.0.116.tar.gz
Algorithm Hash digest
SHA256 f75ffd1fbb33166119d440d01f5e0a1f56f76e0542498775555b0d6e0a567eaa
MD5 7e441ed077ed2c21231723691848cd14
BLAKE2b-256 1686e586f602ea672b213f204e2ef7031a9472859f928c3be8c2f4b3106dd731

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_resaas-0.0.116.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.116-py3-none-any.whl.

File metadata

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

File hashes

Hashes for django_resaas-0.0.116-py3-none-any.whl
Algorithm Hash digest
SHA256 95e0abaa29181d67dfbae32a2d69c1308c59437d5f4fa64389c72954e2a4c831
MD5 f360cf307a83ddaba2c6fc1528e1e657
BLAKE2b-256 44a190c62d678479758c55de0c1222e7323e217f0d68c5e318f764ae24009464

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_resaas-0.0.116-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