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.9.0b3-cp313-cp313-win_amd64.whl (731.1 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.9.0b3-cp313-cp313-manylinux_2_34_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.0b3-cp313-cp313-macosx_13_0_x86_64.whl (900.6 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.9.0b3-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (750.1 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.0b3-cp312-cp312-win_amd64.whl (736.0 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.9.0b3-cp312-cp312-manylinux_2_34_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.0b3-cp312-cp312-macosx_13_0_x86_64.whl (897.9 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.9.0b3-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (747.3 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.0b3-cp311-cp311-win_amd64.whl (741.4 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.9.0b3-cp311-cp311-manylinux_2_34_x86_64.whl (979.7 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.0b3-cp311-cp311-macosx_13_0_x86_64.whl (873.8 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.9.0b3-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (730.4 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

Details for the file bosa_core_binary-0.9.0b3-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 9c2a6f3c7029a6d8ccadc240f8d35284396a537ba5c7f3be71e1f685f3649edc
MD5 64215d2365f019c7ee65fe836893525f
BLAKE2b-256 dc4d44315eb592f624739eaad569661251267b573b325a17aad8fd65fd661ad4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 7e27a5886873bc14f09efe64da2b9b8aa41c50c003bec008dbf220aff5b72b4e
MD5 75ef0879b8f10a9b0d3e807a62c6e717
BLAKE2b-256 0be574c9e5967d5242415967bdb5c1b8280418bfbca6267328872466d5c50d0c

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.0b3-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 3d0ceeb13854776af4cac19d5a37590b9b8743ba282f044ffaf2ab0016b49261
MD5 150da8065e38bc905b3e30b6315a3795
BLAKE2b-256 d94e45d26afbf37ba420be0d0e1e75dcedd35440de9aee4a2021f67394366c9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 7ccfa405786960cb7be56b6b797f62dc55efa271d9b40e03cc06d3094ebe89e4
MD5 0956b109ff977222c48bb611e765be70
BLAKE2b-256 d18fa60c515f7c3f192703dd25095e64045af0d2994b14cb508521691a5a3159

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 203b80db9f535f529537de7dc5f43301e266871a20e8f9412db80a0e44fb5ca5
MD5 86a2d510b066c0dd2f67a10a4a5500e8
BLAKE2b-256 97ae757f3645f0b3ce5754d90ac1db9e6474967beedbd7eb5de5b050e6aa234c

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 f20b09da46baec151e1dfee1e39689ee4d7cd8c7e3a2d3efd932309403b253bc
MD5 e8c2785b293890d908e3e1b8d5f766e5
BLAKE2b-256 ab5859e6b39b8a7232382b88ded19414f63cc2f152226a0bd29609decaa83fe9

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.0b3-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 aed2677da0c0fd5e1123fb429f1672f9395d89eab0101d7cbd2653cad1adbb8c
MD5 aae91de1d382ed204450e3fe9411db76
BLAKE2b-256 4f52e1f3740cf2dc895796517b93a1937f63048ed1a93b4e06d5ba025e7c8f4a

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 c8bd3ca9769b6853b299433ee48dbddc7f6bcfa03d629ac183fd43f1fc96f1b8
MD5 3160152b53299096d7205318e9c4a6c1
BLAKE2b-256 0eb3fb541859500e2be96433f3064986d4223f3a4c7a943d721f8d93edc99f2a

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 9316103b7c18ce6cfa31b518c1afdb71ed4aa7050fddd83c87e4bb4a51f05d68
MD5 c92e401c8c728b77c9b78b74d129f38c
BLAKE2b-256 bb66b2ba63632405666286b06725dbbb79cbf90ba99281cc834b914083a15a79

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp311-cp311-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp311-cp311-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 f2c7cf221b4d01c80ff93c5fd9070eca06945937b0d0c7f8e5b309ba2502c70c
MD5 e6c5da47fae805a0fecaf2ea07fad8ce
BLAKE2b-256 8623acb88331a0565ffa43218493a5e3f64e93372a4b23658ba8c497ad533cd6

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.0b3-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 afdec4a3e39729b46cd061bdf2397bea8cd4a88733ff1d74b767c414caae84b7
MD5 fdd921c163e20b10d45b8568f1c860f8
BLAKE2b-256 4f2c95697871043aa40862ff0b69785e47b9fe4fb5b12639777b4a15c9b8fe84

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.0b3-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.9.0b3-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.0b3-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 728f800c83975fc5767576648162febb6b522ba04d28c33354e8a6bb63c22c0d
MD5 362804d3073ddf919e7eebaf1571b4b4
BLAKE2b-256 7f9efeba4ae8ec231063d466d795ba7257846b3b7fe25163d180b34da9f8f8fb

See more details on using hashes here.

Provenance

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