Confdb Schemas

Introduction

The Confdb Schemas API enables confdb-schema assertions management.

All endpoints require a macaroon authenticated request with no special permissions.

See Macaroons for details on how to obtain a suitable macaroon for interacting with this API. You could also use the surl command line, available as a snap:

snap install surl

to exercise this (and other) store APIs. The following example authenticates to the store and saves the macaroon locally for use in subsequent requests:

surl -a prod -s production -e <email> [[-p <macaroon_permission>]]

surl -a prod -X <http-method> https://dashboard.snapcraft.io/<endpoint> [[-d '<json payload>']]

See surl help for the details about these and other surl options.

The Confdb Schemas API is exposed at the following base URLs:

Response Format

JSON will be returned in all responses from the API, including error responses, please refer to the following section for details about the format.

Prepare confdb-schema assertion headers ready for signing.

Introduced in version 16

POST /api/v2/confdb-schemas/build-assertion

Prepare confdb-schema headers for local signing.

Return confdb-schema assertion headers ready for local signing by the publisher.

reqheader Authorization

macaroon authorization header for an active user

status 200

success

status 400

error

status 401

authentication required

Usage

As mentioned in the introduction, this endpoint can be exercised using the surl command as follows:

surl -s production -e your-email@example.com -X POST https://dashboard.snapcraft.io/api/v2/confdb-schemas/build-assertion -d '<input-data-as-json>'

where your-email@example.com has to be an existing account.

Example

Prepare assertion headers for a confdb-schema named “network”.

Request:

POST /api/v2/confdb-schemas/build-assertion HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...
Content-Type: application/json

{
    "account-id": "f22PSauKuNkwQTM9Wz67ZCjNACuSjjhN",
    "name": "network",
    "views": {
        "wifi-setup": {
            "rules": [
                {"request": "ssids", "storage": "wifi.ssids"},
                {"request": "ssid", "storage": "wifi.ssid", "access": "read-write"},
                {"request": "password", "storage": "wifi.psk", "access": "write"},
                {"request": "status", "storage": "wifi.status", "access": "read"},
                {"request": "private.{placeholder}", "storage": "wifi.{placeholder}"}
            ]
        }
    },
    "body": "{\n  \"storage\": {\n    \"schema\": {\n      \"wifi\": {\n        \"values\": \"any\"\n      }\n    }\n  }\n}",
    "timestamp": "2024-03-06T09:00:00Z"
}

Response:

HTTP/1.1 200 OK
Content-Type: application/json

{
    "type": "confdb-schema",
    "account-id": "f22PSauKuNkwQTM9Wz67ZCjNACuSjjhN",
    "authority-id": "f22PSauKuNkwQTM9Wz67ZCjNACuSjjhN",
    "name": "network",
    "revision": "0",
    "views": {
        "wifi-setup": {
            "rules": [
                {"request": "ssids", "storage": "wifi.ssids"},
                {"request": "ssid", "storage": "wifi.ssid", "access": "read-write"},
                {"request": "password", "storage": "wifi.psk", "access": "write"},
                {"request": "status", "storage": "wifi.status", "access": "read"},
                {"request": "private.{placeholder}", "storage": "wifi.{placeholder}"}
            ]
        }
    },
    "body": "{\n  \"storage\": {\n    \"schema\": {\n      \"wifi\": {\n        \"values\": \"any\"\n      }\n    }\n  }\n}",
    "timestamp": "2024-03-06T09:00:00Z"
}

Errors

Request payload contains a number of request JSON schema violations.

Request:

POST /api/v2/confdb-schemas/build-assertion HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...
Content-Type: application/json

{
    "surprise-field": 123,
    "name": "name",
    "views": [
        "wifi-setup": {
            "rules": [
                {"request": "ssids", "storage": "wifi.ssids"},
                {"request": "ssid", "storage": "wifi.ssid", "access": "read-write"},
                {"request": "password", "storage": "wifi.psk", "access": "write"},
                {"request": "status", "storage": "wifi.status", "access": "read"},
                {"request": "private.{placeholder}", "storage": "wifi.{placeholder}"}
            ]
        }
    ],
    "body": ""
}

Response:

HTTP/1.1 400 Bad Request
Content-Type: application/json

{
    "error-list": [
        {
            "message": "Additional properties are not allowed ('surprise-field' was unexpected) at /",
            "code": "invalid-request"
        },
        {
            "message": "'account-id' is a required property at /",
            "code": "invalid-request"
        }
    ]
}

