Skip to content

Rest Inventory v1 API

Global

GET Inventory Summary

  • Method: GET
  • Description: returns a list of All Inventory Items
  • API PATH: /services/inventory/v1/inventory
Response
  • 200 OK
    {
        "inventory":[
            {
                "name":"adduser",
                "version":"3.118",
                "type":"DEB"
            },
            {
                "name":"com.eclipsesource.jaxrs.provider.gson",
                "version":"2.3.0.201602281253",
                "type":"BUNDLE"
            },
                  {
                "name":"org.eclipse.kura.example.beacon",
                "version":"1.0.500",
                "type":"DP"
            }
        ]
    }
    
    Supported type values are:
  • BUNDLE : represents a OSGi Bundle
  • DP : represents a OSGi Deployment Package
  • DEB : represents a Linux Debian package
  • RPM : represents a Linux RPM package
  • APK : represents a Linux Alpine APK package
  • DOCKER : represents a container instance
  • CONTAINER_IMAGE : represents a container image
  • UNKNOWN : fallback type for unrecognized resources

Bundles

GET bundles

  • Method: GET
  • Description: returns a list of bundles.
  • API PATH: /services/inventory/v1/bundles
Response
  • 200 OK
    {
        "bundles":[
            {
                "name":"org.eclipse.osgi",
                "version":"3.16.0.v20200828-0759",
                "id":0,
                "state":"ACTIVE",
                "signed":true
            },
            {
                "name":"org.eclipse.equinox.cm",
                "version":"1.4.400.v20200422-1833",
                "id":1,
                "state":"ACTIVE",
                "signed":false
            }
        ]
    }
    

Start bundle

  • Method: POST
  • API PATH: /services/inventory/v1/bundles/_start
Request Body
{ 
"name":"org.eclipse.osgi",
}
Responses
  • 200 OK status
  • 400 Bad Request (Malformed Client JSON)
  • 404 Resource Not Found
  • 500 Internal Server Error

Stop bundle

  • Method: POST
  • API PATH: /services/inventory/v1/bundles/_stop
Request Body
{ 
"name":"org.eclipse.osgi",
}
Responses
  • 200 OK status
  • 400 Bad Request (Malformed Client JSON)
  • 404 Resource Not Found
  • 500 Internal Server Error

Deployment Packages

GET packages

  • Method: GET
  • Description: returns a list of deployment packages.
  • API PATH: /services/inventory/v1/deploymentPackages
Response
  • 200 OK
    {
        "deploymentPackages":[
            {
                "name":"org.eclipse.kura.example.beacon",
                "version":"1.0.500",
                "signed":false,
                "bundles":[
                    {
                        "name":"org.eclipse.kura.example.beacon",
                        "version":"1.0.500",
                        "id": 171,
                        "state": "ACTIVE",
                        "signed": false
                    }
                ]
            }
        ]
    }
    

System Packages (DEB/RPM/APK)

GET System Packages

  • Method: GET
  • Description: returns a list of system packages.
  • API PATH: /services/inventory/v1/systemPackages
Response
  • 200 OK
    {
        "systemPackages":[
            {
                "name":"adduser",
                "version":"3.118",
                "type":"DEB"
            },
            {
                "name":"alsa-utils",
                "version":"1.1.8-2",
                "type":"DEB"
            },
            {
                "name":"ansible",
                "version":"2.7.7+dfsg-1",
                "type":"DEB"
            },
            {
                "name":"apparmor",
                "version":"2.13.2-10",
                "type":"DEB"
            },
            {
                "name":"apt",
                "version":"1.8.2.1",
                "type":"DEB"
            },
            {
                "name":"apt-listchanges",
                "version":"3.19",
                "type":"DEB"
            },
            {
                "name":"apt-transport-https",
                "version":"1.8.2.2",
                "type":"DEB"
            },
            {
                "name":"apt-utils",
                "version":"1.8.2.1",
                "type":"DEB"
            }
        ]
    }
    

Containers

GET Containers

  • Method: Get
  • Description: returns a list of Containers.
  • API PATH: /services/inventory/v1/containers
Response
  • 200 OK
    {
      "containers":
      [
        {
          "name":"container_1",
          "version":"nginx:latest",
          "type":"DOCKER",
          "state":"active"
        }
      ]
    }
    

Start container

  • Method: POST
  • API PATH: /services/inventory/v1/containers/_start
Request Body
{
    "name":"container_1",
    "version": "nginx:latest",
}
Responses
  • 200 OK
  • 400 Bad Request (Malformed Client JSON)
  • 404 Resource Not Found
  • 500 Internal Server Error

Stop container

  • Method: POST
  • API PATH: /services/inventory/v1/containers/_stop
Request Body
{
    "name":"container_1",
    "version": "nginx:latest",
}
Responses
  • 200 OK
  • 400 Bad Request (Malformed Client JSON)
  • 404 Resource Not Found
  • 500 Internal Server Error

Images

Images Images

  • Method: Get
  • Description: returns a list of Images.
  • API PATH: /services/inventory/v1/images
Response
  • 200 OK
    {
      "containers":
      [
        {
          "name":"nginx",
          "version":"latest",
          "type":"ContainerImage",
        }
      ]
    }
    

Delete Image

  • Method: POST
  • API PATH: /services/inventory/v1/images/_delete
Request Body
{
      "name":"nginx",
      "version":"latest",
}
Responses
  • 200 OK
  • 400 Bad Request (Malformed Client JSON)
  • 404 Resource Not Found
  • 500 Internal Server Error

States

Bundle States

-   `ACTIVE`: Bundle is running
-   `INSTALLED`: Bundle is starting
-   `UNINSTALLED`: Bundle has failed, or is stopped
-   `UNKNOWN`: Bundle state can not be determined

Container States

-   `active`: Container is running
-   `installed`: Container is starting
-   `uninstalled`: Container has failed, or is stopped
-   `unknown`: Container state can not be determined