Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/knowsuchagency/orkestra
The elegance of Airflow + the power of AWS
https://github.com/knowsuchagency/orkestra
aws orchestration step-functions
Last synced: 3 months ago
JSON representation
The elegance of Airflow + the power of AWS
- Host: GitHub
- URL: https://github.com/knowsuchagency/orkestra
- Owner: knowsuchagency
- License: mit
- Created: 2021-04-28T07:56:44.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-02-05T17:53:26.000Z (about 1 year ago)
- Last Synced: 2024-11-01T03:32:37.313Z (4 months ago)
- Topics: aws, orchestration, step-functions
- Language: Python
- Homepage: https://knowsuchagency.github.io/orkestra
- Size: 1.82 MB
- Stars: 50
- Watchers: 4
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-cdk - Orkestra - An event-driven alternative to Airflow built on the AWS CDK and Step Functions. (High-Level Frameworks / Multi-accounts setup)
- awesome-cdk - Orkestra - An event-driven alternative to Airflow built on the AWS CDK and Step Functions. (High-Level Frameworks / Multi-accounts setup)
README
# Orkestra
### The elegance of Airflow + the power of AWS
[data:image/s3,"s3://crabby-images/1cf04/1cf043bbf608e8baf41f57af2d971af08a48bc47" alt="Docs"](https://knowsuchagency.github.io/orkestra)
[data:image/s3,"s3://crabby-images/dd349/dd3495406c9c146821870671d89ec58b2930478f" alt="Codecov"](https://app.codecov.io/gh/knowsuchagency/orkestra/)[data:image/s3,"s3://crabby-images/a0e43/a0e43a324d87cd49091d092670fafa5984e13741" alt="PyPI"](https://pypi.org/project/orkestra/)
data:image/s3,"s3://crabby-images/2952c/2952cbf2edc1bea6231dd23a81a97315efdf99c7" alt="PyPI - Downloads"
data:image/s3,"s3://crabby-images/55b98/55b98ecd3b855a7af43f9dd5a4283081dacdde7a" alt="PyPI - License"
data:image/s3,"s3://crabby-images/12153/12153676f57658e4c6915d26486b508d54a31f4b" alt="PyPI - Python Version"
data:image/s3,"s3://crabby-images/5ed59/5ed59267bd9a6f2de84561f6cdec1859a4531bae" alt="GitHub issues"
[data:image/s3,"s3://crabby-images/75b7f/75b7ff52f8c5707017679a0e624cc2e4a0c58aa5" alt="Mentioned in Awesome CDK"](https://github.com/kolomied/awesome-cdk)[comment]: <> ([data:image/s3,"s3://crabby-images/1564a/1564a694b73cf1fb2a2ad67cfcfac1df4d08515d" alt="codecov"](https://codecov.io/gh/knowsuchagency/orkestra))
*examples/hello_orkestra.py*
```python
import random
from typing import *
from uuid import uuid4from aws_lambda_powertools import Logger, Tracer
from pydantic import BaseModelfrom orkestra import compose
from orkestra.interfaces import Durationdef dag():
(
generate_item
>> add_price
>> copy_item
>> double_price
>> (do_nothing, assert_false)
>> say_hello
>> [random_int, random_float]
>> say_goodbye
)class Item(BaseModel):
id: str
name: str
price: Optional[float] = None@classmethod
def random(cls):
return cls(
id=str(uuid4()),
name=random.choice(
[
"potato",
"moon rock",
"hat",
]
),
)logger = Logger()
tracer = Tracer()
default_args = dict(
enable_powertools=True,
timeout=Duration.seconds(6),
)@compose(**default_args)
def generate_item(event, context):
logger.info("generating random item")
item = Item.random().dict()
logger.info(item)
tracer.put_metadata("GenerateItem", "SUCCESS")
return item@compose(model=Item, **default_args)
def add_price(item: Item, context):
price = 3.14
logger.info(
"adding price to item",
extra={
"item": item.dict(),
"price": price,
},
)
item.price = price
return item.dict()@compose(model=Item, **default_args)
def copy_item(item: Item, context) -> list:
logger.info(item.dict())
return [item.dict()] * 10@compose(model=Item, is_map_job=True, **default_args)
def double_price(item: Item, context):
item.price = item.price * 2
return item.dict()@compose(**default_args)
def assert_false(event, context):
assert False@compose(**default_args)
def do_nothing(event, context):
logger.info({"doing": "nothing"})@compose(**default_args)
def say_hello(event, context):
return "hello, world"@compose(**default_args)
def say_goodbye(event, context):
return "goodbye"@compose(**default_args)
def random_int(event, context):
return random.randrange(100)@compose(**default_args)
def random_float(event, context):
return float(random_int(event, context))dag()
```*app.py*
```python
#!/usr/bin/env python3
from aws_cdk import core as cdkfrom examples.hello_orkestra import generate_item
class HelloOrkestra(cdk.Stack):
def __init__(self, scope, id, **kwargs):super().__init__(scope, id, **kwargs)
generate_item.schedule(
self,
expression="rate(5 minutes)",
state_machine_name="hello_orkestra",
)app = cdk.App()
app.synth()
```data:image/s3,"s3://crabby-images/6b4b5/6b4b5c2ec3a1513ef3bc0de73334f0eac5192e59" alt="state machine"