ExtremeCloud IQ Controller :: Application Manager API (1.61.1)

Download OpenAPI specification:Download

Introduction

The Application Manager API provides a programmatic interface to install and manage applications, create and manage containers, storage, images, and templates, and access system information and features. It is based on RESTful principles and uses standard HTTP methods for requests and responses. It uses OAuth 2.0 for authentication and authorization. API request and response bodies are formatted in JavaScript Object Notation (JSON).
Note: To submit API calls, your RESTful API consuming program needs to have logged in using credentials granting at least read permissions, and only user accounts with FullAdmin credentials can make configuration changes through the REST API.

Authentication and Authorization

The Application Manager REST API uses the OAuth 2.0 protocol to provide secure authorized access to the API. OAuth is an authorization framework that enables web, mobile, and desktop applications to access protected resources. To begin, pass your client login credentials in the Authorization header within a POST request to the management/v1/oauth2/token endpoint. In exchange for these credentials, the ExtremeCloud IQ Controller authorization server issues tokens called bearer tokens that you use for authorization when making subsequent REST API calls.

Authorization

Get access to data while protecting your account credentials. Obtain the bearer token with a POST request to the management/v1/oauth2/token endpoint using OAuth2 password grant type.

Security Scheme Type: OAuth2
Flow type: password
Token URL: /management/v1/oauth2/token
Scopes:
  • read -

    Grant read-only access to all data

  • FullAdmin -

    Grant read-write access to all data

apps

Install and manage applications.

Start an application

Starts an application with the specified template name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template that needs to be started.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Stop an application

Stops an application with the specified template name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template that needs to be stopped.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

getLog

Return an application’s log

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template to be accessed

query Parameters
stdout
boolean
Default: true

Return logs from stdout

stderr
boolean
Default: true

Return logs from stderr

since
integer <int32>
Default: 0

Only return logs since this time, as a UNIX timestamp

timestamps
boolean
Default: false

Add timestamps to every log line

tail
string
Default: "all"

Only return this number of log lines from the end of the logs. Specify as an integer or 'all' to output all log lines.

Responses

Uninstall an application

Uninstalls an application with the specified template name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template that needs to be uninstalled.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Upgrade an application

Upgrades an application from registry.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template that needs to be upgraded.

query Parameters
version
required
string

Version of the application.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Install an application from registry

Installs an application from the registry.

Authorizations:
Authorization
query Parameters
name
required
string

Name of application template that needs to be installed.

version
required
string

Version of the application that needs to be installed.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Install an application from file

Installs an application from file.

Authorizations:
Authorization
query Parameters
name
required
string

Name of application template that needs to be installed

Request Body schema: multipart/form-data
file
string <binary>

A tar archive containing images of the application that needs to be installed.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Upgrade an application from file

Upgrades an application from file.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template that needs to be upgraded.

Request Body schema: multipart/form-data
file
string <binary>

A tar archive containing images of the application to be upgraded.

Responses

Response samples

Content type
application/json
{
  • "AppName": "defender",
  • "AppTitle": "Extreme Defender for IoT",
  • "AppDescription": "Next generation security for medical and other connected devices.",
  • "AppIcon": "",
  • "ProxyAppUrl": true,
  • "AppFileNameFormat": "defender_[0-9]{2}\\.[0-9]{2}\\.[0-9]{2}",
  • "AppRegistry": "Docker Hub",
  • "Type": "BUILT_IN",
  • "AppVersion": "1.0.0",
  • "LatestVersion": "2.0.0",
  • "AppState": "NOT_INSTALLED",
  • "StartedAt": "2019-08-24T14:15:22Z",
  • "Warnings": [
    ]
}

Retrieve resource usage statistics

Returns an application’s resource usage statistics.

Authorizations:
Authorization
path Parameters
name
required
string

Name of the application template to be accessed

Responses

Response samples

