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

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.1b5-cp313-cp313-win_amd64.whl (638.7 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.1b5-cp313-cp313-manylinux_2_31_x86_64.whl (950.6 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_x86_64.macosx_15_0_x86_64.whl (731.6 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64macOS 15.0+ x86-64

bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (637.3 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

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

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.1b5-cp312-cp312-manylinux_2_31_x86_64.whl (951.4 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_x86_64.macosx_15_0_x86_64.whl (728.0 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64macOS 15.0+ x86-64

bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (636.3 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

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

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.1b5-cp311-cp311-manylinux_2_31_x86_64.whl (861.0 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_x86_64.macosx_15_0_x86_64.whl (719.9 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64macOS 15.0+ x86-64

bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (619.7 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 c0f8e87b955e014e78fed975facbc7773d59930d60f80aa659e19462e24b13e3
MD5 b4df30366cbeafa058c5d4b2f1497f32
BLAKE2b-256 65e78ade340b031e8a681f56272e528bf5ea0c2bf2a5129a976df6c7928e676b

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 63de7ab0c636b69401b992bc98664c51cd4cd60145f4a2e4864ed4f622052c48
MD5 72544152d04237abfad1a6970e4fc142
BLAKE2b-256 08388447b8aeaa73fd165bda8bf581157f92a3624954721bee45205c8d558568

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_x86_64.macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_x86_64.macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 1d653b4e7c8548a34f1cbea1caa814583ff94f38575d84e3a71c1cd5af3d79e2
MD5 55aa7777eccbfa389e6c0856682fb6e6
BLAKE2b-256 b3bc056397e01c49f378a54b19749195c7181df923b0a2f139a8ed2ae7adf2c1

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_x86_64.macosx_15_0_x86_64.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.1b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 2d784dc2e06b1a39094f6a135e7b02b90a716f0a28cef5ae573010888bf01654
MD5 f4b7f8b89e53066fdb8c9ec0b5bed5b8
BLAKE2b-256 eb2ca662bc04e84138c0d0156dc7026232c0162c4b244861b010e5d97430715b

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.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.1b5-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 c676877c466eeba7dd001ca7513c4a9ebd81fc53739c26add29011b7320947a0
MD5 f5aa502c107cbd4ffc35e08c400f8874
BLAKE2b-256 4bec5ff6b8dcb37b00972b55fbfbc093ba3f59adeeca13b0a16c83116acd6403

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 8dedb7b9c33733e24fa5d893f59ef77e3baeb4c344ad3adfdcf235701f48b050
MD5 617ee8310d1e11bdca33e832c92dc030
BLAKE2b-256 64d7e1b13f4e59a22e423a5c4f791970cf9434db19aef1b98c48fdba9e7ba180

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_x86_64.macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_x86_64.macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 6a14330ff41cd616411f6336dd8bfd5923b6d3938dda0e1f98ea13b7af229e1c
MD5 844d9d2a59ef06921abde05653db5c5e
BLAKE2b-256 ea8082ec653bf559f8fd0b6364f058b9a8ce4e89f1548b653be6e0f4b2c5c6f4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_x86_64.macosx_15_0_x86_64.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.1b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 302d6cec3ebd71519c2daf1d92cfa3bd53fc8020dd6dca16b4cedb0eb93563b4
MD5 4a56140755de21c8bcc668b1c4f60471
BLAKE2b-256 558c1f66aea317e3b903a06ba025532fbe8a0540db71efa24e5a4ef45157b0e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.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.1b5-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 cd514b64325eba40e46bc45be6033ae0d698c20e9b0faf8b3b7013fd98324966
MD5 7d5cc34dd0a1171be7a1d2c6f5f8a72c
BLAKE2b-256 3e351447b983f701d1f06779cb1437d16f7785adf5418f8a3a07201deb6aae39

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 be9647c393979f60e6670c9f02e6f6356bcb7ad5e858b0af21c12ae79fed0326
MD5 244f8543e0a559278b3f3cab0e739397
BLAKE2b-256 20c4e7efb173606da5fbab839dd11ebe40e4f3c5247e2784b115600e09446083

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_x86_64.macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_x86_64.macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 47f937b8d9b9955b5fc7fe708d175e9eb8daf7ed34b1529407c567b662972dd5
MD5 3fc8d1fd5a98bf0a07080b6c3a7231b0
BLAKE2b-256 1186091dee840a6f8fa7d2cfcf174561dd7fe37298a13323ce31f4c5df345c38

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_x86_64.macosx_15_0_x86_64.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.1b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 6b068845a84ccfaf2acd9a2f43686505b1fef5e743e7fb836ddf5798199725a6
MD5 a541d94a984fbd93eedcfd688cf9bd65
BLAKE2b-256 0e1c0be2deea9ef307113c345807211997897d19a4036c15db3f2b0fdcadc4bf

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.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