Skip to main content

Robocorp Actions

Project description

⚡️ robocorp-actions

⚠️ Deprecation Notice: Development of this package has moved and continues under a new PyPI package: sema4ai-actions. You can follow the development in this GitHub repository. The robocorp-actions package will no longer receive updates, so please update your dependencies to ensure continued support and improvements.

A Python library designed to simplify the development of Python actions (AI or otherwise) to be run with the Robocorp Action Server.

Getting started

If you have not setup Action Server already, see the 🏃‍♂️ Quickstart on how to do that.

Decorate your Python function with the @action decorator:

from robocorp.actions import action

@action
def sum_numbers(a: float, b: float) -> float:
    ...

And your function is now an ⚡️Action!

You can now run and debug your action by Starting Action Server with action-server start and accessing the UI at http://localhost:8080.

Note: Action inputs and outputs support only int, float, str and bool types.

Describe your action

For an action's purpose and usage to be understood by AI models (and humans) it needs to be documented correctly.

To do that, use Google Style Docstring to write a clear and concise description on what your action does and document the action inputs and expected output:

@action
def get_weather_forecast(city: str, days: int, scale: str = "celsius") -> str:
    """
    Returns weather conditions forecast for a given city.

    Args:
        city (str): Target city to get the weather conditions for
        days: How many day forecast to return
        scale (str): Temperature scale to use, should be one of "celsius" or "fahrenheit"

    Returns:
        str: The requested weather conditions forecast
    """
    ...

Tip: Experiment with and iterate the exact documentation wording to get more predictable results when using your action with AI apps.


Consequential flag

You can explicitly provide the is_consequential flag for an action to mark it's operations as "must always prompt the user for confirmation before running" by OpenAI GPTs (and possibly by other providers). If set to False, the user will be provided with an "always allow" feature.

@action(is_consequential=True)
def get_weather_forecast(city: str, days: int, scale: str = "celsius") -> str:

Execution

To get the full benefits of your actions, the suggested way to run them is using Action Server. But it's also possible to do that directly in command line by passing the named arguments:

python -m robocorp.actions run -- --city=Helsinki --days=3

Guides

API Reference

Explore our API for extensive documentation.

Changelog

A list of releases and corresponding changes can be found in the changelog.

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

robocorp_actions-0.2.2.tar.gz (16.8 kB view details)

Uploaded Source

Built Distribution

robocorp_actions-0.2.2-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file robocorp_actions-0.2.2.tar.gz.

File metadata

  • Download URL: robocorp_actions-0.2.2.tar.gz
  • Upload date:
  • Size: 16.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.8.0-1014-azure

File hashes

Hashes for robocorp_actions-0.2.2.tar.gz
Algorithm Hash digest
SHA256 574ec61ca91858ef173c2ef8ed847be8177adca1b9f2459dcc4e09d9525ed8eb
MD5 6c64835dc16bca4a04baf9d32e560f1f
BLAKE2b-256 295c2c7b6c1bb363f9ca0847f1ecd22864d85bacf928ac2207147080c143246e

See more details on using hashes here.

File details

Details for the file robocorp_actions-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: robocorp_actions-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 19.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.8.0-1014-azure

File hashes

Hashes for robocorp_actions-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 70f0311723aba03b6b2d8ab2d309a68fcdfc5c3a636676bf46451a3da535c2f0
MD5 e501fa3a0561f9464c116fab07978f2d
BLAKE2b-256 a25f8f7c0522be04baa3a2ea99604d9625c55163fba729f84e76fedc73ed14fd

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