Content type
application/json
{
  • "MemoryUsage": 0,
  • "CpuUsage": 0
}

containers

Create and manage containers.

listContainers

Returns a list of all containers. You can filter by container image or volume.

Authorizations:
Authorization
query Parameters
imageNameOrId
string

Name or ID of container image

containerName
string

Name of container

volumeName
string

Name of container volume

Responses

Response samples

Content type
application/json
[
  • {
    }
]

inspectContainer

Returns low-level information about a container based on name or ID.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to use

Responses

Response samples

Content type
application/json
{
  • "Name": "string",
  • "Path": "string",
  • "State": {
    },
  • "Args": [
    ],
  • "Id": "string",
  • "Node": {
    },
  • "Created": "2019-08-24T14:15:22Z",
  • "Image": "string",
  • "Config": {
    },
  • "Mounts": [
    ],
  • "NetworkSettings": {
    },
  • "Driver": "string",
  • "ProcessLabel": "string",
  • "ResolvConfPath": "string",
  • "HostsPath": "string",
  • "AppArmorProfile": "string",
  • "ExecIDs": [
    ],
  • "HostnamePath": "string",
  • "MountLabel": "string",
  • "RestartCount": 0,
  • "LogPath": "string",
  • "VolumesRW": {
    },
  • "ExecDriver": "string",
  • "Volumes": {
    },
  • "HostConfig": {
    }
}

restartContainer

Restarts a container based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be restarted

Responses

removeContainer

Removes a container based on name or ID.

Authorizations:
Authorization
path Parameters
nameOrId
required
string

ID or name of the container to be removed

query Parameters
force
boolean
Default: false

Kill the container that is currently running.

removeVolumes
boolean
Default: false

Remove volumes associated with the container.

Responses

renameContainer

Rename a container based on name or ID.

Authorizations:
Authorization
path Parameters
nameOrId
required
string

ID or name of the container to be renamed

query Parameters
name
required
string

New name for the container

Responses

unpauseContainer

Unpause a container based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be unpaused

Responses

startContainer

Starts a container based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be started

Responses

pauseContainer

Pauses a container based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be paused

Responses

stopContainer

Stops a container based on name or ID.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be stopped

Responses

createContainer

Creates a container

Authorizations:
Authorization
query Parameters
name
string

Assigns the specified name to the container. Must match /?[a-zA-Z0-9_-]+

Request Body schema: application/json

Definition of the container to be created

object

An object mapping ports to an empty object in the form: {"/<tcp|udp>": {}}

Image
string

The name of the image to use when creating the container

object (HostConfigDefinition)

Container configuration that depends on the host we are running on

Cmd
Array of strings

Command to run specified as a string or an array of strings

Env
Array of strings

A list of environment variables to set inside the container in the form

Responses

Request samples

Content type
application/json
{
  • "ExposedPorts": {
    },
  • "Image": "string",
  • "HostConfig": {
    },
  • "Cmd": [
    ],
  • "Env": [
    ]
}

Response samples

Content type
application/json
{
  • "Id": "string",
  • "Warnings": [
    ]
}

killContainer

Kills a container based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be killed

Responses

getContainerStats

Returns a container’s resource usage statistics based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be accessed

Responses

Response samples

Content type
application/json
{
  • "Name": "string",
  • "Path": "string",
  • "State": {
    },
  • "Args": [
    ],
  • "Id": "string",
  • "Node": {
    },
  • "Created": "2019-08-24T14:15:22Z",
  • "Image": "string",
  • "Config": {
    },
  • "Mounts": [
    ],
  • "NetworkSettings": {
    },
  • "Driver": "string",
  • "ProcessLabel": "string",
  • "ResolvConfPath": "string",
  • "HostsPath": "string",
  • "AppArmorProfile": "string",
  • "ExecIDs": [
    ],
  • "HostnamePath": "string",
  • "MountLabel": "string",
  • "RestartCount": 0,
  • "LogPath": "string",
  • "VolumesRW": {
    },
  • "ExecDriver": "string",
  • "Volumes": {
    },
  • "HostConfig": {
    }
}

