Metadata-Version: 2.1
Name: sfini
Version: 0.1.0
Summary: Create, run and manage AWS Step Functions easily
Home-page: https://github.com/EpicWink/sfini
Author: Laurie
Author-email: laurie@sitesee.com.au
Maintainer: Laurie
Maintainer-email: laurie@sitesee.com.au
License: MIT
Project-URL: Documentation, https://sfini.readthedocs.io/en/latest/
Project-URL: Source, https://github.com/EpicWink/sfini
Project-URL: Bugs, https://github.com/EpicWink/sfini/issues
Keywords: aws sfn service step functions states
Platform: UNKNOWN
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Natural Language :: English
Classifier: Operating System :: POSIX :: Linux
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: MacOS
Classifier: License :: OSI Approved :: MIT License
Requires-Python: ~=3.6
Description-Content-Type: text/markdown
Requires-Dist: boto3
Provides-Extra: dev
Requires-Dist: moto ; extra == 'dev'
Requires-Dist: pytest ; extra == 'dev'
Requires-Dist: pytest-cov ; extra == 'dev'
Requires-Dist: pytest-timeout ; extra == 'dev'
Requires-Dist: sphinx ; extra == 'dev'
Requires-Dist: sphinx-rtd-theme ; extra == 'dev'

# sfini
[![Build Status](
https://travis-ci.org/EpicWink/sfini.svg?branch=master)](
https://travis-ci.org/EpicWink/sfini)
[![codecov](
https://codecov.io/gh/EpicWink/sfini/branch/master/graph/badge.svg)](
https://codecov.io/gh/EpicWink/sfini)
[![Documentation Status](
https://readthedocs.org/projects/sfini/badge/?version=latest)](
https://sfini.readthedocs.io/en/latest/?badge=latest)
[![Contributor Covenant](
https://img.shields.io/badge/Contributor%20Covenant-v1.4%20adopted-ff69b4.svg)](
CODE_OF_CONDUCT.md)

Create, run and manage AWS Step Functions easily. Pronounced "SFIN-ee".

This package aims to provide a user-friendly interface into defining and
running Step Functions. Things you can do in `sfini` to interact with AWS Step
Functions:
* Implement and register activities
* Define and register state machines
* Start, track and stop executions
* Run workers for activities
* Get information for registered activities and state machines
* De-register state machines and activities

Note: this is not a tool to convert Python code into a Step Functions state
machine. For that, see [pyawssfn](https://github.com/bennorth/pyawssfn).

## Getting started
### Prerequisites
* [AWS](https://aws.amazon.com/) (Amazon Web Services) account, with
  access to Step Functions
* AWS [IAM](https://aws.amazon.com/iam/) (Identity and Access Management)
  credentials

### Installation
```bash
pip install sfini
```

## Usage
### Documentation
Check the [documentation](https://sfini.readthedocs.io/en/latest/) or use
the built-in help:
```bash
pydoc sfini
```

```python
import sfini
help(sfini)
```

### AWS Step Functions
[AWS Step Functions](https://aws.amazon.com/step-functions/) (SFN) is a
workflow-management service, providing the ability to coordinate tasks in a
straight-forward fashion. Further documentation can be found in the
[AWS documentation](
https://docs.aws.amazon.com/step-functions/latest/dg/welcome.html).

Usage of Step Functions consists of two types: state-machines and activities.
A state-machine is a graph of operations which defines a workflow of an
application, comprised of multiple types of "states", or stages of the
workflow. An activity processes input to an output, and is used to process a
task "state" in the state-machine (multiple task states can have the same
activity assigned it.

Once a state-machine is defined and registered (along with the used
activities), you run executions of that state-machine on different inputs to
run the workflow. `sfini` allows you to start, stop and get the history of
these executions.

State-machines support conditional branching (and therefore loops), retries
(conditional and unconditional), exception-catching, external AWS service
support for running tasks, parallel execution and input/output processing.
External services including AWS Lambda, so you don't have to deploy your own
activity runners.

Once state-machines and activities are defined and registered, you can view and
update their details in [the SFN web console](
https://console.aws.amazon.com/states/home?#/).

### Role ARN
Every state-machine needs a role ARN (Amazon Resource Name). This is an AWS IAM
role ARN which allows the state-machine to process state executions. See AWS
Step Functions documentation for more information.

### Example
More examples found [in the documentation](
https://sfini.readthedocs.io/en/latest/examples.html).

```python
import sfini

# Define activities
activities = sfini.ActivityRegistration(prefix="test")


@activities.activity("addActivity")
def add_activity(data):
    return data["a"] + data["b"]


# Define state-machine
add = sfini.Task("add", add_activity)
sm = sfini.construct_state_machine("testAdding", add)

# Register state-machine and activities
activities.register()
sm.register()

# Start activity worker
worker = sfini.Worker(add_activity)
worker.start()

# Start execution
execution = sm.start_execution(execution_input={"a": 3, "b": 42})
print(execution.name)
# testAdding_2019-05-13T19-07_0354d790

# Wait for execution and print output
execution.wait()
print(execution.output)
# 45
print(execution.format_history())
# ExecutionStarted [1] @ 2019-06-23 20:03:52.817000+10:00
# TaskStateEntered [2] @ 2019-06-23 20:03:52.840000+10:00:
#   name: add
# ActivityScheduled [3] @ 2019-06-23 20:03:52.840000+10:00:
#   resource: arn:aws:states:us-west-2:ACCID:activity:testaddActivity
# ActivityStarted [4] @ 2019-06-23 20:03:53.954000+10:00:
#   worker: hostname-3a4fb480
# ActivitySucceeded [5] @ 2019-06-23 20:03:55.028000+10:00
# TaskStateExited [6] @ 2019-06-23 20:03:55.028000+10:00:
#   name: add
# ExecutionSucceeded [7] @ 2019-06-23 20:03:55.028000+10:00
# Output: 45

# Stop activity workers
worker.end()
worker.join()

# Deregister state-machine and activities
activities.deregister()
sm.deregister()
```


