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

Uploaded CPython 3.14Windows x86-64

fabricatio_core-0.3.34.dev1-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.34.dev1-cp314-cp314-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.14manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.34.dev1-cp314-cp314-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.14macOS 11.0+ ARM64

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

Uploaded CPython 3.13Windows x86-64

fabricatio_core-0.3.34.dev1-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.34.dev1-cp313-cp313-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.34.dev1-cp313-cp313-macosx_11_0_arm64.whl (4.9 MB view details)

Uploaded CPython 3.13macOS 11.0+ ARM64

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

Uploaded CPython 3.12Windows x86-64

fabricatio_core-0.3.34.dev1-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.34.dev1-cp312-cp312-manylinux_2_34_aarch64.whl (4.8 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ ARM64

fabricatio_core-0.3.34.dev1-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.34.dev1-cp314-cp314-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp314-cp314-win_amd64.whl
Algorithm Hash digest
SHA256 460e29918291d53b08f7fd6b7dd9e55dcee4205143af0a1f6b6af4c1ee7f51ab
MD5 4f417f6f079b12321e006df8f9687742
BLAKE2b-256 79905c878f191530b37e30e5ffcf89d675960ea129a60b5964b0c9f214cca2ef

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp314-cp314-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp314-cp314-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 79fa6a112b1f46f485bf20489e0abce6bd3cc48c9a12c91649d95833ec0c6200
MD5 4ebb7fee34a2759185e1f3091c9593b6
BLAKE2b-256 fc6b2f898ac7390b7145fb01994bccb85a952b8dc22fd2779e88681ca67a166b

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp314-cp314-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp314-cp314-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 fa9d02df5b775c807f6a2a6d9d29fdd84ff986f7a41a66413de6fd2fa7b107c9
MD5 0df7a7deaab1c3366100c6ecdf879cc5
BLAKE2b-256 65e21a0416fe124b2067525b789ac53ab2412c719d361a0bac1bd0b0ab863009

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp314-cp314-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp314-cp314-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 06fd06ff8e945b056e90bc6f23faa9676fe0c2938e2cf5bd0602b25359fce222
MD5 a6577deb613e835ae2a150ef9263ed60
BLAKE2b-256 a2c995de425d6dff49a97a8c1ebcfed52fa81566acedb61b4392a5798c9ff2da

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 b71934e46b8cb4d3c6f56ebc8fa0a39f3d2939899a3be6cd107a9df4f6d62270
MD5 df4aa9f54c6ad4f07cde97112ebe893f
BLAKE2b-256 4006452fa96d0a60860464091ab2a95ec0d643763316fa0d09a42a1f753cc18b

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 0426403f8c3bac7083f4d18c80469f9799c3f0a580f6f0765ea95a94adc302ca
MD5 d0e4ea3e4f635a1e383403fbca480552
BLAKE2b-256 229149f0f6003f650e2bdfd29f968ac2d29c2ee96fb9c1438180a4825a57c163

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp313-cp313-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp313-cp313-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 a662e20891c431b71b0b408d8521bbedd2339b5267f399ba18a3377c05844bb1
MD5 2f7aa686b8640ebe6535bae024fc8a9c
BLAKE2b-256 7eabcb9ec63ec18a857588d530f7fa4e2637a4f7e1a94d48456ff1d42053437a

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp313-cp313-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp313-cp313-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 5f43c44d5f6f450c564acb32e3fdcd29047bc8d45bf575a35efa04d7dbee8ff1
MD5 336e3e66df245c10af4b08b0639d1fcd
BLAKE2b-256 8414cdbef0afb82fa786c7cf5237bafc2e4897ee984d203df61e3d73963770c2

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 6778fd0b8f28331be2c598732c60d5efc26d06aeebac54dd43118ebe4f3b7f13
MD5 42c8fe6a41c24e4ddd96903fdc20dfb9
BLAKE2b-256 b37692d73673896726c84845e53969b1b84d8f05b0e3f9014d2c889bfecc3571

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 f5d3ef234924d38665b0c66f26716434800c8ec149e8553ccdb4cf8c159ab2be
MD5 0f289c0616ebc9ae153dc62964364a76
BLAKE2b-256 8dacaa7052b34621f81a25fa727b8833b02711ecd42205df5e66c07d642f0265

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp312-cp312-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp312-cp312-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 d497692ac3787db199821ebbd94c7fbc38827df571b38c339b183a7609e9232e
MD5 cb22e93d45386a690c5ed22052996335
BLAKE2b-256 4254807faaea793668ecfa4d780c9a0fce161c93d2dc192bf23f82639dea8cc8

See more details on using hashes here.

File details

Details for the file fabricatio_core-0.3.34.dev1-cp312-cp312-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for fabricatio_core-0.3.34.dev1-cp312-cp312-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 8e1149359a6fc5f6a1f88c9abb26bbcb0a5bee6396a87851f1f1d0b7c184a449
MD5 cab5f37d026ec53ef52b408bc7ebf5dd
BLAKE2b-256 d9c966d828a5c95874e1adcc769c929da0c863795f4dc52ca62422dbe7c3e023

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