getContainerLogs

Returns stdout and stderr logs from a container based on ID or name. Note: This endpoint works only for containers with the json-file or journald logging driver.

Authorizations:
Authorization
path Parameters
idOrName
required
string

ID or name of the container to be accessed

query Parameters
stdout
boolean
Default: false

Return logs from stdout

stderr
boolean
Default: false

Return logs from stderr

since
integer <int32>
Default: 0

Only return logs since this time (a UNIX timestamp).

timestamps
boolean
Default: false

Add timestamps to every log line.

tail
string
Default: "all"

Only return this number of log lines from the end of the logs. Specify as an integer or all to output all log lines.

Responses

images

Create and manage application images.

listImages

Returns list of images on the server. This endpoint returns a different, smaller representation of an image compared to when inspecting a single image.

Authorizations:
Authorization

Responses

Response samples

Content type
application/json
[
  • {
    }
]

pullImage

Creates an image by pulling it from a registry.

Authorizations:
Authorization
query Parameters
fromImage
required
string

Name of image to pull. The name may include a tag or digest. The pull is cancelled if the HTTP connection is closed.

Responses

inspectImage

Returns low-level information about an image based on ID or name.

Authorizations:
Authorization
path Parameters
idOrName
required
string

Name or ID of image to be accessed

Responses

removeImage

Removes an image based on ID or name, along with any untagged parent images that were referenced by that image. Note: Images cannot be removed if they have descendant images, are being used by a running container, or are being used by a build.

Authorizations:
Authorization
path Parameters
idOrName
required
string

Name or ID of image to be removed

query Parameters
force
required
boolean
Default: false

Remove image even if it is being used by a stopped container or has other tags.

Responses

Response samples

Content type
application/json
[
  • { }
]

tagImage

Tags an image based on ID or name, to make it part of a repository.

Authorizations:
Authorization
path Parameters
idOrName
required
string

Name or ID of image to tag

query Parameters
repo
required
string

The repository to tag in. For example, someuser/someimage

tag
required
string

Name of the new tag

Responses

importImage

Load a set of images and tags into a repository.

Authorizations:
Authorization
header Parameters
Content-Length
integer <int64>
Request Body schema: multipart/form-data
file
string <binary>

A tar archive containing images to be loaded into a repository

Responses

exportImage

Returns a tarball containing all images and metadata for a repository.

Authorizations:
Authorization
path Parameters
idOrName
required
string

Name or ID of repository to be accessed

Responses

Response samples

Content type
No sample

system

Access system information and features.

getSystemInformation

Returns system information

Authorizations:
Authorization

Responses

Response samples

Content type
application/json
{
  • "Name": "string",
  • "Debug": true,
  • "ID": "string",
  • "ClusterStore": "string",
  • "NCPU": 0,
  • "CgroupDriver": "string",
  • "ContainersPaused": 0,
  • "MemoryLimit": true,
  • "MemTotal": 0,
  • "Architecture": "string",
  • "InitPath": "string",
  • "HttpProxy": "string",
  • "InitSha1": "string",
  • "Driver": "string",
  • "KernelVersion": "string",
  • "CpuCfsQuota": true,
  • "HttpsProxy": "string",
  • "CpuCfsPeriod": true,
  • "KernelMemory": true,
  • "DriverStatus": [
    ],
  • "ExecutionDriver": "string",
  • "DockerRootDir": "string",
  • "IPv4Forwarding": true,
  • "Labels": [
    ],
  • "NoProxy": "string",
  • "SwapLimit": true,
  • "Swarm": {
    },
  • "OperatingSystem": "string",
  • "OSType": "string",
  • "NEventsListener": 0,
  • "NFd": 0,
  • "ServerVersion": "string",
  • "NGoroutines": 0,
  • "SystemStatus": [
    ],
  • "Plugins": {
    },
  • "OomKillDisable": true,
  • "RegistryConfig": {
    },
  • "Containers": 0,
  • "Images": 0,
  • "SystemTime": "2019-08-24T14:15:22Z",
  • "ContainersStopped": 0,
  • "IndexServerAddress": "string",
  • "ContainersRunning": 0,
  • "ExperimentalBuild": true
}

