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-cp314-cp314-win_amd64.whl (5.0 MB view details)

Uploaded CPython 3.14Windows x86-64

fabricatio_core-0.3.33-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-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-cp314-cp314-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.14macOS 11.0+ ARM64

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

Uploaded CPython 3.13Windows x86-64

fabricatio_core-0.3.33-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-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-cp313-cp313-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.13macOS 11.0+ ARM64

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

Uploaded CPython 3.12Windows x86-64

fabricatio_core-0.3.33-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-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-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-cp314-cp314-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp314-cp314-win_amd64.whl
Algorithm Hash digest
SHA256 17a5b0a5dccbecd06d978d91c52ab035560952da63b942e3c671789e6b926ed8
MD5 eb008c851d2e4a328a2ac83838a746cd
BLAKE2b-256 d9e7cd8a99b39ae1bb0f6062e9cf7bc0fa86cb6279d985849090ebfd48d71b90

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp314-cp314-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 85c471b6d8fe1713e4935adfb85fff4163d7a6e1f1393df38a07a5545df43d69
MD5 c23d3b37aac700d60e7058f98f39462d
BLAKE2b-256 4a50bfc7f5dbd6f4c85cb1c032911a1d1c0beac3bf23982d5a18d1dc4ee8aa1d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp314-cp314-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 e52cf50ddb56df268848392217b918681084ff47f7c66cca0776bdcc0908d747
MD5 82c1cbaf467b29f934ae94a873f1be7d
BLAKE2b-256 e343bba6b2f6209012cb644fbccd145217d8776a15f7741fd4ef3b10e24da98e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp314-cp314-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6ddd428442de37f7ee2b5255831338eaca52381c74203012eb94d467fac54c34
MD5 2c0229155e6148ff45b96135c9912875
BLAKE2b-256 0a61c66e8bdcc8ac3692c97c53aa99eec69d7545ff32bc773b374e2f5bcc385a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 ecbffa4a8ba2da4950c65dd3c7be380ca209dfab2459ca8f444c2548f3824061
MD5 f24a0ad1bf7ef29453ae34fa9c0552f7
BLAKE2b-256 96ac1ccffb9fce247cfcd24de28b8aa00317770edeadf77926f07bef774c8023

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 3da40b9986b2b630bdde7d0ba6dfd517e3feb3739b6f678c35bf0226d5c9ed6c
MD5 91582eca1425c067d81743b9ddfcde97
BLAKE2b-256 ea8881fe24bd8eead5fba80c67b536c5700e885a8847c0c427bea8387fa13c36

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp313-cp313-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 119c0085aecd0204267bc6728d04b6e6f52c09dbe04dd07aa58f9d1d743138c9
MD5 63febabbe98829eb5c6ac38b2c4a889c
BLAKE2b-256 9c9768e2af575cb590c5b6a92b39f17bd76f4eee25f8784e1477327fed130d21

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp313-cp313-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 08d84bedd4476ad30b4b4aada89cdef9fee0eb8f2b0bb02eab5ac6fef63dcd3f
MD5 10af44006d142a4c0738a8c27d95ab0e
BLAKE2b-256 8c283a1a4494d88f64b180f17564c85cb687418a2af3785b5ac1c793c303d160

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 84f526e007c803861310385370a5ee74fc6656ca059569676764070ab8aebf35
MD5 fa6cb803427aa9c68907b9d1ab704e83
BLAKE2b-256 9ab3c5e11b731cac1e1edd055ec378eacec9d1cd6243e0e12473571b5d88a620

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 9738d7f356e3c0ec894f2c9b841dd208fff242ec42d01499f93070d2971834ab
MD5 8cb542cc329f457ba3f0f6055c7259c4
BLAKE2b-256 8f0a8784728b0ea949ff7d65de6aa28474ac982174fd947e29b0adf1c0ceb67a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp312-cp312-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 acb288f5408c0d9825adff1053c374b7f89e3957c29751928deea35c90849d6d
MD5 1813a736efb143619c56c2d488c0690f
BLAKE2b-256 4fed055456c751efac415d31a5753349edc639588d289cec7ad7818b43879774

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fabricatio_core-0.3.33-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 90033f4d677b07bd60a46c889482cddb0bdc5d68a39a9aaf7bf5fb5452359578
MD5 89b53b2903f503324d890eaa90f57b11
BLAKE2b-256 00520e95195ae000a9041cc4f450eb5efb218f7cb6f055d55666d85f82135170

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