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

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.9.2b2-cp313-cp313-manylinux_2_31_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.9.2b2-cp313-cp313-macosx_13_0_x86_64.whl (907.5 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.9.2b2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (758.0 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.2b2-cp312-cp312-win_amd64.whl (739.7 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.9.2b2-cp312-cp312-manylinux_2_31_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.9.2b2-cp312-cp312-macosx_13_0_x86_64.whl (905.7 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.9.2b2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (754.1 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.2b2-cp311-cp311-win_amd64.whl (746.2 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.9.2b2-cp311-cp311-manylinux_2_31_x86_64.whl (991.9 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.9.2b2-cp311-cp311-macosx_13_0_x86_64.whl (882.4 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.9.2b2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (737.6 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 159f6a211c0e9125f16afd3b510efbf2e03ccd353c1b946a6645a8fb2fda1fc1
MD5 107c69237d37a86e84cb88235e992d43
BLAKE2b-256 20908f1226e15cc712e1af0bdd944535b1e3a0af8e616e8d5f0c3b2faecb371d

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 48fad4fca3d39b3045706aa779dcca703ea88196ffede90050dbd2e1ee1d3100
MD5 27071cceaa6bd2bf17709591b4610484
BLAKE2b-256 60ee88ca60ab067e4b7c56be20216fe6e2f6e50417459ccfeb3ca15fb193f964

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 7430a69b1d64da64b83de0de67b1eec8fafd20a70bef852d9210a6d88667ec30
MD5 8f3cd66fbd61d166baafba4eada480c6
BLAKE2b-256 00b10738baa78b21eeb2e6b11565a8f26b9f3c8da2f4742ee9a01f7c5c269c5d

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 4582f968d7a971ecbe7677256fdec81db30321d5f7c6cea35e40a7b199fa2713
MD5 ae6185b726ad5f79d3071d682f830174
BLAKE2b-256 783c06e83964639d5aa40994bc826f9d215e1f97547390b7c656a3cccd2d5df2

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 224ca7e220a26294dc3efb1f6561294a55f3441a8a3596473e314b345023cb8a
MD5 7bc35fbefa26dd84adc8dba7a2156fb0
BLAKE2b-256 41aae77eff5f01d191c021168a5b0ebc20afa2095f172410c6904c62e08c7771

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 0ade414f10a5ea4004a1889da7a5bcf82e9769aa709725e9d023b8c18b52ab65
MD5 72b7949178cadc7cc246542574685583
BLAKE2b-256 20d333d044a64c8062644a4fc7cf385206f88f8f077236e6590922148ad6dd7f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 92879f5d117fd0400e6193f9707e3b97b5f43e8126989706884a6589146ce822
MD5 6084a19df35ca3d8cb37459d1aff0086
BLAKE2b-256 89d8b142f526bebd6e784cd70cab3173ed45e75f42f700732b853ccde0006493

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 61375d9b43c92498b36edbb93b86eb98730854c190fcaab54b40a75305210584
MD5 902f21fe010c2ad6f20b3c588abd332b
BLAKE2b-256 dab825036ff28adc85838ebf77b355b4be291e4469afe8c4d7ffcffff451adc4

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 718cde2b053266208e9998deab55fc5ecd72298c285faa224f649e873cfd445e
MD5 a66fd51536cf41df8029796510272834
BLAKE2b-256 5751f99c504926c6fe8d913ab725b5c1dc6a8f5e0aa2a1f9d8d9220da497f97a

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 0e4a97501074e8c490d2ac5b3310eba65bcc9f1e3ec3e421fc22a2b4d23a61bc
MD5 ebf96e138fab35efa443249bba3e4b9f
BLAKE2b-256 76ecc60fe05c7405aab7bf6b0cc476091c5dd5f9a6d0397c247e3940cd7d4927

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 9180259b7b9aaa8616a376d483306d29370cae14a5f9a65d349fd4067de1bb94
MD5 9d6b14ee5b7ba8c92563007a02c7b4dc
BLAKE2b-256 0286196b7b5370f8c66c8c57fd2189c41d1c01234891b6c8d54960c60530878c

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 b70617f7a007fec60fea85de1985e19a342b31131a0f8a03278983b4cd1c883f
MD5 11752a26ed72f03fd4f56e989c266161
BLAKE2b-256 94bddb2ae7a3cf54efe3b1dab60042f1684214c64f830408ffe46a3005d945b3

See more details on using hashes here.

Provenance

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