getApplicationTemplates

Returns available application templates.

Authorizations:
Authorization

Responses

Response samples

Content type
application/json
[
  • {
    }
]

templates

Create and manage templates.

list

Returns a summary of all supported templates (for both installed and uninstalled apps).

Authorizations:
Authorization

Responses

Response samples

Content type
application/json
[
  • {
    }
]

add

Creates a new user-defined application template.

Authorizations:
Authorization
Request Body schema: application/json

User defined application template

required
object (ApplicationInformation)

General information for an application

required
object (ApplicationConfiguration)

Configuration of an application

Responses

Request samples

Content type
application/json
{
  • "AppInfo": {
    },
  • "AppConfiguration": {
    }
}

getTemplate

Returns a user-defined application template based on name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of application template to be accessed

Responses

Response samples

Content type
application/json
{
  • "AppInfo": {
    },
  • "AppConfiguration": {
    }
}

update

Updates a user-defined application template based on name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of template to be updated

Request Body schema: application/json

Application template

required
object (ApplicationInformation)

General information for an application

required
object (ApplicationConfiguration)

Configuration of an application

Responses

Request samples

Content type
application/json
{
  • "AppInfo": {
    },
  • "AppConfiguration": {
    }
}

remove

Removes a user-defined application template based on name.

Authorizations:
Authorization
path Parameters
name
required
string

Name of template to be removed

Responses

getDefaults

Returns default parameters to use when creating a new custom template.

Authorizations:
Authorization

Responses

Response samples

Content type
application/json
[
  • {
    }
]

getSummary

Retrieve the summary of an application template.

Authorizations:
Authorization
path Parameters
name
required
string

Application template name

Responses

Response samples

Content type
application/json
{
  • "AppInfo": {
    },
  • "AppConfiguration": {
    }
}

volumes

Create and manage persistent storage that can be attached to containers.

createVolume

Creates a volume with the specified configuration.

Authorizations:
Authorization
Request Body schema: application/json

Volume configuration

name
string
mountPoint
string

Responses

Request samples

Content type
application/json
{
  • "name": "string",
  • "mountPoint": "string"
}

Response samples

Content type
application/json
{
  • "Name": "string",
  • "Status": {
    },
  • "Labels": {
    },
  • "Driver": "string",
  • "Scope": "string",
  • "Options": {
    },
  • "DriverOpts": {
    },
  • "Mountpoint": "string"
}

inspectVolume

Returns information about a volume based on name or ID.

Authorizations:
Authorization
path Parameters
nameOrId
required
string

Name or ID of volume to be accessed

Responses

Response samples

Content type
application/json
{
  • "Name": "string",
  • "Status": {
    },
  • "Labels": {
    },
  • "Driver": "string",
  • "Scope": "string",
  • "Options": {
    },
  • "DriverOpts": {
    },
  • "Mountpoint": "string"
}

removeVolume

Deletes a volume based on name or ID.

Authorizations:
Authorization
path Parameters
nameOrId
required
string

Name or ID of volume to be deleted

Responses

listVolumes

Returns a list of all volumes on the server.

Authorizations:
Authorization
query Parameters
dangling
boolean
Default: false

When set to true, returns all volumes that are not in use by a container. When set to false, only returns volumes that are in use by one or more containers.

Responses

Response samples

Content type
application/json
{
  • "Warnings": [
    ],
  • "Volumes": [
    ]
}