Skip to main content

BOSA Core Library

Project description

BOSA Core

BOSA Core is a flexible plugin-based architecture that allows you to build modular and extensible applications. It provides a robust framework for managing plugins, handling dependencies, and injecting services.

Key Features

  • 🔌 Plugin-based Architecture
  • 💉 Dependency Injection
  • 🔄 Service Registry
  • 🛠️ Flexible Plugin Handlers
  • 🌐 HTTP Interface Support
  • 📊 OpenTelemetry Integration
  • 🛡️ Sentry Error Tracking
  • 📜 Logging

Installation

Prerequisites

1. Installation from Pypi

Choose one of the following methods to install the package:

Using pip

pip install bosa-core-binary

Using Poetry

poetry add bosa-core-binary

2. Development Installation (Git)

For development purposes, you can install directly from the Git repository:

poetry add "git+ssh://git@github.com/GDP-ADMIN/bosa-sdk.git#subdirectory=python/bosa-core"

Plugin Architecture Overview

Plugin Architecture

How It Works

  1. Plugin Manager: The central piece that orchestrates everything

    • Manages plugin lifecycle
    • Handles service registration
    • Initializes plugins with required dependencies
  2. Service Registry: A container for all services

    • Stores service instances
    • Handles dependency injection
    • Maps service types to their implementations
    • Note: You don't need to create your own Service Registry - it's integrated into the Manager!
  3. Plugin Handler: Interface for providing services to plugins

    • Creates service injections through create_injections
    • Initializes plugin-specific resources
    • Can be extended for different types of plugins (e.g., HTTP handlers)
  4. Plugin: Base class for all plugins

    • Has basic metadata (name, description, version)
    • Receives injected services automatically
    • Can be extended with specific functionality
  5. Open Telemetry: Initializer class to use open telemetry

    • Integrates with OpenTelemetry for tracing and metrics
    • Provides observability for plugins and services
    • Can be configured to export data to various backends (e.g., Jaeger, Prometheus)
  6. Sentry: Initializer class to use sentry

    • Integrates with Sentry for error tracking and performance monitoring
    • Captures exceptions and sends them to Sentry
    • Provides insights into application performance and errors

Authentication

BOSA Core provides a robust, multi-tenancy authentication system, allowing secure client and user management.

  1. Client Management:

    • Clients are created using a Master Key (BOSA_WHITELISTED_KEYS).
    • Each client has a unique API key used for authentication.
    • API Key Format: sk-client-<base64-client-id>.<base64-client-name>.<client-secret>.
    • Clients can manage their users and authentication settings.
  2. User Authentication:

    • Clients create users by providing an identifier.
    • Each user receives a secret, which is displayed only once.
    • Users authenticate using their identifier and secret.
    • User API Key Format: sk-user-<base64-user-id>.<base64-user-identifier>.<user-secret>.
  3. Token-Based Access:

    • Upon authentication, users receive JWT tokens for secure access.
    • Tokens are verified for subsequent requests.
    • Tokens expire after 30 days (default: 43,200 minutes).
    • Tokens can be revoked when necessary.
  4. Third-Party Integrations:

    • Users can create integrations with third-party services.
    • Authentication credentials are securely stored.
    • Each integration can be assigned scoped access.

For detailed implementation, refer to the Authentication README.

Implementation Details

The plugin system works through these key components:

1. Plugin Manager

from fastapi_interface import FastApiHttpInterface

# Create FastAPI handler
fastapi_handler = FastApiHttpInterface()

# Initialize manager with the handler
manager = PluginManager(handlers=[fastapi_handler])
manager.register_plugin(MyPlugin)
  • Initializes the plugin system
  • Manages plugin lifecycle
  • Handles service registration

2. Plugin Handler

from bosa_core.plugin import PluginHandler

class MyHandler(PluginHandler):
    @classmethod
    def create_injections(cls, instance):
        # Tell the manager what services this handler provides
        return {MyService: instance}

    @classmethod
    def initialize_plugin(cls, instance, plugin):
        # Initialize plugin resources
        pass
  • Creates service mappings via create_injections
  • Initializes plugin resources
  • Can be customized for different plugin types

3. Plugin

from bosa_core.plugin import Plugin
from fastapi_interface import FastApiService

class MyPlugin(Plugin):
    # Services will be injected automatically
    fastapi_service: FastApiService

    def __init__(self, name, description, version):
        super().__init__(name, description, version)
  • Base class for all plugins
  • Receives injected services
  • Can be extended with custom functionality

4. Open telemetry external exporter (enable fastapi & langchain instrumentation)

from bosa_core.telemetry import OpenTelemetryConfig, FastAPIConfig, init_telemetry
from fastapi import FastAPI

