Skip to main content

Base Reusable Services for SaaS

Project description

Geek Cafe Services

Python 3.13+ Version DynamoDB AWS Lambda

⚠️ Pre-1.0 Notice: This library is under active development. Breaking changes may occur until we reach a stable 1.0 GA release. We recommend pinning to specific versions in production.

✨ New in v0.3.0: Complete CRUDL Lambda handlers for all core resources (Events, Users, Groups, Messages, Votes)!

Test Coverage

Tests Coverage

Overall Coverage: 83.1% (9646/11611 statements)

Coverage Summary

Metric Value
Total Statements 11,611
Covered Statements 9,646
Missing Statements 1,965
Coverage Percentage 83.1%
Total Tests 1145
Test Status ✅ All Passing

Files Needing Attention (< 80% coverage)

Coverage Missing Lines File
17.5% 47 lambda_handlers/_base/authorized_secure_handler.py
25.3% 133 domains/communities/services/community_member_service.py
46.3% 58 domains/auth/models/role.py
46.9% 34 domains/auth/models/permission.py
46.9% 85 domains/auth/services/resource_permission_service.py
56.2% 7 lambda_handlers/_base/secure_handler.py
58.5% 17 domains/messaging/handlers/contact_threads/update/app.py
62.3% 118 utilities/lambda_event_utility.py
63.4% 86 domains/communities/services/community_service.py
64.0% 41 domains/files/services/s3_file_service.py

... and 22 more files with < 80% coverage

Running Tests

# Run all tests with coverage
./run_unit_tests.sh

# View detailed coverage report
open reports/coverage/index.html

Last updated: 2025-10-16 13:22:11


Description

Geek Cafe Services is a production-ready, enterprise-grade library that provides reusable database services specifically designed for multi-tenant SaaS applications. Built on top of AWS DynamoDB, this library offers a prescriptive approach to building scalable, maintainable backend services with consistent patterns and best practices.

Why Geek Cafe Services?

🏗️ Consistent Architecture: All services follow the same proven patterns for CRUD operations, error handling, and access control
🔒 Multi-Tenant by Design: Built-in tenant isolation ensures secure data separation across customers
DynamoDB Optimized: Leverages DynamoDB's strengths with efficient GSI indexes and query patterns
🛡️ Production Ready: Comprehensive error handling, logging, pagination, and batch operations
🧪 Fully Tested: 100% test coverage with comprehensive test suites for reliability
📖 Well Documented: Extensive documentation with practical examples and best practices

Perfect For

  • SaaS Applications requiring multi-tenant data isolation
  • Serverless Architectures built on AWS Lambda and DynamoDB
  • Teams wanting consistent, proven patterns across services
  • Rapid Development with pre-built, tested service components

Installation

# Clone the repository
git clone https://github.com/geekcafe/geek-cafe-services.git
cd geek-cafe-services

# Setup the development environment
./pysetup.sh

# Install dependencies
pip install -r requirements.txt

Quick Start

from geek_cafe_saas_sdk.message_service import MessageService

# Initialize service
service = MessageService()

# Create a message
result = service.create(
    tenant_id="your_tenant",
    user_id="your_user",
    type="notification",
    content={"title": "Welcome!", "body": "Thanks for joining us."}
)

if result.success:
    print(f"Created message: {result.data.id}")

Available Services

🚀 Lambda Handler Wrappers (NEW in v0.2.0)

Purpose: Eliminate 70-80% of boilerplate code in AWS Lambda functions

Key Capabilities:

  • ✅ Automatic API key validation from environment
  • ✅ Request body parsing and camelCase → snake_case conversion
  • ✅ Service initialization with connection pooling for warm starts
  • ✅ Built-in CORS and error handling
  • ✅ User context extraction from authorizers
  • ✅ Service injection for easy testing
  • ✅ Support for public and secured endpoints

Available Handlers:

  • ApiKeyLambdaHandler - API key validation (most common)
  • PublicLambdaHandler - No authentication (config endpoints)
  • BaseLambdaHandler - Extensible base for custom handlers

Quick Example:

from geek_cafe_saas_sdk.lambda_handlers import ApiKeyLambdaHandler
from geek_cafe_saas_sdk.vote_service import VoteService

# All boilerplate handled in 3 lines
handler = ApiKeyLambdaHandler(
    service_class=VoteService,
    require_body=True,
    convert_case=True
)

def lambda_handler(event, context):
    return handler.execute(event, context, create_vote)

def create_vote(event, service, user_context):
    # Just your business logic - everything else is handled!
    payload = event["parsed_body"]  # Already parsed & converted
    return service.create_vote(
        tenant_id=user_context.get("tenant_id", "anonymous"),
        user_id=user_context.get("user_id", "anonymous"),
        **payload
    )

Use Cases: Any AWS Lambda function with API key auth, reducing code by 70-80% while maintaining all functionality

📖 Complete Lambda Handlers Documentation

📧 MessageService

Purpose: Complete message and notification management system

Key Capabilities:

  • ✅ Full CRUD operations with tenant isolation
  • ✅ Flexible JSON content storage for any message type
  • ✅ Efficient querying by user, tenant, and message type
  • ✅ Automatic audit trails and timestamps
  • ✅ Built-in access control and validation

Use Cases: User notifications, system alerts, communication logs, announcement management

🗳️ Voting Services Suite

Purpose: Complete voting and rating system with real-time aggregation

Architecture: Three interconnected services working together:

