Definitions for @turbot/gcp-memorystore

instance

{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"displayName": {
"type": "string"
},
"labels": {
"$ref": "gcp#/definitions/labels"
},
"locationId": {
"type": "string"
},
"alternativeLocationId": {
"type": "string"
},
"redisVersion": {
"type": "string"
},
"reservedIpRange": {
"type": "string"
},
"secondaryIpRange": {
"type": "string"
},
"host": {
"type": "string"
},
"port": {
"type": "integer"
},
"currentLocationId": {
"type": "string"
},
"createTime": {
"type": "string"
},
"state": {
"$ref": "#/definitions/instanceState"
},
"statusMessage": {
"type": "string"
},
"redisConfigs": {
"type": "object"
},
"tier": {
"$ref": "#/definitions/instanceTier"
},
"memorySizeGb": {
"type": "integer"
},
"authorizedNetwork": {
"type": "string"
},
"persistenceIamIdentity": {
"type": "string"
},
"connectMode": {
"$ref": "#/definitions/instanceConnectMode"
},
"authEnabled": {
"type": "boolean"
},
"serverCaCerts": {
"type": "array"
},
"transitEncryptionMode": {
"$ref": "#/definitions/instanceTransitEncryptionMode"
},
"maintenancePolicy": {
"type": "object"
},
"maintenanceSchedule": {
"type": "object"
},
"replicaCount": {
"type": "integer"
},
"nodes": {
"type": "array"
},
"readEndpoint": {
"type": "string"
},
"readEndpointPort": {
"type": "integer"
},
"readReplicasMode": {
"$ref": "#/definitions/instanceReadReplicasMode"
},
"customerManagedKey": {
"type": "string"
},
"persistenceConfig": {
"type": "object"
},
"suspensionReasons": {
"type": "array"
},
"turbot": {
"type": "object",
"properties": {
"akas": {
"type": "array",
"items": {
"$ref": "#/definitions/instanceAka"
}
},
"tags": {
"$ref": "gcp#/definitions/labels"
},
"title": {
"$ref": "#/definitions/instanceName"
},
"custom": {
"type": "object",
"properties": {
"createTimestamp": {
"$ref": "turbot#/definitions/isoTimestamp"
},
"gcp": {
"$ref": "gcp#/definitions/gcpMetadata"
}
}
}
}
}
},
"additionalProperties": true,
"tests": [
{
"description": "all details provided",
"input": {
"name": "projects/project1/locations/us-east1/instances/instance-01",
"parent": "projects/project1/locations/us-east1",
"labels": {
"foo": "bar",
"foo1": "bar1"
},
"turbot": {
"akas": [
"gcp://redis.googleapis.com/projects/project1/locations/us-east1/instances/instance-01"
],
"tags": {
"foo": "bar",
"foo1": "bar1"
},
"title": "projects/project1/locations/us-east1/instances/instance-01",
"custom": {
"createTimestamp": "2017-03-05T13:58:05.590Z",
"gcp": {
"projectId": "project1",
"regionName": "us-east1"
}
}
}
}
},
{
"description": "invalid - name property is missing",
"input": {
"parent": "projects/project1/locations/us-east1",
"labels": {
"foo": "bar",
"foo1": "bar1"
},
"turbot": {
"akas": [
"gcp://redis.googleapis.com/projects/project1/locations/us-east1/instances/instance-01"
],
"tags": {
"foo": "bar",
"foo1": "bar1"
},
"title": "projects/project1/locations/us-east1/instances/instance-01",
"custom": {
"createTimestamp": "2017-03-05T13:58:05.590Z",
"gcp": {
"projectId": "project1",
"regionName": "us-east1"
}
}
}
},
"expected": true
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instance",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

Instance

{
"description": "A Memorystore for Redis instance.",
"properties": {
"alternativeLocationId": {
"description": "Optional. If specified, at least one node will be provisioned in this zone in addition to the zone specified in location_id. Only applicable to standard tier. If provided, it must be a different zone from the one provided in [location_id]. Additional nodes beyond the first 2 will be placed in zones selected by the service.",
"type": "string"
},
"authEnabled": {
"description": "Optional. Indicates whether OSS Redis AUTH is enabled for the instance. If set to \"true\" AUTH is enabled on the instance. Default value is \"false\" meaning AUTH is disabled.",
"type": "boolean"
},
"authorizedNetwork": {
"description": "Optional. The full name of the Google Compute Engine [network](https://cloud.google.com/vpc/docs/vpc) to which the instance is connected. If left unspecified, the `default` network will be used.",
"type": "string"
},
"connectMode": {
"description": "Optional. The network connect mode of the Redis instance. If not provided, the connect mode defaults to DIRECT_PEERING.",
"enum": [
"CONNECT_MODE_UNSPECIFIED",
"DIRECT_PEERING",
"PRIVATE_SERVICE_ACCESS"
],
"type": "string"
},
"createTime": {
"description": "Output only. The time the instance was created.",
"readOnly": true,
"type": "string"
},
"currentLocationId": {
"description": "Output only. The current zone where the Redis primary node is located. In basic tier, this will always be the same as [location_id]. In standard tier, this can be the zone of any node in the instance.",
"readOnly": true,
"type": "string"
},
"customerManagedKey": {
"description": "Optional. The KMS key reference that the customer provides when trying to create the instance.",
"type": "string"
},
"displayName": {
"description": "An arbitrary and optional user-provided name for the instance.",
"type": "string"
},
"host": {
"description": "Output only. Hostname or IP address of the exposed Redis endpoint used by clients to connect to the service.",
"readOnly": true,
"type": "string"
},
"labels": {
"additionalProperties": {
"type": "string"
},
"description": "Resource labels to represent user provided metadata",
"type": "object"
},
"locationId": {
"description": "Optional. The zone where the instance will be provisioned. If not provided, the service will choose a zone from the specified region for the instance. For standard tier, additional nodes will be added across multiple zones for protection against zonal failures. If specified, at least one node will be provisioned in this zone.",
"type": "string"
},
"maintenancePolicy": {
"$ref": "#/definitions/MaintenancePolicy",
"description": "Optional. The maintenance policy for the instance. If not provided, maintenance events can be performed at any time."
},
"maintenanceSchedule": {
"$ref": "#/definitions/MaintenanceSchedule",
"description": "Output only. Date and time of upcoming maintenance events which have been scheduled.",
"readOnly": true
},
"memorySizeGb": {
"description": "Required. Redis memory size in GiB.",
"type": "integer"
},
"name": {
"description": "Required. Unique name of the resource in this scope including project and location using the form: `projects/{project_id}/locations/{location_id}/instances/{instance_id}` Note: Redis instances are managed and addressed at regional level so location_id here refers to a GCP region; however, users may choose which specific zone (or collection of zones for cross-zone instances) an instance should be provisioned in. Refer to location_id and alternative_location_id fields for more details.",
"type": "string"
},
"nodes": {
"description": "Output only. Info per node.",
"items": {
"$ref": "#/definitions/NodeInfo"
},
"readOnly": true,
"type": "array"
},
"persistenceConfig": {
"$ref": "#/definitions/PersistenceConfig",
"description": "Optional. Persistence configuration parameters"
},
"persistenceIamIdentity": {
"description": "Output only. Cloud IAM identity used by import / export operations to transfer data to/from Cloud Storage. Format is \"serviceAccount:\". The value may change over time for a given instance so should be checked before each import/export operation.",
"readOnly": true,
"type": "string"
},
"port": {
"description": "Output only. The port number of the exposed Redis endpoint.",
"readOnly": true,
"type": "integer"
},
"readEndpoint": {
"description": "Output only. Hostname or IP address of the exposed readonly Redis endpoint. Standard tier only. Targets all healthy replica nodes in instance. Replication is asynchronous and replica nodes will exhibit some lag behind the primary. Write requests must target 'host'.",
"readOnly": true,
"type": "string"
},
"readEndpointPort": {
"description": "Output only. The port number of the exposed readonly redis endpoint. Standard tier only. Write requests should target 'port'.",
"readOnly": true,
"type": "integer"
},
"readReplicasMode": {
"description": "Optional. Read replicas mode for the instance. Defaults to READ_REPLICAS_DISABLED.",
"enum": [
"READ_REPLICAS_MODE_UNSPECIFIED",
"READ_REPLICAS_DISABLED",
"READ_REPLICAS_ENABLED"
],
"type": "string"
},
"redisConfigs": {
"additionalProperties": {
"type": "string"
},
"description": "Optional. Redis configuration parameters, according to http://redis.io/topics/config. Currently, the only supported parameters are: Redis version 3.2 and newer: * maxmemory-policy * notify-keyspace-events Redis version 4.0 and newer: * activedefrag * lfu-decay-time * lfu-log-factor * maxmemory-gb Redis version 5.0 and newer: * stream-node-max-bytes * stream-node-max-entries",
"type": "object"
},
"redisVersion": {
"description": "Optional. The version of Redis software. If not provided, latest supported version will be used. Currently, the supported values are: * `REDIS_3_2` for Redis 3.2 compatibility * `REDIS_4_0` for Redis 4.0 compatibility (default) * `REDIS_5_0` for Redis 5.0 compatibility * `REDIS_6_X` for Redis 6.x compatibility",
"type": "string"
},
"replicaCount": {
"description": "Optional. The number of replica nodes. The valid range for the Standard Tier with read replicas enabled is [1-5] and defaults to 2. If read replicas are not enabled for a Standard Tier instance, the only valid value is 1 and the default is 1. The valid value for basic tier is 0 and the default is also 0.",
"type": "integer"
},
"reservedIpRange": {
"description": "Optional. For DIRECT_PEERING mode, the CIDR range of internal addresses that are reserved for this instance. Range must be unique and non-overlapping with existing subnets in an authorized network. For PRIVATE_SERVICE_ACCESS mode, the name of one allocated IP address ranges associated with this private service access connection. If not provided, the service will choose an unused /29 block, for example, 10.0.0.0/29 or 192.168.0.0/29. For READ_REPLICAS_ENABLED the default block size is /28.",
"type": "string"
},
"secondaryIpRange": {
"description": "Optional. Additional IP range for node placement. Required when enabling read replicas on an existing instance. For DIRECT_PEERING mode value must be a CIDR range of size /28, or \"auto\". For PRIVATE_SERVICE_ACCESS mode value must be the name of an allocated address range associated with the private service access connection, or \"auto\".",
"type": "string"
},
"serverCaCerts": {
"description": "Output only. List of server CA certificates for the instance.",
"items": {
"$ref": "#/definitions/TlsCertificate"
},
"readOnly": true,
"type": "array"
},
"state": {
"description": "Output only. The current state of this instance.",
"enum": [
"STATE_UNSPECIFIED",
"CREATING",
"READY",
"UPDATING",
"DELETING",
"REPAIRING",
"MAINTENANCE",
"IMPORTING",
"FAILING_OVER"
],
"readOnly": true,
"type": "string"
},
"statusMessage": {
"description": "Output only. Additional information about the current status of this instance, if available.",
"readOnly": true,
"type": "string"
},
"suspensionReasons": {
"description": "Optional. reasons that causes instance in \"SUSPENDED\" state.",
"items": {
"enum": [
"SUSPENSION_REASON_UNSPECIFIED",
"CUSTOMER_MANAGED_KEY_ISSUE"
],
"type": "string"
},
"type": "array"
},
"tier": {
"description": "Required. The service tier of the instance.",
"enum": [
"TIER_UNSPECIFIED",
"BASIC",
"STANDARD_HA"
],
"type": "string"
},
"transitEncryptionMode": {
"description": "Optional. The TLS mode of the Redis instance. If not provided, TLS is disabled for the instance.",
"enum": [
"TRANSIT_ENCRYPTION_MODE_UNSPECIFIED",
"SERVER_AUTHENTICATION",
"DISABLED"
],
"type": "string"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/Instance",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceAka

{
"type": "string",
"pattern": "^gcp://redis.googleapis.com/projects/[^/]+/locations/[^/]+/instances/[a-z][-a-z0-9]{0,39}$",
"tests": [
{
"input": "gcp://redis.googleapis.com/projects/project1/locations/location1/instances/instance-01"
},
{
"description": "invalid - project id is missing",
"input": "gcp://redis.googleapis.com/projects//locations/location1/instances/instance-01",
"expected": false
},
{
"description": "invalid - location id not provided",
"input": "gcp://redis.googleapis.com/projects/project1/locations//instances/instance-01",
"expected": false
},
{
"description": "invalid - instance id is missing",
"input": "gcp://redis.googleapis.com/projects/project1/locations/location1/instances/",
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceAka",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceConnectMode

{
"type": "string",
"enum": [
"CONNECT_MODE_UNSPECIFIED",
"DIRECT_PEERING",
"PRIVATE_SERVICE_ACCESS"
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceConnectMode",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceName

{
"type": "string",
"pattern": "^projects/[^/]+/locations/[^/]+/instances/[a-z][-a-z0-9]{0,39}$",
"tests": [
{
"input": "projects/project1/locations/location1/instances/instance-01"
},
{
"description": "invalid - project id is missing",
"input": "projects//locations/location1/instances/instance-01",
"expected": false
},
{
"description": "invalid - location id not provided",
"input": "projects/project1/locations//instances/instance-01",
"expected": false
},
{
"description": "invalid - instance id is missing",
"input": "projects/project1/locations/location1/instances/",
"expected": false
},
{
"description": "invalid - instance id started with uppercase",
"input": "projects/project1/locations/location1/instances/Instance-01",
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceName",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceReadReplicasMode

{
"type": "string",
"enum": [
"READ_REPLICAS_MODE_UNSPECIFIED",
"READ_REPLICAS_DISABLED",
"READ_REPLICAS_ENABLED"
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceReadReplicasMode",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceState

{
"type": "string",
"enum": [
"READY",
"STATE_UNSPECIFIED",
"UPDATING",
"DELETING",
"REPAIRING",
"MAINTENANCE",
"IMPORTING",
"FAILING_OVER",
"CREATING"
],
"tests": [
{
"input": "READY"
},
{
"input": "FAILING_OVER"
},
{
"description": "invalid - empty string",
"input": "",
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceState",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceTier

{
"type": "string",
"enum": [
"TIER_UNSPECIFIED",
"BASIC",
"STANDARD_HA"
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceTier",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

instanceTransitEncryptionMode

{
"type": "string",
"enum": [
"TRANSIT_ENCRYPTION_MODE_UNSPECIFIED",
"SERVER_AUTHENTICATION",
"DISABLED"
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/instanceTransitEncryptionMode",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

MaintenancePolicy

{
"description": "Maintenance policy for an instance.",
"properties": {
"createTime": {
"description": "Output only. The time when the policy was created.",
"readOnly": true,
"type": "string"
},
"description": {
"description": "Optional. Description of what this policy is for. Create/Update methods return INVALID_ARGUMENT if the length is greater than 512.",
"type": "string"
},
"updateTime": {
"description": "Output only. The time when the policy was last updated.",
"readOnly": true,
"type": "string"
},
"weeklyMaintenanceWindow": {
"description": "Optional. Maintenance window that is applied to resources covered by this policy. Minimum 1. For the current version, the maximum number of weekly_window is expected to be one.",
"items": {
"$ref": "#/definitions/WeeklyMaintenanceWindow"
},
"type": "array"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/MaintenancePolicy",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

MaintenanceSchedule

{
"description": "Upcoming maintenance schedule. If no maintenance is scheduled, fields are not populated.",
"properties": {
"canReschedule": {
"description": "If the scheduled maintenance can be rescheduled, default is true.",
"type": "boolean"
},
"endTime": {
"description": "Output only. The end time of any upcoming scheduled maintenance for this instance.",
"readOnly": true,
"type": "string"
},
"scheduleDeadlineTime": {
"description": "Output only. The deadline that the maintenance schedule start time can not go beyond, including reschedule.",
"readOnly": true,
"type": "string"
},
"startTime": {
"description": "Output only. The start time of any upcoming scheduled maintenance for this instance.",
"readOnly": true,
"type": "string"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/MaintenanceSchedule",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

memorystore

{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"state": {
"$ref": "gcp#/definitions/state"
},
"parent": {
"type": "string"
},
"config": {
"type": "object"
},
"turbot": {
"type": "object",
"properties": {
"akas": {
"type": "array",
"items": {
"$ref": "#/definitions/memorystoreAka"
}
},
"title": {
"type": "string"
},
"custom": {
"type": "object",
"properties": {
"gcp": {
"$ref": "gcp#/definitions/gcpMetadata"
}
}
}
}
}
},
"tests": [
{
"description": "Valid - base test",
"input": {
"name": "projects/932405488407/services/redis.googleapis.com",
"turbot": {
"akas": [
"gcp://serviceusage.googleapis.com/projects/932405488407/services/redis.googleapis.com"
],
"title": "Memorystore",
"custom": {
"gcp": {
"projectId": "cse-legolas-2"
}
}
}
}
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/memorystore",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

memorystoreAka

{
"type": "string",
"pattern": "^gcp://serviceusage.googleapis.com/projects/[0-9]{12}/services/redis.googleapis.com$",
"tests": [
{
"descritpion": "base case",
"input": "gcp://serviceusage.googleapis.com/projects/932405488407/services/redis.googleapis.com"
},
{
"description": "invalid - service name is in correct",
"input": "gcp://serviceusage.googleapis.com/projects/932405488407/services/redish.googleapis.com",
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/memorystoreAka",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

memorystoreSupportedRegions

{
"type": "array",
"items": {
"$ref": "#/definitions/regionName"
},
"minItems": 1,
"example": [
[
"us-central1",
"us-east1"
]
],
"default": [
"asia-east1",
"asia-northeast1",
"asia-southeast1",
"australia-southeast1",
"europe-north1",
"europe-west1",
"europe-west2",
"europe-west3",
"europe-west4",
"us-central1",
"us-east1",
"us-east4",
"us-west1",
"us-west2"
],
"tests": [
{
"description": "one region",
"input": [
"us-east1"
]
},
{
"description": "all supported regions",
"input": [
"asia-east1",
"asia-northeast1",
"asia-southeast1",
"australia-southeast1",
"europe-north1",
"europe-west1",
"europe-west2",
"europe-west3",
"europe-west4",
"us-central1",
"us-east1",
"us-east4",
"us-west1",
"us-west2"
]
},
{
"description": "invalid - no regions",
"input": [],
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/memorystoreSupportedRegions",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

NodeInfo

{
"description": "Node specific properties.",
"properties": {
"id": {
"description": "Output only. Node identifying string. e.g. 'node-0', 'node-1'",
"readOnly": true,
"type": "string"
},
"zone": {
"description": "Output only. Location of the node.",
"readOnly": true,
"type": "string"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/NodeInfo",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

PersistenceConfig

{
"description": "Configuration of the persistence functionality.",
"properties": {
"persistenceMode": {
"description": "Optional. Controls whether Persistence features are enabled. If not provided, the existing value will be used.",
"enum": [
"PERSISTENCE_MODE_UNSPECIFIED",
"DISABLED",
"RDB"
],
"type": "string"
},
"rdbNextSnapshotTime": {
"description": "Output only. The next time that a snapshot attempt is scheduled to occur.",
"readOnly": true,
"type": "string"
},
"rdbSnapshotPeriod": {
"description": "Optional. Period between RDB snapshots. Snapshots will be attempted every period starting from the provided snapshot start time. For example, a start time of 01/01/2033 06:45 and SIX_HOURS snapshot period will do nothing until 01/01/2033, and then trigger snapshots every day at 06:45, 12:45, 18:45, and 00:45 the next day, and so on. If not provided, TWENTY_FOUR_HOURS will be used as default.",
"enum": [
"SNAPSHOT_PERIOD_UNSPECIFIED",
"ONE_HOUR",
"SIX_HOURS",
"TWELVE_HOURS",
"TWENTY_FOUR_HOURS"
],
"type": "string"
},
"rdbSnapshotStartTime": {
"description": "Optional. Date and time that the first snapshot was/will be attempted, and to which future snapshots will be aligned. If not provided, the current time will be used.",
"type": "string"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/PersistenceConfig",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

regionName

{
"type": "string",
"enum": [
"asia-east1",
"asia-northeast1",
"asia-southeast1",
"australia-southeast1",
"europe-north1",
"europe-west1",
"europe-west2",
"europe-west3",
"europe-west4",
"us-central1",
"us-east1",
"us-east4",
"us-west1",
"us-west2"
],
"tests": [
{
"description": "valid",
"input": "us-east1"
},
{
"description": "invalid - usea1",
"input": "usea1",
"expected": false
},
{
"description": "invalid - au-north-1",
"input": "au-north-1",
"expected": false
}
],
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/regionName",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

TimeOfDay

{
"description": "Represents a time of day. The date and time zone are either not significant or are specified elsewhere. An API may choose to allow leap seconds. Related types are google.type.Date and `google.protobuf.Timestamp`.",
"properties": {
"hours": {
"description": "Hours of day in 24 hour format. Should be from 0 to 23. An API may choose to allow the value \"24:00:00\" for scenarios like business closing time.",
"type": "integer"
},
"minutes": {
"description": "Minutes of hour of day. Must be from 0 to 59.",
"type": "integer"
},
"nanos": {
"description": "Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999.",
"type": "integer"
},
"seconds": {
"description": "Seconds of minutes of the time. Must normally be from 0 to 59. An API may allow the value 60 if it allows leap-seconds.",
"type": "integer"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/TimeOfDay",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

TlsCertificate

{
"description": "TlsCertificate Resource",
"properties": {
"cert": {
"description": "PEM representation.",
"type": "string"
},
"createTime": {
"description": "Output only. The time when the certificate was created in [RFC 3339](https://tools.ietf.org/html/rfc3339) format, for example `2020-05-18T00:00:00.094Z`.",
"readOnly": true,
"type": "string"
},
"expireTime": {
"description": "Output only. The time when the certificate expires in [RFC 3339](https://tools.ietf.org/html/rfc3339) format, for example `2020-05-18T00:00:00.094Z`.",
"readOnly": true,
"type": "string"
},
"serialNumber": {
"description": "Serial number, as extracted from the certificate.",
"type": "string"
},
"sha1Fingerprint": {
"description": "Sha1 Fingerprint of the certificate.",
"type": "string"
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/TlsCertificate",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}

WeeklyMaintenanceWindow

{
"description": "Time window in which disruptive maintenance updates occur. Non-disruptive updates can occur inside or outside this window.",
"properties": {
"day": {
"description": "Required. The day of week that maintenance updates occur.",
"enum": [
"DAY_OF_WEEK_UNSPECIFIED",
"MONDAY",
"TUESDAY",
"WEDNESDAY",
"THURSDAY",
"FRIDAY",
"SATURDAY",
"SUNDAY"
],
"type": "string"
},
"duration": {
"description": "Output only. Duration of the maintenance window. The current window is fixed at 1 hour.",
"readOnly": true,
"type": "string"
},
"startTime": {
"$ref": "#/definitions/TimeOfDay",
"description": "Required. Start time of the window in UTC time."
}
},
"type": "object",
".turbot": {
"uri": "tmod:@turbot/gcp-memorystore#/definitions/WeeklyMaintenanceWindow",
"modUri": "tmod:@turbot/gcp-memorystore"
}
}