Skip to main content

InOrbit Edge SDK for Python

Project description

InOrbit Python Edge SDK

OS Python 3.8 Python 3.9 Python 3.10 Python 3.11 Python 3.12
Linux TeamCity TeamCity TeamCity TeamCity TeamCity
Mac TeamCity TeamCity TeamCity TeamCity TeamCity
Windows TeamCity TeamCity TeamCity TeamCity TeamCity
Qodana -- -- TeamCity --

The InOrbit Edge SDK allows Python programs to communicate with InOrbit platform on behalf of robots - providing robot data and handling robot actions. Its goal is to ease the integration between InOrbit and any other software that handles robot data.


Features

  • Robot session handling through a RobotSessionPool.
  • Publish key-values.
  • Publish robot poses.
  • Publish robot odometry.
  • Publish robot path.
  • Publish robot laser.
  • Execute callbacks on Custom Action execution.
  • Execute scripts (or any program) in response to Custom Action execution.

Quick Start

from inorbit_edge.robot import RobotSessionFactory, RobotSessionPool


def my_command_handler(robot_id, command_name, args, options):
    """Callback for processing custom command calls.

    Args:
        robot_id (str): InOrbit robot ID
        command_name (str): InOrbit command e.g. 'customCommand'
        args (list): Command arguments
        options (dict): object that includes
            - `result_function` can be called to report command execution
            result with the following signature: `result_function(return_code)`
            - `progress_function` can be used to report command output with
            the following signature: `progress_function(output, error)`
            - `metadata` is reserved for the future and will contain additional
            information about the received command request.
    """
    if command_name == "customCommand":
        print(f"Received '{command_name}' for robot '{robot_id}'!. {args}")
        # Return '0' for success
        options["result_function"]("0")


robot_session_factory = RobotSessionFactory(
    api_key="<YOUR_API_KEY>"
)

# Register commands handlers. Note that all handlers are invoked.
robot_session_factory.register_command_callback(my_command_handler)
robot_session_factory.register_commands_path("./user_scripts", r".*\.sh")

robot_session_pool = RobotSessionPool(robot_session_factory)

robot_session = robot_session_pool.get_session(
    robot_id="my_robot_id_123", robot_name="Python SDK Quick Start Robot"
)

robot_session.publish_pose(x=0.0, y=0.0, yaw=0.0)

Installation

Stable Release: pip install inorbit-edge
**Development Head: ** pip install git+https://github.com/inorbit-ai/edge-sdk-python.git

Documentation

For full package documentation please visit InOrbit Developer Portal.

Development

See CONTRIBUTING.md for information related to developing the code.

The Three Commands You Need To Know

  1. pip install -e .[dev]

    This will install your package in editable mode with all the required development dependencies (i.e. tox).

  2. make build

    This will run tox which will run all your tests in Python 3.8 - 3.11 as well as linting your code.

  3. make clean

    This will clean up various Python and build generated files so that you can ensure that you are working in a clean environment.

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

inorbit-edge-1.17.2.tar.gz (40.8 kB view details)

Uploaded Source

Built Distribution

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

inorbit_edge-1.17.2-py3-none-any.whl (38.7 kB view details)

Uploaded Python 3

File details

Details for the file inorbit-edge-1.17.2.tar.gz.

File metadata

  • Download URL: inorbit-edge-1.17.2.tar.gz
  • Upload date:
  • Size: 40.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for inorbit-edge-1.17.2.tar.gz
Algorithm Hash digest
SHA256 56aca5a76d411496e9bca85aa216e2bece9432601ca13a9dfbc073bbccd75820
MD5 b06702d6f16579ad66200a1aab8744a9
BLAKE2b-256 2435f53f5e0e1f9af30ca0a4c7d1af7f778d73c35e21de48677d86f48e94b16f

See more details on using hashes here.

File details

Details for the file inorbit_edge-1.17.2-py3-none-any.whl.

File metadata

  • Download URL: inorbit_edge-1.17.2-py3-none-any.whl
  • Upload date:
  • Size: 38.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for inorbit_edge-1.17.2-py3-none-any.whl
Algorithm Hash digest
SHA256 665cb49d3cc336af96295d5a80557cd8361f50d5adbed2d89f302ba95b5017c5
MD5 759cda42d7f5401b689b5d15e1e18eda
BLAKE2b-256 7000aa207f286a02d51be5a10cd1597ef2bf7200beaf8fde9d557e22f990750b

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