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.4b2-cp313-cp313-win_amd64.whl (642.1 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.4b2-cp313-cp313-manylinux_2_31_x86_64.whl (955.5 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_0_x86_64.whl (759.4 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (640.7 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.5.4b2-cp312-cp312-win_amd64.whl (646.1 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.4b2-cp312-cp312-manylinux_2_31_x86_64.whl (956.1 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_0_x86_64.whl (757.4 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (639.8 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.5.4b2-cp311-cp311-win_amd64.whl (646.7 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.4b2-cp311-cp311-manylinux_2_31_x86_64.whl (865.5 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_0_x86_64.whl (744.8 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (624.1 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

Details for the file bosa_core_binary-0.5.4b2-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 db436d74c3422699997c7a63fd8e95b08e91efcd93b8fd6eeeb384ed7328dcea
MD5 fd921a13851ca5bdfcd623238d8ce00a
BLAKE2b-256 bdfc0796005752f7d259f7ba25395b8dbdeb5c915bd60cae263de376eecaf98f

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 e177af2a113447a8974a0f8cc4187c50ecf9e5ed3faa756b8fcd4aa4e4eea309
MD5 50f81d6d82a3f754bd2eb43e5c4f0605
BLAKE2b-256 aca303899b419cd5719cfc97e888ac2fb0756a9c4e3a2aaba0183e35dbcb528c

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 546e6092e4664fd7fa3857452381b9d1a47ad61b3d8fe79d228fbf3776546961
MD5 e851ccdebca9404c73dc5d133af975f9
BLAKE2b-256 7a8f6db7c14707a26ccc9fc9cd951a717d355aeb4865675e7820e80713b40c4c

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_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.4b2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 5ad8349deef7aab08c875a8f9b2a599e877f02a7c7a9831196890de4336302a3
MD5 f908a9cd7fa7a3527c5724036f173f26
BLAKE2b-256 e85673eb4a394fd2e59f84823b0a4e3614505c5eaf8b2e927a63312356bb4860

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 a0cdbbe80c9b7ed097b36f516fe30dd2cbe7ec4128133df1d22556329bd5b593
MD5 0e038a80ee0539126a3bccef01ed7a5e
BLAKE2b-256 638ca340e04cf3129261898e1ed74393dda3854ab5cd8c6ce1d5744d8f0557e5

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 b34ee79c9d550c69caa3029b1a5a70e02ba1dcbfc99b66d3294b3726286dc0aa
MD5 7470c9752a5752f2f607f8d3357dba03
BLAKE2b-256 d5c5dfe56e66b0f30dd90ecc7c826ed3ee1c78c169b3524dbbc3eed9f892feb9

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 563114b110744ab5695241f4e73e9ff2264e5df508dfeb7426c8f6f3578b4d73
MD5 b8cbe0e1c681fe19e7722f77cd0ac691
BLAKE2b-256 315a09445d57af9a25b2d38fbde27f6eb1e8c8c9e518a284827ded81078bd5d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_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.4b2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 c14e0509a5c01c90210d43d22aeb8029428ac3cc8de79db8a63909c9929916a3
MD5 6f111f818b0013107ea17b761a7cdfe2
BLAKE2b-256 00b9f43c0ee69aa0792014d241c9e45263d118a596e0b5896dfbdd6ea0ce6861

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 cb6533bdd2130335b0d75a21fa6eb13c54c9999dc09ed2920789d0ad404a2787
MD5 618ec9cc737a75ac87125e37bfd4a666
BLAKE2b-256 d736865947606c37b302faec47a2835b923bf81cfd9544b444b0b2b6424d3976

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 1ad3da95f0235c8a315e199f1161e6e56d75ef2d8bbf831746f2b32b5aed12dc
MD5 082754102c1cb9b6c4b1f2a0f627f604
BLAKE2b-256 a915de0022028116e40408881500127e8b4736a3c862624e0e97dc467130cb34

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 d6558baa13ef846a8db42dc64b25e2ec3d9ed8df3d28254d3e8601c89466ad52
MD5 bfa4bdedceb81b1d580b1345eb2b1d40
BLAKE2b-256 e5302bbaa074209f111ac3ee9cdfef8a8401bbc61456f90ae501c6d04308a920

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_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.4b2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.4b2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 713d091bbd3573c53b8c1c622e9598412bc64454d1b317a82e23ecf9462602fa
MD5 b27719afebbad3b762183e01545dacca
BLAKE2b-256 f690eb51042e024b39b793895ce225c232a739b511035e5de47fe4c823d6beb9

See more details on using hashes here.

Provenance

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