VoteService

  • ✅ Individual vote management with automatic upsert behavior
  • ✅ One vote per user per target enforcement
  • ✅ Support for up/down votes or custom vote types
  • ✅ Comprehensive querying by user, target, and tenant

VoteSummaryService

  • ✅ Pre-calculated vote totals for instant retrieval
  • ✅ Target-based optimization for high-performance lookups
  • ✅ Metadata tracking (last tallied timestamp, vote counts)
  • ✅ Tenant-scoped summary management

VoteTallyService

  • ✅ Intelligent vote aggregation with pagination support
  • ✅ Batch processing for multiple targets
  • ✅ Stale target detection and automated re-tallying
  • ✅ Comprehensive error handling and resilience

Use Cases: Product ratings, content voting, feedback systems, community polls, recommendation engines

Documentation

📖 Complete Documentation

Core Features

🏛️ Enterprise Architecture

  • Multi-Tenant by Design: Complete tenant isolation with automatic access control
  • Consistent Patterns: All services follow identical CRUD interfaces and conventions
  • Scalable Design: Built for high-throughput, multi-customer SaaS applications

🔧 Developer Experience

  • Type Safety: Full Python type hints for better IDE support and fewer bugs
  • Comprehensive Testing: 100% test coverage with realistic test scenarios
  • Rich Documentation: Detailed API docs, examples, and best practices
  • Easy Integration: Simple initialization and consistent error handling

Performance & Reliability

  • DynamoDB Optimized: Efficient GSI indexes and query patterns for fast operations
  • Pagination Support: Handle large datasets without memory issues
  • Batch Operations: Process multiple items efficiently
  • Error Resilience: Graceful handling of partial failures and edge cases

🛡️ Production Ready

  • Structured Logging: AWS Lambda Powertools integration for observability
  • Comprehensive Validation: Input validation with detailed error messages
  • Access Control: Automatic tenant and user-based security enforcement
  • Audit Trails: Complete tracking of who did what and when

Environment Setup

# Required environment variables
export DYNAMODB_TABLE_NAME=your_table_name

# Optional AWS configuration (if not using IAM roles)
export AWS_REGION=us-east-1
export AWS_ACCESS_KEY_ID=your_access_key
export AWS_SECRET_ACCESS_KEY=your_secret_key

Testing

# Run all tests
pytest tests/ -v

# Run specific service tests
pytest tests/test_message_service.py -v
pytest tests/test_vote_*_service.py -v

# Run with coverage
pytest tests/ --cov=geek_cafe_saas_sdk --cov-report=html

Project Structure

geek-cafe-services/
├── src/geek_cafe_saas_sdk/
│   ├── lambda_handlers/     # 🆕 Lambda handler wrappers (v0.2.0)
│   │   ├── base.py          # Base handler with common functionality
│   │   ├── api_key_handler.py    # API key validation handler
│   │   ├── public_handler.py     # Public (no auth) handler
│   │   └── service_pool.py       # Service connection pooling
│   ├── middleware/          # CORS, auth, error handling decorators
│   ├── utilities/           # Request/response helpers
│   ├── models/              # Data models with DynamoDB mapping
│   ├── *_service.py         # Service implementations
│   ├── database_service.py  # Base service class
│   └── service_result.py    # Standardized response wrapper
├── tests/                   # Comprehensive test suite
├── docs/                    # Detailed documentation
│   └── lambda_handlers.md   # 🆕 Lambda wrapper documentation
├── examples/                # Working code examples
│   └── lambda_handlers/     # 🆕 Handler examples
└── README.md               # This file

Contributing

We welcome contributions! Here's how to get started:

  1. Fork the repository and create a feature branch
  2. Follow the existing patterns - consistency is key
  3. Add comprehensive tests for any new functionality
  4. Update documentation for API changes
  5. Submit a Pull Request with a clear description

Development Guidelines

  • Follow existing code style and patterns
  • Maintain 100% test coverage for new code
  • Update documentation for any API changes
  • Use meaningful commit messages
  • Test against multiple Python versions if possible

License

This project is licensed under the MIT License - see the LICENSE file for details.

Support


Built with ❤️ for the SaaS development community

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

geek_cafe_saas_sdk-0.7.5.tar.gz (332.9 kB view details)

Uploaded Source

Built Distribution

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

geek_cafe_saas_sdk-0.7.5-py3-none-any.whl (419.2 kB view details)

Uploaded Python 3

File details

Details for the file geek_cafe_saas_sdk-0.7.5.tar.gz.

File metadata

  • Download URL: geek_cafe_saas_sdk-0.7.5.tar.gz
  • Upload date:
  • Size: 332.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for geek_cafe_saas_sdk-0.7.5.tar.gz
Algorithm Hash digest
SHA256 246e670721105bc615a5ef6d6783b328a1ab251b1eee151d3d266c08ec54e46a
MD5 4a9616e00095103a8369f5cc9741eaed
BLAKE2b-256 563914d95bcdc7b19c96e01b4aff11a9d710537d23f4000932d4ba6028981e29

See more details on using hashes here.

File details

Details for the file geek_cafe_saas_sdk-0.7.5-py3-none-any.whl.

File metadata

File hashes

Hashes for geek_cafe_saas_sdk-0.7.5-py3-none-any.whl
Algorithm Hash digest
SHA256 eb5ed1e9442dde1b55712b1e7e2e59a4ee2eb935d2935bd828044b154a21c20f
MD5 2721f6782729828c4708c350bf66aaec
BLAKE2b-256 aaf1f937c3cef3d4dd94a1686121aac8274a2494543968f0134f0e87b690dbf9

See more details on using hashes here.

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