#product-os #server-api #api-calls #open-api #server-framework #automation #workflow

product-os-connector

Product OS : Connector provides a framework for definining a server with APIs, outward API calls, a workflow to pass data along, all using only configuration that can be defined in JSON or Yaml. This flexible and powerful framework is akin to using automation tools like Zapier and IFTTT and tray.io and supports using OpenAPI / Swagger defined APIs.

19 releases

new 0.0.21 Jan 13, 2025
0.0.20 Jan 5, 2025
0.0.19 Jun 14, 2024
0.0.18 Apr 18, 2024
0.0.5 Aug 21, 2023

#319 in Web programming

Download history 66/week @ 2024-09-23 19/week @ 2024-09-30 3/week @ 2024-10-07 14/week @ 2024-10-14 34/week @ 2024-10-21 15/week @ 2024-10-28 21/week @ 2024-11-04 6/week @ 2024-11-11 24/week @ 2024-11-18 24/week @ 2024-11-25 35/week @ 2024-12-02 43/week @ 2024-12-09 10/week @ 2024-12-16 86/week @ 2024-12-30 73/week @ 2025-01-06

172 downloads per month
Used in 14 crates (via product-os-configuration)

AGPL-3.0-only

300KB
4.5K SLoC

Product OS : Connector

Product OS : Connector provides a framework for definining a server with APIs, outward API calls, a workflow to pass data along, all using only configuration that can be defined in JSON or Yaml. This flexible and powerful framework is akin to using automation tools like Zapier and IFTTT and tray.io and supports using OpenAPI / Swagger defined APIs.

What is Product OS?

Product OS is a collection of packages that provide different tools and features that can work together to build products more easily for the Rust ecosystem.

Installation

Use the Rust crate package manager cargo to install Product OS : Connector.

cargo add product-os-connector

or add Product OS : Connector to your cargo.toml [packages] section.

product-os-connector = { version = "0.0.21", features = [], default-features = true, optional = false }

Features

Product OS Connector supports a number of features leveraging existing Rust libraries to help connect APIs together using only configuration:

  • Define server with a set of inward APIs using only configuration
  • Define a set of outward APIs that can be called using only configuration
  • Supports REST, GraphQL and Web Sockets initially
  • Supports a number of authentication methods
  • Import OpenAPI / Swagger definitions easily for outward API calls
  • Define a workflow by passing data along from inward calls, passed through outward calls, data manipulation and then response
  • Supports no_std with alloc only environments

To make the most of Connector, you should use the Product OS : Server crate.

// Feature samples TODO

Usage

// Examples TODO

Contributing

Contributions are not currently available but will be available on a public repository soon.

License

GNU AGPLv3

Dependencies

~19–27MB
~730K SLoC