A comprehensive Python framework for building secure medical and business applications with advanced security features and Flet integration
Project description
Essencia
A comprehensive Python framework for building secure medical and business applications with Brazilian market support.
Features
- Security First: Field-level encryption, XSS protection, rate limiting, CSRF tokens
- Medical Ready: Encrypted medical fields, LGPD compliance features
- Brazilian Support: CPF/CNPJ validators, phone formatting, Portuguese error messages
- Multi-Database: MongoDB and PostgreSQL support with consistent API
- Smart Caching: Redis-based intelligent caching with fallback
- Modern UI: Built on Flet (Flutter for Python)
- Type Safe: Full type hints and Pydantic validation
- Laboratory System: Import, store and analyze lab test results with encryption
Installation
# Basic installation
pip install essencia
# With security extras (bcrypt, argon2)
pip install essencia[security]
# With PostgreSQL support
pip install essencia[postgresql]
# All features
pip install essencia[all]
Quick Start
Environment Setup
Create a .env file:
# Required for encryption features
ESSENCIA_ENCRYPTION_KEY="your-base64-encoded-32-byte-key"
# Database connections (optional, defaults to localhost)
MONGODB_URL="mongodb://localhost:27017"
REDIS_URL="redis://localhost:6379"
Generate an encryption key:
python -c "import secrets; import base64; print(base64.b64encode(secrets.token_bytes(32)).decode())"
Basic Usage
from essencia import MongoModel, CPFValidator, EncryptedCPF
from essencia.fields import DefaultDateTime
# Define a model with encrypted fields
class Patient(MongoModel):
COLLECTION_NAME = "patients"
name: str
cpf: EncryptedCPF # Automatically encrypted/decrypted
created_at: DefaultDateTime
# Validate Brazilian data
try:
CPFValidator.validate("123.456.789-09")
except ValidationError as e:
print(f"Invalid CPF: {e}")
# Use the model
patient = Patient(name="João Silva", cpf="123.456.789-09")
patient.save_self() # CPF is encrypted in database
Security Features
from essencia.security import sanitize_input, RateLimiter
from essencia.cache import IntelligentCache
# Input sanitization
clean_html = sanitize_input("<script>alert('xss')</script>Hello")
# Result: "Hello"
# Rate limiting
rate_limiter = RateLimiter()
if rate_limiter.is_allowed("user-123", "login"):
# Process login
pass
# Intelligent caching
cache = IntelligentCache()
cache.set("user:123", user_data, ttl=3600)
Service Pattern
from essencia.services import EnhancedBaseService
class PatientService(EnhancedBaseService):
model_class = Patient
collection_name = "patients"
async def find_by_cpf(self, cpf: str):
# CPF is automatically encrypted for search
return await self.find_one({"cpf": cpf})
Laboratory Data Management
from essencia.models import LabTest, LabTestAnalyzer
from essencia.utils import LabCSVImporter
# Import lab results from CSV
importer = LabCSVImporter(patient_key="patient_123", doctor_key="dr_smith")
success_count, errors = importer.import_csv("lab_results.csv")
# Analyze test trends
glucose_trend = LabTestAnalyzer.get_test_trend("patient_123", "Glicemia Jejum")
print(f"Latest: {glucose_trend['latest']} mg/dL, Trend: {glucose_trend['trend']}")
# Get abnormal results
abnormal = LabTestAnalyzer.get_abnormal_results("patient_123")
Components
Models
MongoModel- Base model for MongoDB with sync operationsBaseModel- Async base model using Motor- Built-in field types:
MongoId,ObjectReferenceId,StrEnum
Security
- Sanitization: HTML/Markdown sanitizers for XSS prevention
- Session Management: Secure sessions with CSRF protection
- Authorization: Role-based access control (RBAC)
- Rate Limiting: Multiple strategies (sliding window, token bucket)
- Encryption: Field-level encryption for sensitive data
Validators
CPFValidator- Brazilian CPF validation and formattingCNPJValidator- Brazilian CNPJ validationPhoneValidator- Brazilian phone numbersEmailValidator- Email validationMoneyValidator- Brazilian currency formattingDateValidator- Date validation with business rules
Fields
EncryptedCPF,EncryptedRG- Encrypted Brazilian documentsEncryptedMedicalData- For medical recordsEncryptedLabResults- For laboratory test resultsDefaultDate,DefaultDateTime- Auto-populated timestamps
Laboratory System
LabTestType- Catalog of test types with reference rangesLabTest- Individual test results with encryptionLabTestBatch- Import tracking and auditingLabTestAnalyzer- Trend analysis and reportingLabCSVImporter- CSV import utility
Documentation
- Security Policy - Security features and reporting
- Migration Guide - Migrating from previous versions
- Publishing Guide - PyPI publication checklist
- Laboratory System - Lab data management guide
Requirements
- Python 3.12+
- MongoDB 4.0+
- Redis 6.0+ (optional, for caching)
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
- Create an issue for bug reports or feature requests
- For security issues, see SECURITY.md
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file essencia-1.13.0.tar.gz.
File metadata
- Download URL: essencia-1.13.0.tar.gz
- Upload date:
- Size: 593.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
51f749a9bc6ed3bced1d0e0475f7225336694c23aae22031e370f3a5ebdd231d
|
|
| MD5 |
4ddd648201ea45320c3b528965500a48
|
|
| BLAKE2b-256 |
5e912eab64f79057042628b6a7fef4ac927e06f54e35951ee1a7d558d7154ffe
|
File details
Details for the file essencia-1.13.0-py3-none-any.whl.
File metadata
- Download URL: essencia-1.13.0-py3-none-any.whl
- Upload date:
- Size: 550.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
43e1827819047c64278bad3fb3397c953996fdc69ca5ba906e42eb3872866346
|
|
| MD5 |
78313a0e8b9b4b478ad67bb6ae2fa926
|
|
| BLAKE2b-256 |
db638dc04ca719a68b4bcc93287bd2b1c274d70a52c2b3e3b899991a8a071190
|