Skip to main content

Open source machine learning framework to automate text- and voice-based conversations: NLU, dialogue management, connect to Slack, Facebook, and more - Create chatbots and voice assistants

Project description

Taskflow Python-SDK

Join the chat on Taskflow Community Forum Build Status Coverage Status PyPI version

Python SDK for the development of custom actions for Taskflow.


💡 We're migrating issues to Jira 💡

Starting January 2023, issues for Taskflow Open Source are located in this Jira board. You can browse issues without being logged in; if you want to create issues, you'll need to create a Jira account.


Installation

To install the SDK run

pip install taskflow-sdk

Compatibility

taskflow-sdk package:

SDK version compatible Taskflow version
1.0.x >=1.0.x

old taskflow_core_sdk package:

SDK version compatible Taskflow Core version
0.12.x >=0.12.x
0.11.x 0.11.x
not compatible <=0.10.x

Usage

Detailed instructions can be found in the Taskflow Documentation about Custom Actions.

Docker

Usage

In order to start an action server using implemented custom actions, you can use the available Docker image taskflow/taskflow-sdk.

Before starting the action server ensure that the folder containing your actions is handled as Python module and therefore has to contain a file called __init__.py

Then start the action server using:

docker run -p 5055:5055 --mount type=bind,source=<ABSOLUTE_PATH_TO_YOUR_ACTIONS>,target=/app/actions \
	taskflow/taskflow-sdk:<version>

The action server is then available at http://localhost:5055/webhook.

Custom Dependencies

To add custom dependencies you enhance the given Docker image, e.g.:

# Extend the official Taskflow SDK image
FROM taskflow/taskflow-sdk:<version>

# Change back to root user to install dependencies
USER root

# To install system dependencies
RUN apt-get update -qq && \
    apt-get install -y <NAME_OF_REQUIRED_PACKAGE> && \
    apt-get clean && \
    rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*

# To install packages from PyPI
RUN pip install --no-cache-dir <A_REQUIRED_PACKAGE_ON_PYPI>

# Switch back to non-root to run code
USER 1001

Building from source

Taskflow SDK uses Poetry for packaging and dependency management. If you want to build it from source, you have to install Poetry first. This is how it can be done:

curl -sSL https://install.python-poetry.org | python3 -

There are several other ways to install Poetry. Please, follow the official guide to see all possible options.

To install dependencies and taskflow-sdk itself in editable mode execute

make install

Code Style

To ensure a standardized code style we use the formatter ruff. If your code is not formatted properly, GitHub CI will fail to build.

If you want to automatically format your code on every commit, you can use pre-commit. Just install it via pip install pre-commit and execute pre-commit install.

To check and reformat files execute

make lint

Steps to release a new version

Releasing a new version is quite simple, as the packages are build and distributed by GitHub Actions.

Release steps:

  1. Switch to the branch you want to cut the release from (main in case of a major / minor, the current release branch for patch releases).
  2. If this is a minor / major release: Make sure all fixes from currently supported minor versions have been merged from their respective release branches (e.g. 3.3.x) back into main.
  3. Run make release
  4. Create a PR against main or the release branch (e.g. 1.2.x)
  5. If this is a minor release, a new release branch should be created pointing to the same commit as the tag to allow for future patch releases, e.g.
    git checkout -b 1.2.x
    git push origin 1.2.x
    

License

Licensed under the Apache License, Version 2.0. Copyright 2021 Taskflow Technologies GmbH. Copy of the license.

A list of the Licenses of the dependencies of the project can be found at the bottom of the Libraries Summary.

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

taskflow_sdk-3.10.1.tar.gz (49.5 kB view details)

Uploaded Source

Built Distribution

taskflow_sdk-3.10.1-py3-none-any.whl (64.3 kB view details)

Uploaded Python 3

File details

Details for the file taskflow_sdk-3.10.1.tar.gz.

File metadata

  • Download URL: taskflow_sdk-3.10.1.tar.gz
  • Upload date:
  • Size: 49.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.14

File hashes

Hashes for taskflow_sdk-3.10.1.tar.gz
Algorithm Hash digest
SHA256 71810287e8877ea8fab59ec45706bf7bc8102a6f63b847be896a2a14d0f4fb49
MD5 ab975f0de7574b06266990c27717da18
BLAKE2b-256 c7ebeffc9941da6843143bb7fb04c9e1f3f628bfc7226e2fade3f5b28a09c1a6

See more details on using hashes here.

File details

Details for the file taskflow_sdk-3.10.1-py3-none-any.whl.

File metadata

File hashes

Hashes for taskflow_sdk-3.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 152dfded1f6accf458f61d74b687c8150e616db6ff01f9ed07b5ac66c62f3bd6
MD5 1c39dffe888e4abce859eed75f83df6f
BLAKE2b-256 fc047cd6d45577c20e0d1519dbc3f82c01ae6ca61fd49859a476473546b10210

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page