Files
hatchet/examples/python/rate_limit/worker.py
Gabe Ruttner 8e80faf2d6 Fe overhaul docs (#1640)
* api changes

* doc changes

* move docs

* generated

* generate

* pkg

* backmerge main

* revert to main

* revert main

* race?

* remove go tests
2025-04-30 14:10:09 -07:00

61 lines
1.1 KiB
Python

from pydantic import BaseModel
from hatchet_sdk import Context, Hatchet
from hatchet_sdk.rate_limit import RateLimit, RateLimitDuration
hatchet = Hatchet(debug=True)
# > Workflow
class RateLimitInput(BaseModel):
user_id: str
rate_limit_workflow = hatchet.workflow(
name="RateLimitWorkflow", input_validator=RateLimitInput
)
# > Static
RATE_LIMIT_KEY = "test-limit"
@rate_limit_workflow.task(rate_limits=[RateLimit(static_key=RATE_LIMIT_KEY, units=1)])
def step_1(input: RateLimitInput, ctx: Context) -> None:
print("executed step_1")
# > Dynamic
@rate_limit_workflow.task(
rate_limits=[
RateLimit(
dynamic_key="input.user_id",
units=1,
limit=10,
duration=RateLimitDuration.MINUTE,
)
]
)
def step_2(input: RateLimitInput, ctx: Context) -> None:
print("executed step_2")
def main() -> None:
hatchet.rate_limits.put(RATE_LIMIT_KEY, 2, RateLimitDuration.SECOND)
worker = hatchet.worker(
"rate-limit-worker", slots=10, workflows=[rate_limit_workflow]
)
worker.start()
if __name__ == "__main__":
main()