Skip to main content

An AI Agent IaC tool that aims to make developing and deploying AI Agents easier.

Project description

woodwork-engine

PyPI - Version PyPI - Python Version PyPI - Installs License GitHub Stars

Welcome to woodwork-engine, an AI Agent IaC tool that aims to make developing and deploying AI Agents easier.

Through defining components in a configuration language, an LLM will decompose the task into actionable steps, which can be executed using the supplied tools. We use latest research to inform design decisions, and we implement this as most of the setup is copy/paste across projects. Through only focussing on the necessary components of a system, this package should make designing custom, vertical agents much easier.

Table of Contents

Features

  • A custom config language, woodwork (.ww files), allowing agent components to be declared
  • Integrations and communication between components are handled
  • Additional customisation or extension can be provided by implementing some of our interfaces

Screenshot 2025-01-01 160031

A roadmap is provided with details on future features.

Installation

  1. Run pip install woodwork-engine: This gives access to the woodwork CLI tool, along with the ability to parse and deploy AI Agent components from .ww files
  2. Install the Woodwork extension on VSCode if relevant: This provides syntax highlighting and intellisense for code in .ww files

Usage

  1. Begin by duplicating the .env.example file and placing it in your project's root directory
  2. Rename the file to .env (ensure this is part of your project's .gitignore so that it isn't committed)
  3. Depending on the .ww configuration file, populate the .env file with your corresponding keys

See the .env.example file for further details.

Once you've configured your .ww config file and your .env file, there are two ways to run woodwork: A standalone application, or used as a dependency.

Standalone Application

  1. Create a main.ww file and write some code: This file is where component declarations are read from. For some inspiration, consult the examples
  2. Run woodwork init: This installs the necessary dependencies to run your components
  3. Run woodwork: This activates the components and initializes a logger

As A Dependency

When using woodwork as a dependency, you will need to build your own logger implementation. Not building your own logger will result in no logs being generated but the application will still run.

  1. (Optional) Create a ./config directory: This is where the logging configuration will live.
  2. (Optional) Copy the log_config.json into your ./config directory: This configures your logger
  3. In your file you'd like to utilize woodwork in, add from woodwork import __main__ as m
  4. See dev-main.py for how to build your logger and configure calling woodwork

Developer Setup

If you are interested in contributing, the following steps are used to activate a developer environment.

  1. Install pre-commit if needed via pip install pre-commit
  2. Run pre-commit install [--hook-type pre-push] to run linting and formatting before commiting or pushing

Available Arguments

You can pass arguments to woodwork. For more details, see woodwork --help.

Argument Options Default Notes
--mode run, debug, embed, clear run Debug is deprecated, use Run instead. If using a workflow, you must use embed or clear.
--init none, isolated, all none
--workflow none, add, remove, find none If specifying a workflow, you must provide a target.
--target String "" Defines the target for the workflow. For add workflows, specify the file path to the workflow. For remove workflows, specify the workflow ID. For find workflows, specify the search query.
--version N/A N/A Prints the current version of Woodwork. Note: this will override any other arguments.

When calling your script, you can pass argument to the script as long as they do not conflict with woodworks arguments.

Logging

In log_config.json, you can set the desired logging levels for stdout and the generated log file. Do this by editing the respective level property in the json for the respective handler. Options include the standard logging levels: DEBUG, INFO, WARNING, ERROR, CRITICAL.

You can monitor the log file during execution by opening a terminal and entering tail -f logs/debug_log.log (or your custom log file name if modified in the log_config.json)

Examples

For some examples, consult the examples folder. ENV variables are denotes by a '$', place a .env file in the same directory as the main.ww file and populate it with the necessary variables.

Contributing

To view the contributing guide for woodwork, the CONTRIBUTING.md file in the meta repository contains more information. We would love your help! Additionally, if you prefer working on other projects aligned with language servers or web development, woodwork-language and woodwork-website could be worth taking a look at.

License

woodwork-engine uses a GPL license, which can be read in full here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

woodwork_engine-0.2.10.tar.gz (48.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

woodwork_engine-0.2.10-py3-none-any.whl (63.5 kB view details)

Uploaded Python 3

File details

Details for the file woodwork_engine-0.2.10.tar.gz.

File metadata

  • Download URL: woodwork_engine-0.2.10.tar.gz
  • Upload date:
  • Size: 48.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for woodwork_engine-0.2.10.tar.gz
Algorithm Hash digest
SHA256 e3b38741fa940fceed49030d84b8e872863fc9817e0729350601838843e28b99
MD5 7359f41a59c22ac4ec1418341cd23b68
BLAKE2b-256 f6382269013e8380ad87fce9c0254c87155571a8336a8af96f11cec40b1983d1

See more details on using hashes here.

File details

Details for the file woodwork_engine-0.2.10-py3-none-any.whl.

File metadata

File hashes

Hashes for woodwork_engine-0.2.10-py3-none-any.whl
Algorithm Hash digest
SHA256 cdc9db4bf4e85a8389b6df0bd441cb938f5f6ce39b9ecc365acf94eb9e5f863b
MD5 8869fe274e12c73549fa1c46f82c2fea
BLAKE2b-256 50f75513b5e82aecb26e42993bca676437aebf92b902474d298e25e0cbf2e3df

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