Skip to main content

Peridio Device API (1.0.0)

Download OpenAPI specification:Download

License: Peridio

The Peridio Device API is the primary way for devices to interact with Peridio.

Global Headers

The following headers may be supplied when requesting any route.

For critical context about how Peridio Cloud will interpret these headers, refer to the device integration section of the bundle distribution reference.

For context regarding deprecated headers, see deployment eligibility.

key value description
peridio-release-prn A release PRN. Informs Peridio of what release is currently active on the device.
peridio-bundle-prn A bundle PRN. Informs Peridio of what bundle is currently active on the device.
peridio-release-version A release version. Informs Peridio of what release version is representative of the device's state.
x-peridio-architecture A firmware architecture. Deprecated. See deployment eligibility. The architecture of the device's currently active firmware. When supplying any x-peridio header, you should supply all x-peridio headers.
x-peridio-platform A firmware platform. Deprecated. See deployment eligibility. The platform of the device's currently active firmware. When supplying any x-peridio header, you should supply all x-peridio headers.
x-peridio-product A firmware product. Deprecated. See deployment eligibility. The product of the device's currently active firmware. When supplying any x-peridio header, you should supply all x-peridio headers.
x-peridio-uuid A firmware UUID. Deprecated. See deployment eligibility. The UUID of the device's currently active firmware. When supplying any x-peridio header, you should supply all x-peridio headers.
x-peridio-version A firmware version. Deprecated. See deployment eligibility. The version of the device's currently active firmware. When supplying any x-peridio header, you should supply all x-peridio headers.

Devices

get device me

Returns information about the device identified by the request's authentication.

Expandable

This endpoint has an expandable response. See expanding responses.

Authorizations:
MutualTLS
query Parameters
expand
Array of strings

See expanding responses.

Expandable Fields

For more information on each field, reference the response.

  • cohort
  • manifest
    • artifact
    • artifact_version
    • binary_prn
    • custom_metadata
    • hash
    • signatures
    • size
    • target
    • url
header Parameters
peridio-release-prn
string (prn)
Examples: prn:1:a1ed0c4e-f222-4bb3-89dc-48320018875d:release:e4bf3021-b8d7-42d5-a1bd-52121427ebd0
peridio-release-version
string (release-version)
Example: 1.0.0

Responses

Response samples

Content type
application/json
{
  • "data": {
    }
}

get device update

This functionality has been superceded by get update.

Returns information regarding whether an update is available via a deployment.

If an update is available, additional information describing the update is returned including a presigned URL to acquire the update.

Authorizations:
MutualTLS
query Parameters
preflight
boolean
Default: false

When false

The request will count towards update attempts. firmware_url in the response will be set to a presigned URL.

When true

The request will not count towards update attempts. firmware_url in the response will be null.

For example, one may use true to check if an update is available when you don't yet intend to consume the update so that a device does not rack up a number of incomplete updates and eventually get quarantined (pending the failure configuration set on the relevant deployment).

header Parameters
x-peridio-uuid
required
string <uuid> (firmware-uuid)
peridio-release-prn
string (prn)
Examples: prn:1:a1ed0c4e-f222-4bb3-89dc-48320018875d:release:e4bf3021-b8d7-42d5-a1bd-52121427ebd0
peridio-release-version
string (release-version)
Example: 1.0.0

Responses

Response samples

Content type
application/json
{
  • "data": {
    }
}

get update

Returns information regarding whether an update is available via a release or bundle override.

Expandable

This endpoint has an expandable response. By default, only the status field is returned. See expanding responses.

Authorizations:
MutualTLS
query Parameters
expand
Array of strings

See expanding responses.

Expandable Fields

For more information on each field, reference the response.

  • source_type
  • bundle
  • release
  • manifest
    • artifact
    • artifact_version
    • binary_prn
    • custom_metadata
    • hash
    • signatures
    • size
    • target
    • url
header Parameters
peridio-release-prn
string (prn)
Examples: prn:1:a1ed0c4e-f222-4bb3-89dc-48320018875d:release:e4bf3021-b8d7-42d5-a1bd-52121427ebd0
peridio-bundle-prn
string (prn)
Examples: prn:1:a1ed0c4e-f222-4bb3-89dc-48320018875d:bundle:ddd32c59-fc35-4202-a520-a4eddaa11fb3
peridio-release-version
string (release-version)
Examples: 1.0.0

Responses

Response samples

Content type
application/json
{
  • "status": "update",
  • "source_type": "release",
  • "release": {
    },
  • "bundle": {
    },
  • "custom_metadata": { },
  • "manifest": [
    ]
}

Tunnels

List tunnels

This only returns :requested and :open tunnels.

For list options, we only support pagination params.

Authorizations:
MutualTLS
query Parameters
page
string

A cursor for pagination across multiple pages of results. Don't include this parameter on the first call. Use the next_page value returned in a previous response to request subsequent results.

Responses

Response samples

Content type
application/json
{
  • "tunnels": [
    ],
  • "next_page": "string"
}

Configure a tunnel

Configures a tunnel with device networking data.

If successful, the tunnel's state will be open. Only tunnels with a state of requested can be configured.

Authorizations:
MutualTLS
Request Body schema: application/json
required
tunnel_prn
required
string (tunnel-prn)

Peridio Resource Names (PRNs) uniquely identify Peridio resources.

cidr_blocks
required
Array of strings (cidrs)

A set of CIDR blocks that the device has available for use with remote access. The device's wireguard peer IP as well as wireguard interface IP will be choosen from this set so it must contain at least two distinct IPs.

port_ranges
required
Array of strings (port-ranges)

A set of port ranges that the device has available for use with remote access. The device can use this to constrain the pool of ports from which Peridio will choose the wireguard server listen port, that is, the port on which the server is listening for wireguard UDP traffic.

device_proxy_port
required
number

The port on which the device is listening for wireguard UDP traffic.

device_public_key
required
string

The device's public key for wireguard.

Responses

Request samples

Content type
application/json
{
  • "tunnel_prn": "prn:1:be4d30b4-de6b-47cd-85ea-a75e23fd63ef:tunnel:b3f1f699-3bc8-4c77-bda2-b974595d5e3f",
  • "cidr_blocks": [
    ],
  • "port_ranges": [
    ],
  • "device_proxy_port": 53000,
  • "device_public_key": "Y4nCIXdpb+f3WgPi0377FDPCAfP+st82s98lTRepHEk="
}

Response samples

Content type
application/json
{
  • "data": {
    }
}

Update a tunnel

Update a tunnel currently only allows changing a tunnel to a closed state.

Authorizations:
MutualTLS
path Parameters
tunnel_prn
required
string (tunnel-prn)
Example: prn:1:be4d30b4-de6b-47cd-85ea-a75e23fd63ef:tunnel:b3f1f699-3bc8-4c77-bda2-b974595d5e3f

Peridio Resource Names (PRNs) uniquely identify Peridio resources.

Request Body schema: application/json
required
state
string

The state we want the tunnel to be in. Only accepts "closed".

Responses

Request samples

Content type
application/json
{
  • "state": "closed"
}

Response samples

Content type
application/json
{
  • "data": {
    }
}