# Reduct Bridge
[](https://github.com/reductstore/reduct-bridge/releases/latest) [](https://github.com/reductstore/reduct-bridge/actions) [](https://hub.docker.com/r/reduct/bridge) [](https://github.com/reductstore/reduct-bridge/releases/latest) [](https://codecov.io/gh/reductstore/reduct-bridge)
ReductBridge bridges live robotics and IIoT data with long-term storage in ReductStore.
You can configure the bridge using a simple TOML file to define inputs, pipelines, and remotes.
Inputs produce data, pipelines route and modify it, and remotes store it.
## Inputs
An input is a data source. It reads data from a system and produces records for the bridge.
Supported input types include:
mqtt:// or mqtts:// and store raw payloads with optional payload/property label mapping.## Remotes
A remote is a data destination. It receives records from pipelines and writes them to external storage.
Supported remote types include:
## Pipelines
Pipelines connect one or more inputs to one remote.
```toml # Pipeline definition path: # [pipelines.<pipeline_name>] [pipelines.telemetry]
# Required: remote name from [[remotes.*]]. remote = "local"
# Required: one or more input names from [inputs..]. inputs = ["ros_local"]
# Optional label rules (default = []): # 1) Static labels: # { static = { source = "robot" }, to = "" } # - adds labels to matching target entries # 2) Copy labels from one entry to another: # { from = "time", labels = ["timestamp"], to = "echo" } # - remembers labels seen on matching source entries # - applies them to matching target entries labels = [ { static = { source = "ros1" }, to = "" } ] ```
## Supported Formats
ReductBridge supports different payload formats. Support means ReductBridge can parse payloads, extract labels, and, when schema information is available, store that schema in ReductStore.
## Installation
ReductBridge is published in build types named after Cargo feature bundles: ros1, ros2, and iot.
Choose the build type for the input family you need.
### Build Types
Published packages and Docker images are split into these build types so each artifact only includes the dependencies needed for its input family.
| B...
You are about to open
Do you wish to proceed?
Thank you for your report. Information you provided will help us investigate further.
There was an error while sending your report. Please try again later.
Snaps are applications packaged with all their dependencies to run on all popular Linux distributions from a single build. They update automatically and roll back gracefully.
Snaps are discoverable and installable from the Snap Store, an app store with an audience of millions.
On Arch Linux, snap can be installed from the Arch User Repository (AUR). The manual build process is the Arch-supported install method for AUR packages, and you’ll need the prerequisites installed before you can install any AUR package. You can then install snap with the following:
git clone https://aur.archlinux.org/snapd.git
cd snapd
makepkg -si
Once installed, the systemd unit that manages the main snap communication socket needs to be enabled:
sudo systemctl enable --now snapd.socket
If AppArmor is enabled in your system, enable the service which loads AppArmor profiles for snaps:
sudo systemctl enable --now snapd.apparmor.service
To enable classic snap support, enter the following to create a symbolic link between /var/lib/snapd/snap and /snap:
sudo ln -s /var/lib/snapd/snap /snap
Either log out and back in again, or restart your system, to ensure snap’s paths are updated correctly.
To install ReductBridge for IIoT, simply use the following command:
sudo snap install reduct-bridge-iot
Browse and find snaps from the convenience of your desktop using the snap store snap.
Interested to find out more about snaps? Want to publish your own application? Visit snapcraft.io now.