Returns the specified GCP cloud config
GET/v1/cloudconfigs/gcp/:configUid
Returns the specified GCP cloud config
Request​
Path Parameters
Cluster's cloud config uid
Header Parameters
Scope the request to the specified project uid
Responses​
- 200
OK
- application/json
- Schema
- Example (from schema)
Schema
- Array [
- Array [
- ]
- ]
- Array [
- ]
Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
metadata object
ObjectMeta is metadata that all persisted resources must have, which includes all objects users must create.
annotations object
Annotations are system generated key value metadata for the resource. As an input certain annotations like description can be set
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
labels object
Labels are key value data to organize and categorize resources. Providing spectro__tag as value for a label is considered as a kubernetes compliant tag
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
Name of the resource
UID is the unique identifier generated for the resource. This is not an input field for any request.
Populated by the system. Read-only.
spec object
GcpCloudConfigSpec defines the cloud configuration input by user This will translate to clusterspec/machinespec for cluster-api
cloudAccountRef object
ObjectReference contains enough information to let you inspect or modify the referred object.
Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids
clusterConfig object
Cluster level configuration for gcp cloud and applicable for all the machine pools
managedClusterConfig object
GCP managed cluster config
EnableAutopilot indicates whether to enable autopilot for this GKE cluster
Can be Region or Zone
NetworkName if empty would create VPC Network in auto mode. If provided, custom VPC network will be used
Name of the project in which cluster is to be deployed
GCP region for the cluster
machinePoolConfig object[]
additionalLabels object
additionalLabels
additionalTags object
AdditionalTags is an optional set of tags to add to resources managed by the provider, in addition to the ones added by default. For eg., tags for EKS nodeGroup or EKS NodegroupIAMRole
instanceConfig
MemoryMiB is the size of a virtual machine's memory, in MiB
NumCPUs is the number of virtual processors in a virtual machine
whether this pool is for control plane
labels for this pool, example: master/worker, gpu, windows
machinePoolProperties object
Machine pool specific properties
Possible values: [amd64
, arm64
]
Default value: amd64
Architecture type of the pool. Default value is 'amd64'
max size of the pool, for scaling
min size of the pool, for scaling
Minimum number of seconds a node should be Ready, before the next node is selected for repave. Applicable only for workerpools in infrastructure cluster
Size of root volume in GB. Default is 30GB
size of the pool, number of machines
Subnet specifies the subnetwork to use for given instance. If not specified, the first subnet from the cluster region and network is used
subnetIds object
AZ to subnet mapping filled by ally from hubble SubnetIDs ["us-west-2d"] = "subnet-079b6061" This field is optional If we don't provide a subnetId then by default the first private subnet from the AZ will be picked up for deployment
taints object[]
master or worker taints
Possible values: [NoSchedule
, PreferNoSchedule
, NoExecute
]
The taint key to be applied to a node
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
The taint value corresponding to the taint key.
updateStrategy object
rolling update strategy for this machinepool if not specified, will use ScaleOut
Possible values: [RollingUpdateScaleOut
, RollingUpdateScaleIn
]
update strategy, either ScaleOut or ScaleIn if empty, will default to RollingUpdateScaleOut
if IsControlPlane==true && useControlPlaneAsWorker==true, then will remove master taint this will not be used for worker pools
status object
GcpCloudConfigStatus defines the observed state of GcpCloudConfig The cloudimage info built by Mold is stored here image should be mapped to a specific machinepool
For mold controller to identify if is there any changes in Pack
conditions object[]
spectroAnsibleProvisioner: should be added only once, subsequent recocile will use the same provisioner SpectroAnsiblePacker bool json:"spectroAnsiblePacker,omitempty"
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
Time is a wrapper around time.Time which supports correct marshaling to YAML and JSON. Wrappers are provided for many of the factory methods that the time package offers.
Human-readable message indicating details about last transition.
Unique, one-word, CamelCase reason for the condition's last transition.
images object
Images array items should be 1-to-1 mapping to Spec.MachinePoolConfig
addon layers present in spc
roleDigest object
this map will be for ansible roles present in each pack
sourceImageId, it can be from packref's annotations or from pack.json
PackerVariableDigest string json:"packerDigest,omitempty"
If no ansible roles found in Packs then Mold should tell Drive to use capi image and not create custom image, because there is nothing to add
{
"kind": "string",
"metadata": {
"annotations": {},
"creationTimestamp": "2023-12-01T21:31:48.310Z",
"deletionTimestamp": "2023-12-01T21:31:48.310Z",
"labels": {},
"lastModifiedTimestamp": "2023-12-01T21:31:48.310Z",
"name": "string",
"uid": "string"
},
"spec": {
"cloudAccountRef": {
"kind": "string",
"name": "string",
"uid": "string"
},
"clusterConfig": {
"managedClusterConfig": {
"enableAutoPilot": true,
"location": "string"
},
"network": "string",
"project": "string",
"region": "string"
},
"machinePoolConfig": [
{
"additionalLabels": {},
"additionalTags": {},
"azs": [
"string"
],
"instanceConfig": {
"category": "string",
"cpuSet": 0,
"diskGiB": 0,
"memoryMiB": 0,
"name": "string",
"numCPUs": 0
},
"instanceType": "string",
"isControlPlane": true,
"labels": [
"string"
],
"machinePoolProperties": {
"archType": "amd64"
},
"maxSize": 0,
"minSize": 0,
"name": "string",
"nodeRepaveInterval": 0,
"rootDeviceSize": 0,
"size": 0,
"subnet": "string",
"subnetIds": {},
"taints": [
{
"effect": "NoSchedule",
"key": "string",
"timeAdded": "2023-12-01T21:31:48.310Z",
"value": "string"
}
],
"updateStrategy": {
"type": "RollingUpdateScaleOut"
},
"useControlPlaneAsWorker": true
}
]
},
"status": {
"ansibleRoleDigest": "string",
"conditions": [
{
"lastProbeTime": "2023-12-01T21:31:48.311Z",
"lastTransitionTime": "2023-12-01T21:31:48.311Z",
"message": "string",
"reason": "string",
"status": "string",
"type": "string"
}
],
"images": {
"name": "string",
"os": "string",
"region": "string",
"state": "string"
},
"isAddonLayer": true,
"roleDigest": {},
"sourceImageId": "string",
"useCapiImage": true
}
}