Skip to main content
Version: 47.0.0

Service Catalog

The a9s Service Broker can provide different services and service plans. Which services and service plans are provided can be configured in the specific service config for each service, e.g. the postgresql.yml.example.

note

For the sake of simplicity, the examples provided in this section show only the relevant parts. The examples cannot be used like this!

Service Offering Object

You can have a list of Service Offerings under the key services. A Service Offering supports the following properties:

PropertyTypeDescription
name*stringThe name of the Service Offering. MUST be unique across all Service Offering objects that are returned by the a9s Service Broker. MUST be a non-empty string. Using a CLI-friendly name is RECOMMENDED.
guid*stringA GUID used to correlate this Service Offering in future requests to the a9s Service Broker. This MUST be globally unique such that Platforms (and their users) MUST be able to assume that seeing the same value (no matter what Service Broker uses it) will always refer to this Service Offering. MUST be a GUID.
description*stringA short description of the service. MUST be a non-empty string.
label*stringLabel used by a9s Service Broker.
version*stringThe version of the service (eg. 10 for PostgreSQL 10)
tagsarray of stringsTags provide a flexible mechanism to expose a classification, attribute, or base technology of a service, enabling equivalent services to be swapped out without changes to dependent logic in applications, buildpacks, or other services. E.g. mysql, relational, redis, key-value, caching, messaging, amqp.
requiresarray of stringsA list of permissions that the user would have to give the service, if they provision it. The only permissions currently supported are syslog_drain, route_forwarding and volume_mount.
bindable*booleanSpecifies whether Service Instances of the service can be bound to applications. This specifies the default for all Service Plans of this Service Offering. Service Plans can override this field (see Service Plan Object).
documentation_urlstringLink to the documentation of your service
metadataobjectAn opaque object of metadata for a Service Offering. It is expected that Platforms will treat this as a blob. Note that there are conventions in existing Service Brokers and Platforms for fields that aid in the display of catalog data.
dashboard_clientDashboardClientContains the data necessary to activate the Dashboard SSO feature for this service.
plans*array of Service Plan objectsA list of Service Plans for this Service Offering, schema is defined in Service Plans. MUST contain at least one Service Plan.
plans-to-test-for-release-update*array of stringsThese plans will be tested when the platform is updated to a new version. The smoke tests errand is the one responsible for executing these tests. The value for this key can be left empty []. See Service Plans for further information.
plans-to-test*array of stringsThese are the plans that are configured for the service broker and that should be tested. The smoke tests errand is the one responsible for executing these tests. The value for this key can be left empty []. See Service Plans for further information.
planupdates-to-test*array of stringsThese plans will be tested when the service is updated to another plan, e.g: postgresql-single-nano to postgresql-single-medium. The smoke tests errand is the one responsible for executing these tests. The value for this key can be left empty []. See the Service Plans documentation for further information.

NOTE: Fields with an asterisk (*) are REQUIRED.

Example:

postgresql_service:
services:
a9s-postgresql13:
name: a9s-postgresql13
guid: fd4b5214-4755-457a-9fc0-c1caa7e7a203
description: This is a service creating and managing dedicated PostgreSQL service instances and clusters, powered by the a9s Service Framework
label: a9s-postgresql
version: 11
bindable: true
requires: []
tags: [sql, database, object-relational, consistent]
documentation_url: https://docs.anynines.com/
metadata:
displayName: a9s PostgreSQL 13
supportUrl: https://anynines.atlassian.net/servicedesk/customer/portals
documentationUrl: https://docs.anynines.com/
shareable: true
dashboard_client:
id: a9s-postgresql-dashboard-client-id
plans:
postgresql-replica-small:
guid: 772dc604-4d1a-4946-8999-e8dd029d521f
description: A small replica set
free: true
template_name_v2: postgresql13-replica
default_placeholder_values:
vm_type: postgresql-replica-small-vm
persistent_disk_type: postgresql-replica-small-disk
migration_paths:
- postgresql-replica-medium
postgresql-replica-medium:
guid: d7b190d8-2829-4783-ac1b-6b39781d4c6a
description: A medium replica set
free: true
template_name_v2: postgresql13-replica
default_placeholder_values:
vm_type: postgresql-replica-medium-vm
persistent_disk_type: postgresql-replica-medium-disk
migration_paths: []
plans-to-test:
- postgresql-replica-medium
planupdates-to-test:
postgresql-single-small:
- postgresql-single-medium

Add Service Icons

You can add the official icons to the data service's metadata. This can be done by setting the imageUrl parameter, in the metadata section of each of the services' configuration, to the icon's Base64 encoded value as seen in the example below:

postgresql_service:
services:
a9s-postgresql13:
metadata:
imageUrl: 'data:image/png;base64,<BASE64ICON>'
caution

The imageUrl parameter has to be set per service.

This means that, for example, in the a9s PostgreSQL service it has to be done separately for a9s-postgresql11, a9s-postgresql13, etc.

You can find the official icons for each of the a9s Data Services, already encoded, in the tabs below:



Customize Support and Documentation URL

If you want to customize the support and/or documentation URL of a Service Offering, you can do so by replacing the values of supportUrl and/or documentationUrl with your own. These are located in the metadata property, of the Service Offering, as shown below:

postgresql_service:
services:
a9s-postgresql13:
metadata:
supportUrl: https://support.example.com/
documentationUrl: https://docs.example.com/

Add Service Plans

If you want to provide another Service Plan that is not offered by default, you can add your new Service Plan to the service config.

A new Service Plan with a larger VM and persistent disk could look the following:

postgresql-single-ultra:
guid: 8abb159a-b79e-41ee-a374-0a7dccf6723a
description: A ultra single instance
free: true
template_name_v2: postgresql13-single
default_placeholder_values:
vm_type: postgresql-single-ultra-vm
persistent_disk_type: postgresql-single-ultra-disk
migration_paths: []

Delete Service Plans

It is also possible to delete Service Plans for a given Service Offering. These Service Plans won't be provided by the a9s Service Broker. To do this you have to remove the configuration for the Service Plan you want to delete from the specific service config. Then you have to redeploy the service with the new service config.

note

Currently, it is not possible to delete a Service Plan, which has an existing Service Instance. Only unused Service Plans can be deleted.