endpoint = "your-exporter-endpoint"
port = "your-exporter-port"
attributes = {
   "key1":"val1"
}
app = FastAPI()
use_langchain_instrumentation = True
fastapi_config = FastAPIConfig(app=app)
otel_config = OpenTelemetryConfig(endpoint=endpoint, port=port, attributes=attributes, fastapi_config=fastapi_config, use_langchain=use_langchain_instrumentation)
init_telemetry(TelemetryConfig(otel_config=otel_config))

5. Sentry

from bosa_core.telemetry import SentryConfig, init_telemetry

def traces_sampler(sampling_context: dict) -> float:
    """Determine appropriate sampling rate for Sentry transactions.
    Args:
        sampling_context: Context dictionary containing transaction information
    Returns:
        float: Sampling rate between 0 and 1
    """

    ### you can use customization (ex: for certain name sampler will be 0.1) for trace_sampler in this class
    return 1.0


dsn = "your-dsn"
environment = "development/staging/production"
release = "your release tag"
sentry_config = SentryConfig(
        dsn=dsn,
        environment=environment,
        release=release,
        traces_sampler=traces_sampler,
        send_default_pii=True,
    )
init_telemetry(TelemetryConfig(sentry_config=sentry_config))

6. Sentry with Open Telemetry (enable fastapi & langchain instrumentation)

from bosa_core.telemetry import SentryConfig, init_telemetry, FastAPIConfig, OpenTelemetryConfig
from fastapi import FastAPI


def traces_sampler(sampling_context: dict) -> float:
    """Determine appropriate sampling rate for Sentry transactions.
    Args:
        sampling_context: Context dictionary containing transaction information
    Returns:
        float: Sampling rate between 0 and 1
    """

    ### you can use customization (ex: for certain name sampler will be 0.1) for trace_sampler in this class
    return 1.0


dsn = "your-dsn"
environment = "development/staging/production"
release = "your release tag"

attributes = {
   "key1":"val1"
}
app = FastAPI()
use_langchain_instrumentation = True
fastapi_config = FastAPIConfig(app=app)
opentelemetry_init = OpenTelemetryConfig(attributes=attributes, fastapi_config=fastapi_config, use_langchain=use_langchain_instrumentation)

sentry_config = SentryConfig(
        dsn=dsn,
        environment=environment,
        release=release,
        traces_sampler=traces_sampler,
        send_default_pii=True,
        open_telemetry_initiliazer=opentelemetry_init
    )
init_telemetry(sentry_config=sentry_config)

7. Logging Ner API Handler

from bosa_core.logger import init_ner_pii_logging_handler

init_ner_pii_logging_handler(logger_name="logging-name", api_url="https://dev-api-gdplabs-ner-api.obrol.id/anonymize", api_field="text", pii_ner_process_enabled=True)


logger.info("contoh nomor ktp 3525011212941001\ncontoh email john.doe@example.com\ncontoh nomor telepon +628121729819 dan 0812898029384.\ncontoh npwp 01.123.456.7-891.234" ) # if you using gdplabs ner API output will be contoh nomor ktp <ID_KTP_1>\ncontoh email <EMAIL_ADDRESS_1>\ncontoh nomor telepon <PHONE_NUMBER_1> dan <PHONE_NUMBER_2>.\ncontoh npwp <ID_NPWP_1>

[!WARNING] If you are using Logger Ner API handler, the logging process may take some time because it needs to call an API for every log entry synchronously.

8. Logging Regex Handler

from bosa_core.logger import init_regex_pii_logging_handler

init_regex_pii_logging_handler(logger_name="logging-name", pii_regex_process_enabled=True)


logger.info("contoh nomor ktp 3525011212941001\ncontoh email john.doe@example.com\ncontoh nomor telepon +628121729819 dan 0812898029384.\ncontoh npwp 01.123.456.7-891.234" ) # if you using gdplabs ner API output will be contoh nomor ktp <ID_KTP_1>\ncontoh email <EMAIL_ADDRESS_1>\ncontoh nomor telepon <PHONE_NUMBER_1> dan <PHONE_NUMBER_2>.\ncontoh npwp <ID_NPWP_1>

Getting Started

  1. Install dependencies:

    poetry install
    
  2. Create a plugin:

    class MyPlugin(Plugin):
        name = "my-plugin"
        description = "My awesome plugin"
        version = "1.0.0"
    
  3. Register and use:

    # Using FastAPI as an example
    from fastapi import FastAPI
    from fastapi_interface import FastApiHttpInterface
    
    app = FastAPI()
    fastapi_handler = FastApiHttpInterface(app)
    manager = PluginManager(handlers=[fastapi_handler])
    manager.register_plugin(MyPlugin)
    