Request JSON Schema

{
    "additionalProperties": false,
    "definitions": {
        "ContentRule": {
            "additionalProperties": false,
            "properties": {
                "access": {
                    "enum": [
                        "read",
                        "write",
                        "read-write"
                    ]
                },
                "content": {
                    "items": {
                        "oneOf": [
                            {
                                "$ref": "#/definitions/Rule"
                            },
                            {
                                "$ref": "#/definitions/ContentRule"
                            }
                        ]
                    },
                    "minItems": 1,
                    "type": "array"
                },
                "request": {
                    "minLength": 1,
                    "type": "string"
                },
                "storage": {
                    "minLength": 1,
                    "type": "string"
                }
            },
            "required": [
                "storage",
                "content"
            ],
            "type": "object"
        },
        "Rule": {
            "additionalProperties": false,
            "properties": {
                "access": {
                    "enum": [
                        "read",
                        "write",
                        "read-write"
                    ]
                },
                "request": {
                    "minLength": 1,
                    "type": "string"
                },
                "storage": {
                    "minLength": 1,
                    "type": "string"
                }
            },
            "required": [
                "storage"
            ],
            "type": "object"
        }
    },
    "properties": {
        "account-id": {
            "description": "Issuer of the confdb-schema assertion",
            "minLength": 1,
            "type": "string"
        },
        "body": {
            "type": "string"
        },
        "name": {
            "description": "Confdb-schema name",
            "minLength": 1,
            "type": "string"
        },
        "views": {
            "additionalProperties": false,
            "description": "Views in a confdb-schema assertion",
            "maxProperties": 1,
            "minProperties": 1,
            "patternProperties": {
                "^([a-z]-?)+[a-z]+$": {
                    "additionalProperties": false,
                    "minProperties": 1,
                    "properties": {
                        "filters": {
                            "items": {
                                "minProperties": 1,
                                "patternProperties": {
                                    "^.+$": {
                                        "additionalProperties": false,
                                        "properties": {
                                            "optional": {
                                                "type": "boolean"
                                            }
                                        },
                                        "type": "object"
                                    }
                                },
                                "type": "object"
                            },
                            "minItems": 1,
                            "type": "array"
                        },
                        "rules": {
                            "items": {
                                "anyOf": [
                                    {
                                        "$ref": "#/definitions/Rule"
                                    },
                                    {
                                        "$ref": "#/definitions/ContentRule"
                                    }
                                ]
                            },
                            "minItems": 1,
                            "type": "array"
                        }
                    },
                    "required": [
                        "rules"
                    ],
                    "type": "object"
                }
            },
            "propertyNames": {
                "maxLength": 128
            },
            "type": "object"
        }
    },
    "required": [
        "account-id",
        "name",
        "views",
        "body"
    ],
    "type": "object"
}

Manage account’s confdb-schema assertions.

Introduced in version 16

GET /api/v2/confdb-schemas/(?P<name>[\\w-]+)
POST /api/v2/confdb-schemas/(?P<name>[\\w-]+)

Manage account’s confdb-schema assertions.

Usage

As mentioned in the introduction, this endpoint can be exercised using the surl command as follows:

surl -s production -e your-email@example.com -X GET https://dashboard.snapcraft.io/api/v2/confdb-schemas

where your-email@example.com has to be an existing account.

GET /api/v2/confdb-schemas[/<name>]
reqheader Authorization

macaroon authorization header for a registered user

status 200

success

status 400

error

status 401

authentication required

GET requests to

  • /api/v2/confdb-schemas and

  • /api/v2/confdb-schemas/<name>,

return a list of headers for confdb-schema assertions registered by the requesting user, that match requested criteria.

By default, a GET request to /api/v2/confdb-schemas returns headers for all confdb-schemas owned by the requesting account, each at their latest revision. The same applies to /api/v2/confdb-schemas/<name>, except that the result will contain headers for one specific assertion.

GET Examples

Empty response: no confdb-schema assertions found.

Request:

GET /api/v2/confdb-schemas HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...

Response:

HTTP/1.1 200 OK
Content-Type: application/json

{
    "assertions": []
}

Fetch all (2 in this example) confdb-schema assertions owned by the requesting account.

Request:

GET /api/v2/confdb-schemas HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...

Response:

HTTP/1.1 200 OK
Content-Type: application/json

