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

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.0-cp313-cp313-manylinux_2_31_x86_64.whl (905.2 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.0-cp313-cp313-macosx_14_0_arm64.whl (633.5 kB view details)

Uploaded CPython 3.13macOS 14.0+ ARM64

bosa_core_binary-0.5.0-cp313-cp313-macosx_13_0_x86_64.whl (711.7 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.5.0-cp312-cp312-win_amd64.whl (598.2 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.0-cp312-cp312-manylinux_2_31_x86_64.whl (905.9 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.0-cp312-cp312-macosx_14_0_arm64.whl (632.1 kB view details)

Uploaded CPython 3.12macOS 14.0+ ARM64

bosa_core_binary-0.5.0-cp312-cp312-macosx_13_0_x86_64.whl (707.7 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.5.0-cp311-cp311-win_amd64.whl (597.8 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.0-cp311-cp311-manylinux_2_31_x86_64.whl (815.5 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.0-cp311-cp311-macosx_14_0_arm64.whl (625.3 kB view details)

Uploaded CPython 3.11macOS 14.0+ ARM64

bosa_core_binary-0.5.0-cp311-cp311-macosx_13_0_x86_64.whl (698.2 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 7642b4ae4de035347d64d71f6880e70012ebba995b0095e05ce4b6dcae8f37a1
MD5 69540c5428a3fce18274a1e253ac6e3a
BLAKE2b-256 6ccbee0684f7348981f5b5e5464725409773c445dc30610833aa6f56d994ffa6

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 e3bdbc4196f9492079e245c140cf73d50a9740c7f1318141f2f187687b62517f
MD5 73d1c3058b958fb2ef8621f244cba581
BLAKE2b-256 86e00d55997388a3512e929a5931e8969779ec6ff3934d24a2bc6cd7c7e8b144

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.0-cp313-cp313-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp313-cp313-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 ccf26fc5c10fc83a5e4ee18b06352da0bb98ab88d1dbd43881a5a55d0f95e087
MD5 7096ef5dd13a7769ccba02baf7b1a259
BLAKE2b-256 5b2ad4edd4be2d8135bd19ef4aaeff10e4c9b080984ad5197c18f7c561c5a529

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.0-cp313-cp313-macosx_14_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.0-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 ba8244d1a60c310d6a9ae6d2a8cfcd2c6cd727a12d6934db6b74aaa828df3632
MD5 c0ad6ce437d1cbb9865e235e50a208d5
BLAKE2b-256 07ddf64fdca8ab503c27ccdcb1a2b839a72db408f34e8083c9dac700ba1c9f43

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 997d6d5f7c64c379c6f67bdd05a7e5ba4a76f5810fa5d0605ff21b6ef1735243
MD5 9fc08ec78a1b640c7e6bd635d64145c9
BLAKE2b-256 e51d9831635c3de51ea4484485c4bf73e37b0a343fc1ab6aedccf8b8c0fe581b

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 9550a65455089a8811d56d43f2e9a3b649b3bfb47fceb8a5137dbb66046cf854
MD5 2f6d706498714d20e1ad65096cf49d4b
BLAKE2b-256 929dd0b8d30760bb6ce01a7f184424cebe840c2b7d74e592af8210a6071d8ea8

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.0-cp312-cp312-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp312-cp312-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 8ad34f7f901fddbfef9a4ec94e6d5005c03966bffa65328cf6a1d74696b511ed
MD5 8add12e48373df45cd5fac4fa292b9fd
BLAKE2b-256 24cace050e4dab81b6b3730d3119a09ce1705ad7b3c04ff185c1cc4b81fecdd1

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.0-cp312-cp312-macosx_14_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.0-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 6e9899bf1910804d8dde6a7868b24f12c2cc80de894e9d66b5f544292bf16983
MD5 fed0c397dbe7dab4b5d42c61f29ce379
BLAKE2b-256 696f54b2439c8c6b022fe6eddd56d0d4807dc42ada3ffa8f41dbdc73fa2f62e9

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 3e33c983d00666b174d6ca9d132881de5f98223c2ef5acc7417df6dbdb0244a7
MD5 bf9c03bdcab88c1fe28dfb78c4581c06
BLAKE2b-256 f9e273bce97e61806beeb61150af6eb52a0cd4f578862534285e2c3e9b900a49

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 9017b47d134980b25b2692cec89a271113fdafd2523c83b65ee9a9acbe0cf7a1
MD5 2d962cbc9cb04c44e45afadf8b29ff3a
BLAKE2b-256 48d20b21d190e497092677b7a97fed8b7b45e30ce861e960730ac8454f38fe3a

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.0-cp311-cp311-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp311-cp311-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 6c199ffb0872e8868187309bdad179acb34fdb134202f6b8a5fbc7cca5b21a29
MD5 ceafccbd246c723f024b8ec6e0d2fdf8
BLAKE2b-256 8844cfe75ade750b376ce99332821dc382f6aa2db2cd5b9e9c98f825ff9b928f

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.0-cp311-cp311-macosx_14_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.0-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.0-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 562ff652a6532e000bf3f1356aaf15107d9b05ff9f2d38c7ff53b8da498116d2
MD5 5bdcb608a15973f2b27a3683052f89c9
BLAKE2b-256 f04ab1183688764da39bd5aca020da9da0120cee8ef8740976fd7e5af072118b

See more details on using hashes here.

Provenance

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

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