Skip to main content

No project description provided

Project description

iwf-python-sdk

Python SDK for iWF workflow engine

pip install iwf-python-sdk==0.2.0

See samples for use case examples.

Requirements

Concepts

To implement a workflow, the two most core interfaces are

A workflow can contain any number of WorkflowStates.

See more in https://github.com/indeedeng/iwf#what-is-iwf

Development Plan

1.0 -- the basic and most frequently needed features

  • Start workflow API
  • Executing wait_until/execute APIs and completing workflow
  • Parallel execution of multiple states
  • GetWorkflowResultsWithWait API
  • StateOption: WaitUntil(optional)/Execute API timeout and retry policy
  • Get workflow with wait API
  • Timer command
  • AnyCommandCompleted and AllCommandCompleted waitingType
  • InternalChannel command
  • DataAttribute
  • Stop workflow API
  • Improve workflow uncompleted error return(canceled, failed, timeout, terminated)
  • Support execute API failure policy
  • Support workflow RPC
  • Signal command
  • Reset workflow API
  • Skip timer API for testing/operation

Running iwf-server locally

Option 1: use docker compose

See iwf README

Option 2: VSCode Dev Container

Dev Container is an easy way to get iwf-server running locally. Follow these steps to launch a dev container:

  • Install Docker, VSCode, and VSCode Dev Container plugin.
  • Open the project in VSCode.
    cd iwf-python-sdk
    code .
    
  • Launch the Remote-Containers: Reopen in Container command from Command Palette (Ctrl + Shift + P). You can also click in the bottom left corner to access the remote container menu.
  • Once the dev container starts, iwf-server will be listening on port 8801.

How To Contribute

This project uses Poetry as a dependency manager. Check out Poetry's documentation on how to install it on your system before proceeding.

❗Note: If you use Conda or Pyenv as your environment / package manager, avoid dependency conflicts by doing the following first:

  1. Before installing Poetry, create and activate a new Conda env (e.g. conda create -n langchain python=3.9)
  2. Install Poetry (see above)
  3. Tell Poetry to use the virtualenv python environment (poetry config virtualenvs.prefer-active-python true)
  4. Continue with the following steps.

To install requirements:

poetry install

Update IDL

Initialize the IDL Git submodule

git submodule update --init --recursive

Update IDL to the latest commit.

git submodule update --remote --merge

Generate API client from IDL

This project uses openapi-python-client to generate an API client from the IDL. To update the generated client:

mkdir iwf/iwf_api/iwf_api
cd iwf && poetry run openapi-python-client update --path ../iwf-idl/iwf-sdk.yaml --config .openapi-python-client-config.yaml
cd .. && cp -R iwf/iwf_api/iwf_api/* iwf/iwf_api && rm -R iwf/iwf_api/iwf_api && poetry update

The last command will:

  • Fix the api package path
  • Update the local path dependency.

Linting

To run linting for this project:

poetry run pre-commit run --show-diff-on-failure --color=always --all-files

Code of Conduct

This project is governed by the Contributor Covenant v 1.4.1. (Review the Code of Conduct and remove this sentence before publishing your project.)

License

This project uses the Apache 2.0 license. (Update this and the LICENSE file if your project uses a different license.)

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

iwf_python_sdk-0.4.1.tar.gz (69.4 kB view details)

Uploaded Source

Built Distribution

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

iwf_python_sdk-0.4.1-py3-none-any.whl (161.8 kB view details)

Uploaded Python 3

File details

Details for the file iwf_python_sdk-0.4.1.tar.gz.

File metadata

  • Download URL: iwf_python_sdk-0.4.1.tar.gz
  • Upload date:
  • Size: 69.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.9.21 Linux/6.8.0-1020-azure

File hashes

Hashes for iwf_python_sdk-0.4.1.tar.gz
Algorithm Hash digest
SHA256 14d4926642e21cc53b8b36232bf636d4052b36f599b7914e0b4d861f89ce83e6
MD5 301c4a772fdface04f3fd574ea4374de
BLAKE2b-256 b7bb2292f8b78f932a3d53405a9eb591f93bdb40c63ec05315f3682a415c32df

See more details on using hashes here.

File details

Details for the file iwf_python_sdk-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: iwf_python_sdk-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 161.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.9.21 Linux/6.8.0-1020-azure

File hashes

Hashes for iwf_python_sdk-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ace488f2775ad7d0f6308fdd9e1f43edaef18b33d762a6f35e050c0edd0b4c66
MD5 d37e7faaed1d83f93448a12dac6dc564
BLAKE2b-256 2844bf59bedd872f7c5bcc9ced11a78f34fd8530af96a9457c5fb2ef6cc89030

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