REST Resource: projects.locations.unitKinds

Resource: UnitKind

Definition of a Unit. Units belonging to the same UnitKind are managed together; for example they follow the same release model (blueprints, versions etc.) and are typically rolled out together.

JSON representation
{
  "name": string,
  "defaultRelease": string,
  "dependencies": [
    {
      object (Dependency)
    }
  ],
  "inputVariableMappings": [
    {
      object (VariableMapping)
    }
  ],
  "outputVariableMappings": [
    {
      object (VariableMapping)
    }
  ],
  "saas": string,
  "labels": {
    string: string,
    ...
  },
  "annotations": {
    string: string,
    ...
  },
  "uid": string,
  "etag": string,
  "createTime": string,
  "updateTime": string
}
Fields
name

string

Identifier. The resource name (full URI of the resource) following the standard naming scheme:

"projects/{project}/locations/{location}/unitKinds/{unitKind}"

defaultRelease

string

Optional. A reference to the Release object to use as default for creating new units of this UnitKind (optional).

If not specified, a new unit must explicitly reference which release to use for its creation.

dependencies[]

object (Dependency)

Optional. Immutable. List of other unit kinds that this release will depend on. Dependencies will be automatically provisioned if not found. Maximum 10.

inputVariableMappings[]

object (VariableMapping)

Optional. List of inputVariables for this release that will either be retrieved from a dependency's outputVariables, or will be passed on to a dependency's inputVariables. Maximum 100.

outputVariableMappings[]

object (VariableMapping)

Optional. List of outputVariables for this unit kind will be passed to this unit's outputVariables. Maximum 100.

saas

string

Required. Immutable. A reference to the Saas that defines the product (managed service) that the producer wants to manage with EasySaaS. Part of the EasySaaS common data model. Immutable once set.

labels

map (key: string, value: string)

Optional. The labels on the resource, which can be used for categorization. similar to Kubernetes resource labels.

An object containing a list of "key": value pairs. Example: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

annotations

map (key: string, value: string)

Optional. Annotations is an unstructured key-value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects.

More info: https://kubernetes.io/docs/user-guide/annotations

An object containing a list of "key": value pairs. Example: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

uid

string

Output only. The unique identifier of the resource. UID is unique in the time and space for this resource within the scope of the service. It is typically generated by the server on successful creation of a resource and must not be changed. UID is used to uniquely identify resources with resource name reuses. This should be a UUID4.

etag

string

Output only. An opaque value that uniquely identifies a version or generation of a resource. It can be used to confirm that the client and server agree on the ordering of a resource being written.

createTime

string (Timestamp format)

Output only. The timestamp when the resource was created.

Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" or "2014-10-02T15:01:23+05:30".

updateTime

string (Timestamp format)

Output only. The timestamp when the resource was last updated. Any change to the resource made by users must refresh this value. Changes to a resource made by the service should refresh this value.

Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" or "2014-10-02T15:01:23+05:30".

Dependency

Dependency represent a single dependency with another unit kind by alias.

JSON representation
{
  "unitKind": string,
  "alias": string
}
Fields
unitKind

string

Required. Immutable. The unit kind of the dependency.

alias

string

Required. An alias for the dependency. Used for input variable mapping.

VariableMapping

Mapping of input variables to their respective output variable for depedenencies

JSON representation
{
  "variable": string,

  // Union field mapping_type can be only one of the following:
  "from": {
    object (FromMapping)
  },
  "to": {
    object (ToMapping)
  }
  // End of list of possible types for union field mapping_type.
}
Fields
variable

string

Required. name of the variable

Union field mapping_type.

mapping_type can be only one of the following:

from

object (FromMapping)

Optional. Output variables which will get their values from dependencies

to

object (ToMapping)

Optional. Input variables whose values will be passed on to dependencies.

FromMapping

Output variables whose values will be passed on to dependencies

JSON representation
{
  "dependency": string,
  "outputVariable": string
}
Fields
dependency

string

Required. Alias of the dependency that the outputVariable will pass its value to

outputVariable

string

Required. Name of the outputVariable on the dependency

ToMapping

Input variables whose values will be passed on to dependencies

JSON representation
{
  "dependency": string,
  "inputVariable": string,
  "ignoreForLookup": boolean
}
Fields
dependency

string

Required. Alias of the dependency that the inputVariable will pass its value to

inputVariable

string

Required. Name of the inputVariable on the dependency

ignoreForLookup

boolean

Optional. Tells EasySaaS if this mapping should be used during lookup or not

Methods

create

Create a new unit kind.

delete

Delete a single unit kind.

get

Retrieve a single unit kind.

list

Retrieve a collection of unit kinds.

patch

Update a single unit kind.