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.2

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.2-cp313-cp313-win_amd64.whl (639.6 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.2-cp313-cp313-manylinux_2_31_x86_64.whl (951.6 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.2-cp313-cp313-macosx_11_0_universal2.whl (675.2 kB view details)

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

bosa_core_binary-0.5.2-cp313-cp313-macosx_10_13_universal2.whl (754.5 kB view details)

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

bosa_core_binary-0.5.2-cp312-cp312-win_amd64.whl (640.7 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.2-cp312-cp312-manylinux_2_31_x86_64.whl (952.2 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.2-cp312-cp312-macosx_11_0_universal2.whl (674.2 kB view details)

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

bosa_core_binary-0.5.2-cp311-cp311-win_amd64.whl (644.5 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.2-cp311-cp311-manylinux_2_31_x86_64.whl (861.8 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.2-cp311-cp311-macosx_11_0_universal2.whl (667.7 kB view details)

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

bosa_core_binary-0.5.2-cp311-cp311-macosx_10_9_universal2.whl (740.9 kB view details)

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

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 ea27c5ab818ffe78f100ed1d9adde2ea31c3190065853454fe6d0f6ccbaaeb29
MD5 c06cabe49135dcf0e937cd40c0137681
BLAKE2b-256 9e4b6d5f78ba02aad82a231110bfd6e8ace890318f21ff7c64ade360494e9a12

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp313-cp313-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 7c2a0db4c6fa0e770aec557f351cff763163b8ad51622657569baa6b78bc893d
MD5 50e7f4af069c9be7f23b9d83fd0a09eb
BLAKE2b-256 c3ea333b02dcaadd80f6e4c232b150b891a002dd61962f66733c71a1725bdbc2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 9c696646816c9483fcb7f12d3a909a4f1ba86650d4b5aca8063e5f4055bf16fa
MD5 5cbe917c14f87ed04161b9e8c8df4c0e
BLAKE2b-256 39d180a2bf915655cf3424f2d4bb1c4dc2044f7e93c14caa2b5a6d367530d8af

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp313-cp313-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp313-cp313-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 1d87b21c2f70b3666f0abd09ed0f02e039012d5fe0aa104bb37468bd50e42795
MD5 5d43958531073898a0f879b1b919f67a
BLAKE2b-256 41cd0b0ed49326e850ea8769fb27932de0ff1f2aae02daecb421b955eb8c070c

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 c0eccbebbe1a34a87739afe5d40557452938aa75a0156882a8df2b4c698af4e0
MD5 ec2a8a8667e3ca26f6e7799b506ad8da
BLAKE2b-256 08ead16677b6ca571c05a5c73128721d007fd5ce62baba2f2fe1cb8d8fdb39d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp312-cp312-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 7f9fb8fc06d351d90a411063e953cf3b3a380f6fed312d287cd07022d9394f3e
MD5 a072017bb2efb7815ff0bc1210cb8174
BLAKE2b-256 9f84fb1773770e279fa766b9ad1ac872b768de7d7e3aff3606afdc6caaefba64

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp312-cp312-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 f16df176ed9a96a99f68e9d31c74bc22f48b401701bc8723bdf29a728b181cb4
MD5 aec9bfb19842ab2e4264eaa13dc906a5
BLAKE2b-256 a123f3915eabb821cefdb7f690de5b7309a87831de810d7eb2ffe8bf6dd76fc2

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 3b27b875f2f5ea296bf3607b6add9dfa0a0cbdf23b056f7bb703a500feeba36f
MD5 ecfe6c89ffa1af317485fbbd9754f93e
BLAKE2b-256 908f38c32218b23da23cc9da26e46f5e68a2248cb03177675f451082b6fdfd94

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp311-cp311-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 4fe3189d5c666a5bcc2344dac1ae11a55bfc14b08d90d8918189c6f7186efd62
MD5 01a526530553974b66f8d95cc962d603
BLAKE2b-256 1527bf1f7fe3185af8c87d49d347bec9c90823d91f13dd07e992da2cb7ccd8b8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp311-cp311-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 2887defb4c662ccd370d274e712187939617cfde8cd35eea65d884edc9317c39
MD5 d988fce29212cef7e31e504f9be0be6e
BLAKE2b-256 aebfedc7de057cef77730374106834c140e90ee83e895d708ed107b492de20b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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.2-cp311-cp311-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.2-cp311-cp311-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 dfa6e4847018d6b9e260073ed76a91561aaf0c94efd3902e6d1b7f48de17bdc0
MD5 7c99ad9ccf3ca253704ebd341ddae8c6
BLAKE2b-256 7cdfc839a4c73a44ae48ca9ab2ac69c334160d603cd68d8e78d725ac488d3e51

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.2-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