{
    "assertions": [
        {
            "headers": {
                "account-id": "AccountIDXXXOfTheRequestingUserX",
                "views": {
                    "wifi-setup": {
                        "rules": [
                            {
                                "request": "ssids",
                                "storage": "wifi.ssids"
                            },
                            {
                                "access": "read-write",
                                "request": "ssid",
                                "storage": "wifi.ssid"
                            },
                            {
                                "access": "write",
                                "request": "password",
                                "storage": "wifi.psk"
                            },
                            {
                                "access": "read",
                                "request": "status",
                                "storage": "wifi.status"
                            },
                            {
                                "request": "private.{placeholder}",
                                "storage": "wifi.{placeholder}"
                            }
                        ]
                    }
                },
                "authority-id": "AccountIDXXXOfTheRequestingUserX",
                "body-length": "92",
                "name": "network",
                "sign-key-sha3-384": "XSignXKeyXHashXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "timestamp": "2024-03-06T09:00:00Z",
                "type": "confdb-schema"
            },
            "body": "{\n  \"storage\": {\n    \"schema\": {\n      \"wifi\": {\n        \"values\": \"any\"\n      }\n    }\n  }\n}"
        },
        {
            "headers": {
                "account-id": "AccountIDXXXOfTheRequestingUserX",
                "views": {
                    "acme-views": {
                        "rules": [
                            {
                                "request": "acme-headers",
                                "storage": "acme.headers"
                            },
                        ]
                    }
                },
                "authority-id": "AccountIDXXXOfTheRequestingUserX",
                "body-length": "0",
                "name": "network",
                "sign-key-sha3-384": "XSignXKeyXHashXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "timestamp": "2024-03-06T09:00:00Z",
                "type": "confdb-schema"
            },
            "body": ""
        }
    ]
}

Fetch the confdb-schema assertion named ‘wifi-setup’ owned by the requesting account.

Request:

GET /api/v2/confdb-schemas/wifi-setup HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...

Response:

HTTP/1.1 200 OK
Content-Type: application/json

{
    "assertions": [
        {
            "headers": {
                "account-id": "AccountIDXXXOfTheRequestingUserX",
                "views": {
                    "wifi-setup": {
                        "rules": [
                            {
                                "request": "ssids",
                                "storage": "wifi.ssids"
                            },
                            {
                                "access": "read-write",
                                "request": "ssid",
                                "storage": "wifi.ssid"
                            },
                            {
                                "access": "write",
                                "request": "password",
                                "storage": "wifi.psk"
                            },
                            {
                                "access": "read",
                                "request": "status",
                                "storage": "wifi.status"
                            },
                            {
                                "request": "private.{placeholder}",
                                "storage": "wifi.{placeholder}"
                            }
                        ]
                    }
                },
                "authority-id": "AccountIDXXXOfTheRequestingUserX",
                "body-length": "92",
                "name": "network",
                "sign-key-sha3-384": "XSignXKeyXHashXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "timestamp": "2024-03-06T09:00:00Z",
                "type": "confdb-schema"
            },
            "body": "{\n  \"storage\": {\n    \"schema\": {\n      \"wifi\": {\n        \"values\": \"any\"\n      }\n    }\n  }\n}"
        }
    ]
}
POST /api/v2/confdb-schemas
reqheader Authorization

macaroon authorization header for a registered user

status 201

success

status 400

error

status 409

conflict

status 401

authentication required

POST requests to /api/v2/confdb-schemas are used to register new confdb-schema assertions with the store.

The endpoint expects a valid confdb-schema type assertion, signed with a signing key registered with the store. The endpoint expects an x.ubuntu.assertion content-type request.

/api/v2/confdb-schemas/build-assertion endpoint can be used to obtain confdb-schema assertion headers as JSON, to be used as an input to snap sign, which will sign the assertion and output it in the x.ubuntu.assertion format, ready for sending to /api/v2/confdb-schemas in a POST request.

POST Examples

Register a self signed confdb-schema assertion.

Request:

POST /api/v2/confdb-schemas HTTP/1.1
Host: dashboard.snapcraft.io
Authorization: Macaroon root=..., discharge=...
Content-Type: application/x.ubuntu.assertion

type: confdb-schema
authority-id: AccountIDXXXOfTheRequestingUserX
account-id: AccountIDXXXOfTheRequestingUserX
name: network
views:
wifi-setup:
    rules:
    -
        request: ssids
        storage: wifi.ssids
    -
        access: read-write
        request: ssid
        storage: wifi.ssid
    -
        access: write
        request: password
        storage: wifi.psk
    -
        access: read
        request: status
        storage: wifi.status
    -
        request: private.{placeholder}
        storage: wifi.{placeholder}