Development

  • Use Poetry for dependency management
  • Install pre-commit hooks poetry run pre-commit install. This will run checks before each commit.
  • Run ./build.sh to perform all checks:
    • Code formatting and validation (ruff)
    • Documentation style (pydocstyle)
    • Tests (pytest)
    • And more!

References

Product Requirements Documents(PRD):

  • N/A

Architecture Documents:

Design Documents:

Implementation Documents:

Project details


Release history Release notifications | RSS feed

This version

0.5.1

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

bosa_core_binary-0.5.1-cp313-cp313-win_amd64.whl (638.7 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.1-cp313-cp313-macosx_11_0_universal2.whl (674.0 kB view details)

Uploaded CPython 3.13macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1-cp313-cp313-macosx_10_13_universal2.whl (752.2 kB view details)

Uploaded CPython 3.13macOS 10.13+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1-cp312-cp312-win_amd64.whl (639.7 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.1-cp312-cp312-macosx_11_0_universal2.whl (672.6 kB view details)

Uploaded CPython 3.12macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1-cp312-cp312-macosx_10_13_universal2.whl (748.2 kB view details)

Uploaded CPython 3.12macOS 10.13+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1-cp311-cp311-win_amd64.whl (643.8 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.1-cp311-cp311-macosx_11_0_universal2.whl (665.9 kB view details)

Uploaded CPython 3.11macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1-cp311-cp311-macosx_10_9_universal2.whl (738.7 kB view details)

Uploaded CPython 3.11macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file bosa_core_binary-0.5.1-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 b6ad89ce466e213b91fe48c8872b24a821a953acadbb03f0763840a2351c553a
MD5 800959ccbab8b2b6c7096d68c3921d2d
BLAKE2b-256 14d8a9e9c6d1fbc854f16d7422487a7d2906d649ed05f12be5278d657902284e

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp313-cp313-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp313-cp313-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 3e99c3da7165b66d5029e166535e146bf5efa2741b8ea4e9ac249bb35f82b935
MD5 5c694f24043423b6095ee20c5ee30667
BLAKE2b-256 f65d548b7a1972f2409800db632e15bdabe9af67a86250b44276c45a31f31755

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp313-cp313-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp313-cp313-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp313-cp313-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 c79853831097cd511d448bca5adc63ef7449677e7d6282ed96cf16f69be1ed88
MD5 21df49ead816ec7ecc9c6a629d3625fc
BLAKE2b-256 5930ed1701d03b1d544c5f5da8234b116a83cc380b3f1bd0c69daaea7bbf40c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp313-cp313-macosx_10_13_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 46aa345b4f0be5f330dea4754b5be619f72e898ba234bbeebc97b8c6c2f7f668
MD5 f2f79a53d38832140afec31f14d1967a
BLAKE2b-256 5bfad79db64b0d7479547edf6a22cfa199e9f77b04c28b687048255652728b6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp312-cp312-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp312-cp312-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp312-cp312-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 5630f0dae6b3161f34a407fd382785e233d91baf4788d1f4ef8b4880c0f3b81a
MD5 ce63b174524b31dfba9ee27973f4f13d
BLAKE2b-256 1601e223fd7e394a20171cde4668139acd08e1c3325197df7f37323ee3acdb33

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp312-cp312-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp312-cp312-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp312-cp312-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 bfe188f397f6d3011fd7e9761beeb1b9d535a108bfc6c8a82ce703d1b75f6fc4
MD5 744742c42c438328b09847c00c11ff7b
BLAKE2b-256 0c0981d49b670f901faa02550ee6af22ddbd77b04eb614cc4e3e7ad6857dd2b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp312-cp312-macosx_10_13_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 6a65054e3dbb521f923ff2fadc0bf2aae640f46ae9800cb122536be7b301477b
MD5 bdfb4a2288a7de051a5f07b44043d2e9
BLAKE2b-256 52a5b47d2243cfc9b736886cf49516edfa544dda277dd1487b4132cdc4da9be3

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp311-cp311-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp311-cp311-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp311-cp311-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 29a80a214416ea07b644b8227c969899c8ec27233f0e918f80f07d1e45351096
MD5 da109181be6ad8d3aec6089d8faaaa70
BLAKE2b-256 37581282d0c37291355e505ca8dd09e7b4d58071c43efd29b09bc46640381427

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp311-cp311-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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

File details

Details for the file bosa_core_binary-0.5.1-cp311-cp311-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1-cp311-cp311-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 05e3a8ad973df6121b06e73a1799a634a49c6c704cf2bd1a9a08e5e112b294b0
MD5 0c995a69dcce37334631553f041160b4
BLAKE2b-256 f4aede95695c1ab3697fe003eb1ef590de058a49b9e16c626a9d0166995ccd6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1-cp311-cp311-macosx_10_9_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

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