Skip to main content

A foundational Python library providing core components for building LLM-driven applications using an event-based agent structure.

Project description

fabricatio-core

A foundational Python library providing core components for building LLM-driven applications using an event-based agent structure.

📦 Installation

This package is part of the fabricatio monorepo and is available as a single package:

pip install fabricatio

🔍 Overview

Provides essential tools for:

  • Event-based architecture patterns The event-based architecture patterns in this library enable a reactive programming model. Events are used to trigger actions and communicate between different components of the application. For example, when a certain condition is met, an event can be emitted, and other parts of the application can listen for this event and respond accordingly. This pattern helps in building scalable and modular applications.
  • Role-based agent execution framework The role-based agent execution framework allows for the definition of different roles for agents in the application. Each role has specific permissions and responsibilities, and agents can be assigned to these roles. For example, in a multi - user application, there could be roles like 'admin', 'user', and 'guest', each with different levels of access to resources and functionality.
  • Task scheduling and management The task scheduling and management feature is responsible for organizing and executing tasks in the application. It can handle task dependencies, prioritize tasks, and ensure that tasks are executed in the correct order. For example, in a data processing application, tasks like data ingestion, transformation, and analysis can be scheduled and managed using this framework.
  • File system operations and content detection This feature provides functionality for performing file system operations such as reading, writing, and deleting files. It also includes content detection capabilities, which can identify the type of content in a file, such as text, image, or binary data. For example, it can automatically detect the encoding of a text file or the format of an image file.
  • Logging and diagnostics The logging and diagnostics feature helps in monitoring the application's behavior and troubleshooting issues. It can record important events, errors, and warnings in a log file, which can be used for debugging and auditing purposes. For example, if an error occurs during the execution of a task, the log can provide detailed information about the error, including the stack trace and the values of relevant variables.
  • Template rendering and configuration handling The template rendering and configuration handling feature allows for the use of templates to generate dynamic content and manage application configuration. Templates can be used to generate HTML pages, emails, or other types of documents. Configuration handling ensures that the application can be easily configured with different settings, such as database connections and API keys.
  • Type-safe data models for common entities The type-safe data models for common entities ensure that the data used in the application has a well - defined structure. These models are based on Pydantic, which provides type validation and serialization capabilities. For example, in a user management application, a data model can be defined for the 'User' entity, with attributes like 'name', 'email', and 'password', and Pydantic can be used to validate the input data and ensure that it conforms to the defined model.
  • Asynchronous execution utilities The asynchronous execution utilities enable the application to perform tasks asynchronously, which can improve the performance and responsiveness of the application. For example, in a web application, asynchronous I/O operations can be used to handle multiple requests simultaneously without blocking the main thread. This feature uses Python's asyncio library to implement asynchronous programming.

Built on a hybrid Rust/Python foundation for performance-critical operations.

🧩 Key Features

  • Event System: Reactive architecture with event emitters and listeners The event system is the core of the event - based architecture. Event emitters are responsible for generating events, and event listeners are registered to listen for specific events. When an event is emitted, all the registered listeners are notified, and they can perform their respective actions. For example, in a game application, an event emitter can be used to emit an event when a player scores a goal, and event listeners can be used to update the scoreboard and play a sound effect.
  • Role Framework: Agent roles with workflow dispatching capabilities The role framework defines the different roles that agents can have in the application. Each role has a set of permissions and a workflow associated with it. When an agent is assigned a role, the workflow dispatching capabilities ensure that the agent follows the correct sequence of actions. For example, in a project management application, a 'project manager' role may have a workflow that includes tasks like creating a project plan, assigning tasks to team members, and monitoring progress.
  • Task Engine: Status-aware task management with dependencies The task engine is responsible for managing tasks in the application. It keeps track of the status of each task, such as 'pending', 'in progress', or 'completed'. It also handles task dependencies, ensuring that tasks are executed in the correct order. For example, in a software development project, a task to test a module may depend on the completion of the coding task for that module.
  • Toolbox System: Callable tool registry with rich metadata The toolbox system maintains a registry of callable tools in the application. Each tool has rich metadata associated with it, such as its name, description, input parameters, and output format. This metadata can be used to discover and use tools in a more efficient way. For example, in a data analysis application, a tool for calculating statistical measures can be registered in the toolbox, and other parts of the application can use this tool by providing the appropriate input parameters.
  • Type Models: Pydantic-based models for consistent data structures The type models are based on Pydantic, which provides a way to define and validate data structures. These models ensure that the data used in the application is consistent and conforms to the defined schema. For example, in a financial application, a type model can be used to define the structure of a transaction, including attributes like 'amount', 'date', and 'description', and Pydantic can be used to validate the input data and ensure that it is in the correct format.
  • File Utilities: Smart file operations with content type detection The file utilities provide a set of functions for performing file system operations. They include features like content type detection, which can automatically identify the type of content in a file. This can be useful for handling different types of files in a more intelligent way. For example, when reading a file, the file utilities can determine if it is a text file or a binary file and handle it accordingly.
  • Template Engine: Handlebars-based template rendering system The template engine uses the Handlebars library to render templates. Templates are used to generate dynamic content by replacing placeholders with actual values. For example, in a web application, a template can be used to generate HTML pages with dynamic content like user names and product information. The Handlebars syntax allows for easy customization and reuse of templates.
  • Language Tools: Language detection and text processing utilities The language tools provide capabilities for detecting the language of a text and performing text processing tasks. Language detection can be used to determine the language of a user - input text, which can be useful for providing language - specific services. Text processing utilities include functions for tasks like tokenization, stemming, and part - of - speech tagging, which can be used for natural language processing applications.

📁 Structure