timestamp: 2024-03-06T09:00:00Z
body-length: 92
sign-key-sha3-384: XSignXKeyXHashXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

{
    "storage": {
        "schema": {
            "wifi": {
                "values": "any"
            }
        }
    }
}

<the-key>

Response:

HTTP/1.1 201 Created
Content-Type: application/json

{
    "assertions": [
        {
            "headers": {
                "account-id": "AccountIDXXXOfTheRequestingUserX",
                "views": {
                    "wifi-setup": {
                        "rules": [
                            {
                                "request": "ssids",
                                "storage": "wifi.ssids"
                            },
                            {
                                "access": "read-write",
                                "request": "ssid",
                                "storage": "wifi.ssid"
                            },
                            {
                                "access": "write",
                                "request": "password",
                                "storage": "wifi.psk"
                            },
                            {
                                "access": "read",
                                "request": "status",
                                "storage": "wifi.status"
                            },
                            {
                                "request": "private.{placeholder}",
                                "storage": "wifi.{placeholder}"
                            }
                        ]
                    }
                },
                "authority-id": "AccountIDXXXOfTheRequestingUserX",
                "body-length": "92",
                "name": "network",
                "sign-key-sha3-384": "XSignXKeyXHashXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
                "timestamp": "2024-03-06T09:00:00Z",
                "type": "confdb-schema"
            },
            "body": "{\n  \"storage\": {\n    \"schema\": {\n      \"wifi\": {\n        \"values\": \"any\"\n      }\n    }\n  }\n}"
        }
    ]
}

POST Errors

Response JSON Schema

{
    "additionalProperties": false,
    "properties": {
        "assertions": {
            "description": "List of confdb-schema assertions",
            "items": {
                "additionalProperties": false,
                "properties": {
                    "headers": {
                        "additionalProperties": false,
                        "description": "Assertion headers",
                        "properties": {
                            "account-id": {
                                "description": "The \"account-id\" assertion header",
                                "type": "string"
                            },
                            "authority-id": {
                                "description": "The \"authority-id\" assertion header",
                                "type": "string"
                            },
                            "name": {
                                "description": "The \"name\" assertion header",
                                "type": "string"
                            },
                            "sign-key-sha3-384": {
                                "description": "Signing key ID",
                                "type": "string"
                            },
                            "timestamp": {
                                "description": "The \"timestamp\" assertion header",
                                "type": "string"
                            },
                            "type": {
                                "const": "confdb-schema",
                                "description": "The \"type\" assertion header",
                                "type": "string"
                            },
                            "views": {
                                "additionalProperties": false,
                                "description": "Views in a confdb-schema assertion",
                                "maxProperties": 1,
                                "minProperties": 1,
                                "patternProperties": {
                                    "^([a-z]-?)+[a-z]+$": {
                                        "additionalProperties": false,
                                        "minProperties": 1,
                                        "properties": {
                                            "filters": {
                                                "items": {
                                                    "minProperties": 1,
                                                    "patternProperties": {
                                                        "^.+$": {
                                                            "additionalProperties": false,
                                                            "properties": {
                                                                "optional": {
                                                                    "type": "boolean"
                                                                }
                                                            },
                                                            "type": "object"
                                                        }
                                                    },
                                                    "type": "object"
                                                },
                                                "minItems": 1,
                                                "type": "array"
                                            },
                                            "rules": {
                                                "items": {
                                                    "anyOf": [
                                                        {
                                                            "$ref": "#/definitions/Rule"
                                                        },
                                                        {
                                                            "$ref": "#/definitions/ContentRule"
                                                        }
                                                    ]
                                                },
                                                "minItems": 1,
                                                "type": "array"
                                            }
                                        },
                                        "required": [
                                            "rules"
                                        ],
                                        "type": "object"
                                    }
                                },
                                "propertyNames": {
                                    "maxLength": 128
                                },
                                "type": "object"
                            }
                        },
                        "required": [
                            "type",
                            "authority-id",
                            "series",
                            "account-id",
                            "name",
                            "sequence",
                            "snaps",
                            "sign-key-sha3-384",
                            "timestamp"
                        ],
                        "type": "object"
                    }
                },
                "required": [
                    "headers"
                ],
                "type": "object"
            },
            "type": "array"
        }
    },
    "required": [
        "assertions"
    ],
    "type": "object"
}