Skip to main content

OGuild utilities — reusable logging and helpers for Python projects

Project description

OpsGuild Logo
                🚀 Multi-Language Utilities Pack 🚀
                🐍 Python • 🔷 Node.js • 🦀 Rust • 🐹 Go
                ☕ Java • 🔵 C# • 🐘 PHP • 🦎 Python
                📦 Configuration • 🔍 Monitoring • 🛠️ Operations

OpsGuild Utilities Pack

License: GPL v3 Python 3.9+ Poetry

A comprehensive multi-language utilities pack providing essential tools and helper functions for modern software development. Currently featuring Python utilities with plans to expand to multiple programming languages.

🚀 What is OpsGuild Pack?

OpsGuild Pack is a collection of utility libraries designed to solve common development challenges across different programming languages and platforms. Think of it as your Swiss Army knife for software development operations.

Current Components

📦 Installation

Prerequisites

  • Python 3.9 or higher
  • Poetry (recommended) or pip

Using Poetry (Recommended)

poetry add oguild

Using pip

pip install oguild

🎯 Quick Start

Python Logger

# You can import from either singular or plural forms:
from oguild.logs import logger  # or from oguild.log import logger

# Simple logging
logger.info("Hello, World!")
logger.debug("Debug information")

# The logger automatically detects the module name
# Output: INFO: (your_module_name) == Hello, World! [timestamp]

📖 Full Python Logger Documentation

Python Response Handling

# You can import from either singular or plural forms:
from oguild.response import Ok, Error, police  # or from oguild.responses import Ok, Error, police

# Success response
def get_user(user_id: int):
    user = {"id": user_id, "name": "John Doe"}
    return Ok("User retrieved successfully", user, status_code=200)

# Error handling with decorator
@police(default_msg="Failed to process request", default_code=500)
def process_data(data):
    # Your function logic here
    return processed_data

📖 Full Python Response Documentation

Python Utils

from oguild.utils import encode_json_fields, sanitize_fields

# JSON field processing
data = [{"id": 1, "metadata": {"key": "value"}}]
encoded = await encode_json_fields(data, ["metadata"])

# Data sanitization
clean_data = await sanitize_fields({
    "id": 1, "name": "John", "email": "", "age": None
})
# Result: {"id": 1, "name": "John"} - empty values removed

📖 Full Python Utils Documentation

🔄 Flexible Import Options

OGuild provides flexible import options to accommodate different coding preferences:

Logger Imports

# Both of these work identically:
from oguild.logs import Logger, logger      # Original plural form
from oguild.log import Logger, logger       # New singular form

Response Imports

# Both of these work identically:
from oguild.response import Ok, Error, police        # Original singular form
from oguild.responses import Ok, Error, police       # New plural form

This flexibility ensures that users can import using their preferred naming convention while maintaining full backward compatibility.

🤝 Contributing

We welcome contributions across all planned languages! Please follow these steps:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Development Setup

# Clone and setup
git clone https://github.com/OpsGuild/guildpack.git
cd guildpack

# Install development dependencies
poetry install --with dev

# Run tests
poetry run pytest

Contributing to New Languages

When contributing utilities for new languages:

  1. Create a new directory for the language (e.g., javascript/, go/, rust/)
  2. Follow the established project structure
  3. Include comprehensive tests
  4. Create a dedicated README.md for the package
  5. Update this main README with links to the new package
  6. Ensure consistent API design across languages

📄 License

This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.

🆘 Support

🔄 Changelog

Version 0.2.1

  • 🔄 Flexible Import Options - Added support for both singular and plural import forms
    • oguild.logs and oguild.log - both work identically for logger imports
    • oguild.response and oguild.responses - both work identically for response imports
    • Full backward compatibility maintained
    • Enhanced developer experience with preferred naming conventions

Version 0.2.0

  • 🛡️ Response Module - Universal response handling and error management
    • Framework-agnostic error handling (FastAPI, Django, Flask, Starlette)
    • Smart error classification with specialized handlers
    • Async/sync support with automatic context detection
    • Comprehensive logging and stack trace capture
    • @police decorator for automatic error handling
  • 🔧 Utils Module - Data processing and sanitization utilities
    • JSON field encoding/decoding for database operations
    • Advanced data sanitization with customizable rules
    • Pydantic model integration
    • Type-safe async operations
    • Flexible field processors and mapping

Version 0.1.4

  • Initial release with Python logging utilities
  • Smart logger with automatic formatting
  • Logstash integration support
  • Multi-output logging (console, file, logstash)
  • Automatic module detection
  • Foundation for multi-language utilities pack

🌟 Why OpsGuild Pack?

OpsGuild Pack is designed to solve common development challenges across multiple programming languages:

  • Multi-Language Support - Consistent utilities across different tech stacks
  • Production Ready - Built with enterprise needs in mind
  • Developer Friendly - Automatic configuration and intelligent defaults
  • Extensible - Easy to customize and extend for specific use cases
  • Performance - Efficient utilities with minimal overhead
  • Standards Compliant - Follows best practices for each language
  • Unified Experience - Consistent API design across all supported languages

🎯 Use Cases

  • Microservices Architecture - Consistent logging, error handling, and data processing across services
  • Web API Development - Universal response handling and error management for any Python framework
  • Data Processing Pipelines - JSON encoding/decoding and data sanitization for ETL operations
  • Polyglot Teams - Unified utilities regardless of language choice
  • DevOps & SRE - Standardized operational tools across infrastructure
  • Enterprise Development - Consistent patterns for large-scale applications with robust error handling
  • Database Operations - JSON field processing and data normalization for database interactions
  • Open Source Projects - Reusable utilities for community projects

Made with ❤️ by the OpsGuild team

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

oguild-0.1.10.tar.gz (41.2 kB view details)

Uploaded Source

Built Distribution

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

oguild-0.1.10-py3-none-any.whl (47.7 kB view details)

Uploaded Python 3

File details

Details for the file oguild-0.1.10.tar.gz.

File metadata

  • Download URL: oguild-0.1.10.tar.gz
  • Upload date:
  • Size: 41.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.0 CPython/3.11.13 Linux/6.11.0-1018-azure

File hashes

Hashes for oguild-0.1.10.tar.gz
Algorithm Hash digest
SHA256 a15bae952eeb8cd51b194ae4835c588a91174b63104cf3ad9fd565539f09fe74
MD5 a8178dea4b0922cbdc2874a5b64b5a1c
BLAKE2b-256 11da1dd8eb1fee6cc08882a1ed2d53f8e0c8ee0609cb4aa54070177f6f21e127

See more details on using hashes here.

File details

Details for the file oguild-0.1.10-py3-none-any.whl.

File metadata

  • Download URL: oguild-0.1.10-py3-none-any.whl
  • Upload date:
  • Size: 47.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.0 CPython/3.11.13 Linux/6.11.0-1018-azure

File hashes

Hashes for oguild-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 1fb7e7e3ea71558b17050ba1344c0b69e51345e196f9f4dc4908aa4a6ddbf74a
MD5 8c78f31250a4e6def5df05811a9a0b91
BLAKE2b-256 bb1247661e9ef50326c61edd2f5f53f8e168babd3af704ed1e2c921c6f8d8c6c

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