fabricatio-core/
├── capabilities/     - Core capability definitions
├── decorators.py     - Common function decorators
├── emitter.py        - Event emission and handling
├── fs/               - File system operations
├── journal.py        - Logging infrastructure
├── models/           - Core data models
│   ├── action.py     - Action base classes
│   ├── generic.py    - Base traits (Named, Described, etc.)
│   ├── role.py       - Role definitions
│   ├── task.py       - Task abstractions
│   └── tool.py       - Tool interfaces
├── parser.py         - Text parsing utilities
├── rust.pyi          - Rust extension interfaces
├── utils.py          - General utility functions
└── __init__.py       - Package entry point

📄 License

MIT – see LICENSE

GitHub: github.com/Whth/fabricatio

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.

fabricatio_core-0.3.33.dev0-cp314-cp314-win_amd64.whl (5.0 MB view details)

Uploaded CPython 3.14Windows x86-64

fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_x86_64.whl (5.4 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.34+ x86-64

fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.33.dev0-cp314-cp314-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.14macOS 11.0+ ARM64

fabricatio_core-0.3.33.dev0-cp313-cp313-win_amd64.whl (5.0 MB view details)

Uploaded CPython 3.13Windows x86-64

fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_x86_64.whl (5.4 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ x86-64

fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.33.dev0-cp313-cp313-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.13macOS 11.0+ ARM64

fabricatio_core-0.3.33.dev0-cp312-cp312-win_amd64.whl (5.0 MB view details)

Uploaded CPython 3.12Windows x86-64

fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_x86_64.whl (5.4 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ x86-64

fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.33.dev0-cp312-cp312-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.12macOS 11.0+ ARM64

File details

Details for the file fabricatio_core-0.3.33.dev0-cp314-cp314-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp314-cp314-win_amd64.whl
Algorithm Hash digest
SHA256 41a9d79153b4022be1d520694f76802b6c0cd4d8e84d3a863864828009fa49e7
MD5 c848e763deaa67965dde303074fb8d6a
BLAKE2b-256 f7e8708465c861c6775f3a0ee48df6e658b01325866fa98141a82e6f9b2c8b1b

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 b9edb14a18bc57dfbc6fb7193a20ab69db14d2684c652b264a2fb3789f113365
MD5 e08b80112519f7e3f8ce0f4ac18303ca
BLAKE2b-256 023f77c01043f0e5fb27e521deab6bda5c078daa4ec83e4b9b9375f90eedd9a7

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp314-cp314-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 214c002bb16b618200e29c1f3a1c13673c16423e44e0aaf590b4bc7908a7a0ef
MD5 4dca9615ee6c48fa9305bd1b4104fc9b
BLAKE2b-256 717c50dac80fb4d0ecdc0611e0b90240e010da955323bed5949ac33f06a2da22

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp314-cp314-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp314-cp314-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9c917875bd1ac656e2f33fcf50266c62d3a8a41e51f7bfbc1f3027d8a7153211
MD5 52ff784abf0de515192a7b1c1641be91
BLAKE2b-256 c7e97bca76456be196eaa6f449b30824b5ba3f63d85467d4aeedcd04cec53521

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 7ca4d74e6eb57220f98092ee2a516eb13e283f2887c041172edd4a8cd96fcf4f
MD5 9ef48bb0eae307d6455ed43cadfece6a
BLAKE2b-256 c2cf50bda83ceb1a8b93cd0d8724f9a6e024c5f2c2a0f5f448f31443a9390923

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 7620aa6ce5295c590c610a631ebf6f596637ce438a352812533aa7d773c1a467
MD5 c458771b5b1260b1c455ea4c2941b5f1
BLAKE2b-256 1dd2fa421f2639cbc06bb42f24e3cb8b5f40b654f232b2541ec453fda77884c5

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp313-cp313-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 8559a6a5ff58cc04525616feac59ddcd95a1663fc75bacfde13b93c3e3023a15
MD5 f567adf28f632ba3c35b8645736746aa
BLAKE2b-256 15be09bcc9793a7b12438ba0f35c57bb953b7c10bfeef00c2773991fa66522c8

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp313-cp313-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp313-cp313-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 532834852c3e69afbe7e28fed61651296d21f2c13bd94ec57459a41057b1fd1f
MD5 65970d21f2527b4329331b3c228055e6
BLAKE2b-256 53d42c0649568de67fdc597da1992bfdbfa578a30ec3df23749a5f1f805ac469

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 6d13587118591e960ecc1c79405d3b9a71cd9438c460b33128444849e1ff9a3f
MD5 031ff42f71c108211c427973c5948628
BLAKE2b-256 299caaab68336e92501d6bf9a8f8ccd95f5fd4b194924976d2b8c3aa8b3324cf

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 bed7bfbc00f6785a969bc7f60839702c030f5773c15abd009d61f8636e1eace2
MD5 307426da59098f67b7549b29eaef25c0
BLAKE2b-256 a93d92af15534d67d88f382868ed78508ebf74ccb60f367ae33f63513bf11a84

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp312-cp312-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 b9f2f6befc4929fc61bf98e4b21b207f262b9de26ae6f196d3e80eb28be697d4
MD5 772874d39456d1a1790d42471921357a
BLAKE2b-256 e3fc26605315d45c9fda40ea45dde3ab2790d492f1e3f20b41445e91a571f812

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.33.dev0-cp312-cp312-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33.dev0-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 83c5798cd6dd06a019d80c3b15b4da6844831cd1ada8c87e89aeef5a75d87ca5
MD5 bfb964f651b435bb7c7c591d7947adb0
BLAKE2b-256 44e9cc6ed9206eaae1b10bea25a4edc9a7e78d18581cd6c6cf0fe09cd12cdf17

See more details on using hashes here.

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