feat: Add new gcloud commands, API clients, and third-party libraries across various services.

This commit is contained in:
2026-01-01 20:26:35 +01:00
parent 5e23cbece0
commit a19e592eb7
25221 changed files with 8324611 additions and 0 deletions

View File

@@ -0,0 +1,44 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command group `gcloud container azure`."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import util
@base.Deprecate(
is_removed=False,
warning=(
"This command is deprecated. See"
" https://cloud.google.com/kubernetes-engine/multi-cloud/docs/azure/deprecations/deprecation-announcement"
" for more details."
),
error=(
"This command has been removed. See"
" https://cloud.google.com/kubernetes-engine/multi-cloud/docs/azure/deprecations/deprecation-announcement"
" for more details."
),
)
@base.UniverseCompatible
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Azure(base.Group):
"""Deploy and manage clusters of machines on Azure for running containers."""
category = base.COMPUTE_CATEGORY

View File

@@ -0,0 +1,32 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command group `gcloud container azure clients`."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import util
from googlecloudsdk.core import log
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Clients(base.Group):
"""Create and manage Azure clients."""
@staticmethod
def Args(parser):
pass

View File

@@ -0,0 +1,81 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to create an Azure client."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
# Command needs to be in one line for the docgen tool to format properly.
_EXAMPLES = """
To create an Azure client named ``my-client'' in
location ``us-west1'', run:
$ {command} my-client --location=us-west1 --application-id=APP_ID --tenant-id=TENANT_ID
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Create(base.CreateCommand):
"""Create an Azure client."""
detailed_help = {"EXAMPLES": _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClientResourceArg(parser, "to create")
parser.add_argument(
"--tenant-id",
required=True,
help=(
"Azure Active Directory (AAD) tenant ID (GUID) to associate with"
" the client."
),
)
parser.add_argument(
"--application-id",
required=True,
dest="app_id",
help="Azure Active Directory (AAD) Application/Client ID (GUID).",
)
base.ASYNC_FLAG.AddToParser(parser)
flags.AddValidateOnly(parser, "creation of the client")
parser.display_info.AddFormat(constants.AZURE_CLIENT_FORMAT)
def Run(self, args):
"""Runs the create command."""
location = resource_args.ParseAzureClientResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
client_ref = resource_args.ParseAzureClientResourceArg(args)
api_client = api_util.ClientsClient()
message = command_util.ClientMessage(
client_ref.azureClientsId, action="Creating"
)
return command_util.Create(
resource_ref=client_ref,
resource_client=api_client,
message=message,
args=args,
kind=constants.AZURE_CLIENT_KIND,
)

View File

@@ -0,0 +1,64 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to delete an Azure Client."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
_EXAMPLES = """
To delete an Azure client named ``my-client'' in location ``us-west1'', run:
$ {command} my-client --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Delete(base.DeleteCommand):
"""Delete an Azure client."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClientResourceArg(parser, 'to delete')
base.ASYNC_FLAG.AddToParser(parser)
flags.AddAllowMissing(parser, 'client')
def Run(self, args):
"""Runs the delete command."""
location = resource_args.ParseAzureClientResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
client_ref = resource_args.ParseAzureClientResourceArg(args)
api_client = api_util.ClientsClient()
message = command_util.ClientMessage(
client_ref.azureClientsId, region=location
)
return command_util.Delete(
resource_ref=client_ref,
resource_client=api_client,
message=message,
args=args,
kind=constants.AZURE_CLIENT_KIND,
)

View File

@@ -0,0 +1,53 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to describe an Azure Client."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
_EXAMPLES = """
To describe an Azure client named ``my-client'' in
location ``us-west1'', run:
$ {command} my-client --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Describe an Azure client."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClientResourceArg(parser, 'to describe')
def Run(self, args):
"""Runs the describe command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseAzureClientResourceArg(args).locationsId,
self.ReleaseTrack(),
):
client_ref = resource_args.ParseAzureClientResourceArg(args)
api_client = api_util.ClientsClient()
return api_client.Get(client_ref)

View File

@@ -0,0 +1,83 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to get the public certificate of an Azure Client."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
import base64
from apitools.base.py import encoding
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
from googlecloudsdk.core import log
_EXAMPLES = """
To get the public certificate of an Azure client named ``my-client'' in
location ``us-west1'', run:
$ {command} my-client --location=us-west1
To store the certificate in a file named ``client.crt'', run:
$ {command} my-client --location=us-west1 --output-file=client.crt
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class GetPublicCert(base.DescribeCommand):
"""Get the public certificate of an Azure client."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClientResourceArg(
parser, 'to get the public certificate'
)
flags.AddOutputFile(parser, 'to store PEM')
def Run(self, args):
"""Runs the get-public-cert command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseAzureClientResourceArg(args).locationsId,
self.ReleaseTrack(),
):
client_ref = resource_args.ParseAzureClientResourceArg(args)
api_client = api_util.ClientsClient()
client = api_client.Get(client_ref)
cert = self._GetCert(client)
log.WriteToFileOrStdout(
args.output_file if args.output_file else '-',
cert,
overwrite=True,
binary=False,
private=True,
)
def _GetCert(self, client):
if client.pemCertificate:
return client.pemCertificate
# Support older versions with certificate instead of pemCertificate.
# This is needed because "certificate" was removed from the proto so
# the apigen tool doesn't generate it in the AzureClient class.
client_dict = encoding.MessageToPyValue(client)
if 'certificate' in client_dict:
return base64.b64decode(client_dict['certificate'].encode('utf-8'))

View File

@@ -0,0 +1,54 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to list Azure clients."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
_EXAMPLES = """
To lists all clients in location ``us-west1'', run:
$ {command} --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class List(base.ListCommand):
"""List Azure clients."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddLocationResourceArg(parser, 'to list Azure clients')
parser.display_info.AddFormat(constants.AZURE_CLIENT_FORMAT)
def Run(self, args):
"""Runs the list command."""
location_ref = args.CONCEPTS.location.Parse()
with endpoint_util.GkemulticloudEndpointOverride(location_ref.locationsId):
api_client = api_util.ClientsClient()
items, _ = api_client.List(
location_ref, page_size=args.page_size, limit=args.limit
)
return items

View File

@@ -0,0 +1,32 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command group `gcloud container azure clusters`."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import util
from googlecloudsdk.core import log
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Clusters(base.Group):
"""Create and manage Anthos clusters on Azure."""
@staticmethod
def Args(parser):
pass

View File

@@ -0,0 +1,109 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to create an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
# Command needs to be in one line for the docgen tool to format properly.
_EXAMPLES = """
To create a cluster named ``my-cluster'' managed in location ``us-west1'', run:
$ {command} my-cluster --location=us-west1 --azure-region=AZURE_REGION --cluster-version=CLUSTER_VERSION --client=CLIENT --pod-address-cidr-blocks=POD_ADDRESS_CIDR_BLOCKS --resource-group-id=RESOURCE_GROUP_ID --ssh-public-key=SSH_PUBLIC_KEY --subnet-id=SUBNET_ID --vnet-id=VNET_ID
"""
@base.ReleaseTracks(base.ReleaseTrack.GA)
class Create(base.CreateCommand):
"""Create an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
auth_config_group = parser.add_argument_group(
'Authentication configuration', mutex=True, required=True
)
resource_args.AddAzureClusterAndClientResourceArgs(
parser, auth_config_group
)
flags.AddAzureServicesAuthentication(auth_config_group)
flags.AddAzureRegion(parser)
flags.AddEndpointSubnetId(parser)
flags.AddVnetId(parser)
flags.AddResourceGroupId(parser)
flags.AddServiceLoadBalancerSubnetId(parser)
flags.AddPodAddressCidrBlocks(parser)
flags.AddServiceAddressCidrBlocks(parser)
flags.AddClusterVersion(parser)
flags.AddSubnetID(parser, 'the cluster control plane', required=False)
flags.AddVMSize(parser)
flags.AddSSHPublicKey(parser)
flags.AddRootVolumeSize(parser)
flags.AddMainVolumeSize(parser)
flags.AddReplicaPlacements(parser)
flags.AddTags(parser, 'cluster')
flags.AddValidateOnly(parser, 'creation of the cluster')
flags.AddDatabaseEncryption(parser)
flags.AddConfigEncryption(parser)
flags.AddProxyConfig(parser)
flags.AddFleetProject(parser)
flags.AddAdminUsers(parser)
flags.AddAdminGroups(parser)
flags.AddDescription(parser)
flags.AddAnnotations(parser)
flags.AddLogging(parser)
flags.AddMonitoringConfig(parser, True)
base.ASYNC_FLAG.AddToParser(parser)
parser.display_info.AddFormat(constants.AZURE_CLUSTERS_FORMAT)
def Run(self, args):
"""Runs the create command."""
location = resource_args.ParseAzureClusterResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
cluster_client = api_util.ClustersClient()
message = command_util.ClusterMessage(
cluster_ref.azureClustersId,
action='Creating',
kind=constants.AZURE,
region=args.azure_region,
)
return command_util.Create(
resource_ref=cluster_ref,
resource_client=cluster_client,
args=args,
message=message,
kind=constants.AZURE_CLUSTER_KIND,
)
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class CreateAlpha(Create):
"""Create an Anthos cluster on Azure."""
@staticmethod
def Args(parser, track=base.ReleaseTrack.ALPHA):
"""Registers alpha track flags for this command."""
Create.Args(parser)

View File

@@ -0,0 +1,69 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to delete an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
_EXAMPLES = """
To delete a cluster named ``my-cluster'' managed in location ``us-west1'', run:
$ {command} my-cluster --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Delete(base.DeleteCommand):
"""Delete an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClusterResourceArg(parser, 'to delete')
flags.AddAllowMissing(parser, 'cluster')
flags.AddIgnoreErrors(parser, constants.AZURE, 'cluster')
base.ASYNC_FLAG.AddToParser(parser)
def Run(self, args):
"""Runs the delete command."""
location = resource_args.ParseAzureClusterResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
cluster_client = api_util.ClustersClient()
cluster = cluster_client.Get(cluster_ref)
message = command_util.ClusterMessage(
cluster_ref.azureClustersId,
kind=constants.AZURE,
region=cluster.azureRegion,
)
command_util.DeleteWithIgnoreErrors(
args,
cluster_client,
cluster_ref,
message,
constants.AZURE_CLUSTER_KIND,
)

View File

@@ -0,0 +1,61 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to describe an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import versions
from googlecloudsdk.core import log
_EXAMPLES = """
To describe a cluster named ``my-cluster'' managed in location ``us-west1'', run:
$ {command} my-cluster --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Describe an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClusterResourceArg(parser, 'to describe')
def Run(self, args):
"""Runs the describe command."""
self._upgrade_hint = None
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
with endpoint_util.GkemulticloudEndpointOverride(cluster_ref.locationsId):
cluster_client = api_util.ClustersClient()
cluster_info = cluster_client.Get(cluster_ref)
self._upgrade_hint = versions.upgrade_hint_cluster(
cluster_ref, cluster_info, constants.AZURE
)
return cluster_info
def Epilog(self, results_were_displayed):
if self._upgrade_hint:
log.status.Print(self._upgrade_hint)

View File

@@ -0,0 +1,95 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to get credentials of an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.api_lib.container.gkemulticloud import util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
from googlecloudsdk.command_lib.container.gkemulticloud import kubeconfig
from googlecloudsdk.core import log
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class GetCredentials(base.Command):
"""Get credentials of an Anthos cluster on Azure."""
detailed_help = {
'EXAMPLES': kubeconfig.COMMAND_EXAMPLE,
'DESCRIPTION': kubeconfig.COMMAND_DESCRIPTION.format(
cluster_type='Anthos cluster on Azure'
),
}
@staticmethod
def Args(parser):
resource_args.AddAzureClusterResourceArg(parser, 'to get credentials')
flags.AddAuthProviderCmdPath(parser)
flags.AddPrivateEndpoint(parser)
def Run(self, args):
"""Runs the get-credentials command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseAzureClusterResourceArg(args).locationsId,
self.ReleaseTrack(),
):
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
client = api_util.ClustersClient()
log.status.Print('Fetching cluster endpoint and auth data.')
resp = client.Get(cluster_ref)
if (
resp.state
!= util.GetMessagesModule().GoogleCloudGkemulticloudV1AzureCluster.StateValueValuesEnum.RUNNING
):
log.warning(
kubeconfig.NOT_RUNNING_MSG.format(cluster_ref.azureClustersId)
)
if not args.private_endpoint and kubeconfig.ConnectGatewayInNodePools(
resp, cluster_ref.azureClustersId
):
kubeconfig.CheckClusterHasNodePools(
api_util.NodePoolsClient(), cluster_ref
)
kubeconfig.ValidateClusterVersion(resp, cluster_ref.azureClustersId)
context = kubeconfig.GenerateContext(
'azure',
cluster_ref.projectsId,
cluster_ref.locationsId,
cluster_ref.azureClustersId,
)
cmd_args = kubeconfig.GenerateAuthProviderCmdArgs(
'azure',
cluster_ref.azureClustersId,
cluster_ref.locationsId,
cluster_ref.projectsId,
)
kubeconfig.GenerateKubeconfig(
resp,
cluster_ref.azureClustersId,
context,
args.auth_provider_cmd_path,
cmd_args,
args.private_endpoint,
)

View File

@@ -0,0 +1,75 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to list Anthos clusters on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import versions
from googlecloudsdk.core import log
_EXAMPLES = """
To lists all clusters managed in location ``us-west1'', run:
$ {command} --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class List(base.ListCommand):
"""List Anthos clusters on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddLocationResourceArg(parser, 'to list Azure clusters')
parser.display_info.AddFormat(constants.AZURE_CLUSTERS_FORMAT)
def Run(self, args):
"""Runs the list command."""
self._upgrade_hint = None
location_ref = args.CONCEPTS.location.Parse()
with endpoint_util.GkemulticloudEndpointOverride(location_ref.locationsId):
api_client = api_util.ClustersClient()
items, is_empty = api_client.List(
location_ref, page_size=args.page_size, limit=args.limit
)
if is_empty:
return items
platform = constants.AZURE
cluster_info_table, end_of_life_flag = (
versions.generate_cluster_versions_table(
location_ref,
platform,
items,
)
)
if end_of_life_flag:
self._upgrade_hint = versions.upgrade_hint_cluster_list(platform)
return cluster_info_table
def Epilog(self, results_were_displayed):
super(List, self).Epilog(results_were_displayed)
if self._upgrade_hint:
log.status.Print(self._upgrade_hint)

View File

@@ -0,0 +1,54 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to print access tokens for an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
from googlecloudsdk.command_lib.container.gkemulticloud import kubeconfig
@base.Hidden
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class PrintAccessToken(base.Command):
"""Generate an access token for an Anthos cluster on Azure."""
@staticmethod
def Args(parser):
"""Registers flags for this command."""
resource_args.AddAzureClusterResourceArg(parser, "to access")
flags.AddExecCredential(parser)
def Run(self, args):
"""Runs the print-access-token command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseAzureClusterResourceArg(args).locationsId,
self.ReleaseTrack(),
):
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
client = api_util.ClustersClient()
response = client.GenerateAccessToken(cluster_ref)
if args.exec_credential:
return kubeconfig.ExecCredential(
expiration_timestamp=response.expirationTime,
access_token=response.accessToken,
)
return response

View File

@@ -0,0 +1,90 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to update an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
# Command needs to be in one line for the docgen tool to format properly.
_EXAMPLES = """
To update a cluster named ``my-cluster'' managed in location ``us-west1'', run:
$ {command} my-cluster --location=us-west1 --cluster-version=CLUSTER_VERSION --client=CLIENT
"""
@base.ReleaseTracks(base.ReleaseTrack.GA)
class Update(base.UpdateCommand):
"""Update an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
auth_config_group = parser.add_argument_group(
'Authentication configuration', mutex=True
)
resource_args.AddAzureClusterAndClientResourceArgs(
parser, auth_config_group, update=True
)
flags.AddAzureServicesAuthentication(auth_config_group, create=False)
flags.AddClusterVersion(parser, required=False)
flags.AddVMSize(parser)
flags.AddAdminUsers(parser, create=False)
flags.AddAdminGroups(parser)
flags.AddSSHPublicKey(parser, required=False)
flags.AddValidateOnly(parser, 'update of the cluster')
flags.AddDescriptionForUpdate(parser)
flags.AddAnnotationsForUpdate(parser, 'cluster')
flags.AddLogging(parser)
flags.AddMonitoringConfig(parser)
base.ASYNC_FLAG.AddToParser(parser)
parser.display_info.AddFormat(constants.AZURE_CLUSTERS_FORMAT)
def Run(self, args):
"""Runs the update command."""
location = resource_args.ParseAzureClusterResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
cluster_ref = resource_args.ParseAzureClusterResourceArg(args)
cluster_client = api_util.ClustersClient()
message = command_util.ClusterMessage(
cluster_ref.azureClustersId, action='Updating'
)
return command_util.Update(
resource_ref=cluster_ref,
resource_client=cluster_client,
args=args,
message=message,
kind=constants.AZURE_CLUSTER_KIND,
)
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class UpdateAlpha(Update):
"""Update an Anthos cluster on Azure."""
@staticmethod
def Args(parser, track=base.ReleaseTrack.ALPHA):
"""Registers alpha track flags for this command."""
Update.Args(parser)

View File

@@ -0,0 +1,57 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to get Anthos Multi-Cloud server configuration for Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import locations as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.core import log
_EXAMPLES = """
To return supported Azure regions and valid versions in location ``us-west1'', run:
$ {command} --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class GetServerConfig(base.Command):
"""Get Anthos Multi-Cloud server configuration for Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddLocationResourceArg(parser, 'to get server configuration')
parser.display_info.AddFormat(constants.AZURE_SERVER_CONFIG_FORMAT)
def Run(self, args):
"""Runs the get-server-config command."""
location_ref = args.CONCEPTS.location.Parse()
with endpoint_util.GkemulticloudEndpointOverride(location_ref.locationsId):
log.status.Print(
'Fetching server config for {location}'.format(
location=location_ref.locationsId
)
)
client = api_util.LocationsClient()
return client.GetAzureServerConfig(location_ref)

View File

@@ -0,0 +1,33 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command group `gcloud container azure node-pools`."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import util
from googlecloudsdk.core import log
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class NodePools(base.Group):
"""Create and manage node pools in an Anthos cluster on Azure."""
@staticmethod
def Args(parser):
pass

View File

@@ -0,0 +1,97 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to create a node pool in an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
# Command needs to be in one line for the docgen tool to format properly.
_EXAMPLES = """
To create a node pool named ``my-node-pool'' in a cluster named ``my-cluster''
managed in location ``us-west1'', run:
$ {command} my-node-pool --cluster=my-cluster --location=us-west1 --node-version=NODE_VERSION --ssh-public-key=SSH_PUBLIC_KEY --subnet-id=SUBNET_ID
"""
@base.ReleaseTracks(base.ReleaseTrack.GA)
class Create(base.CreateCommand):
"""Create a node pool in an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureNodePoolResourceArg(
parser, 'to create', positional=True
)
flags.AddNodeVersion(parser)
flags.AddAutoscaling(parser)
flags.AddSubnetID(parser, 'the node pool')
flags.AddVMSize(parser)
flags.AddSSHPublicKey(parser)
flags.AddRootVolumeSize(parser)
flags.AddTags(parser, 'node pool')
flags.AddValidateOnly(parser, 'creation of the node pool')
flags.AddMaxPodsPerNode(parser)
flags.AddNodeLabels(parser)
flags.AddNodeTaints(parser)
flags.AddAzureAvailabilityZone(parser)
flags.AddProxyConfig(parser)
flags.AddConfigEncryption(parser)
flags.AddAnnotations(parser, 'node pool')
flags.AddEnableAutoRepair(parser, True)
base.ASYNC_FLAG.AddToParser(parser)
parser.display_info.AddFormat(constants.AZURE_NODE_POOL_FORMAT)
def Run(self, args):
"""Runs the create command."""
location = resource_args.ParseAzureNodePoolResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
node_pool_ref = resource_args.ParseAzureNodePoolResourceArg(args)
node_pool_client = api_util.NodePoolsClient()
message = command_util.NodePoolMessage(
node_pool_ref.azureNodePoolsId,
action='Creating',
cluster=node_pool_ref.azureClustersId,
)
return command_util.Create(
resource_ref=node_pool_ref,
resource_client=node_pool_client,
args=args,
message=message,
kind=constants.AZURE_NODEPOOL_KIND,
)
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class CreateAlpha(Create):
"""Create a node pool in an Anthos cluster on Azure."""
@staticmethod
def Args(parser, track=base.ReleaseTrack.ALPHA):
"""Registers alpha track flags for this command."""
Create.Args(parser)
flags.AddImageType(parser)

View File

@@ -0,0 +1,67 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to delete a node pool in an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
_EXAMPLES = """
To delete a node pool named ``my-node-pool'' in a cluster named ``my-cluster''
managed in location ``us-west1'', run:
$ {command} my-node-pool --cluster=my-cluster --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Delete(base.DeleteCommand):
"""Delete a node pool in an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureNodePoolResourceArg(parser, 'to delete')
flags.AddAllowMissing(parser, 'node pool')
flags.AddIgnoreErrors(parser, constants.AZURE, 'node pool')
base.ASYNC_FLAG.AddToParser(parser)
def Run(self, args):
"""Runs the delete command."""
location = resource_args.ParseAzureNodePoolResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
node_pool_ref = resource_args.ParseAzureNodePoolResourceArg(args)
node_pool_client = api_util.NodePoolsClient()
message = command_util.NodePoolMessage(
node_pool_ref.azureNodePoolsId, cluster=node_pool_ref.azureClustersId
)
command_util.DeleteWithIgnoreErrors(
args,
node_pool_client,
node_pool_ref,
message,
constants.AZURE_NODEPOOL_KIND,
)

View File

@@ -0,0 +1,63 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to describe a node pool in an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import versions
from googlecloudsdk.core import log
_EXAMPLES = """
To describe a node pool named ``my-node-pool'' in a cluster named
``my-cluster'' managed in location ``us-west1'', run:
$ {command} my-node-pool --cluster=my-cluster --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Describe a node pool in an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureNodePoolResourceArg(parser, 'to describe')
def Run(self, args):
"""Runs the describe command."""
self._upgrade_hint = None
node_pool_ref = resource_args.ParseAzureNodePoolResourceArg(args)
with endpoint_util.GkemulticloudEndpointOverride(node_pool_ref.locationsId):
node_pool_client = api_util.NodePoolsClient()
node_pool_info = node_pool_client.Get(node_pool_ref)
self._upgrade_hint = versions.upgrade_hint_node_pool(
node_pool_ref, node_pool_info, constants.AZURE
)
return node_pool_info
def Epilog(self, results_were_displayed):
if self._upgrade_hint:
log.status.Print(self._upgrade_hint)

View File

@@ -0,0 +1,80 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to list node pools in an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import versions
from googlecloudsdk.core import log
_EXAMPLES = """
To list all node pools in a cluster named ``my-cluster''
managed in location ``us-west1'', run:
$ {command} --cluster=my-cluster --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class List(base.ListCommand):
"""List node pools in an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureClusterResourceArg(
parser, 'to list Azure node pools', positional=False
)
parser.display_info.AddFormat(constants.AZURE_NODE_POOL_FORMAT)
def Run(self, args):
"""Runs the list command."""
self._upgrade_hint = None
cluster_ref = args.CONCEPTS.cluster.Parse()
with endpoint_util.GkemulticloudEndpointOverride(cluster_ref.locationsId):
api_client = api_util.NodePoolsClient()
items, is_empty = api_client.List(
cluster_ref, page_size=args.page_size, limit=args.limit
)
if is_empty:
return items
platform = constants.AZURE
node_pool_info_table, end_of_life_flag = (
versions.generate_node_pool_versions_table(
cluster_ref,
platform,
items,
)
)
if end_of_life_flag:
self._upgrade_hint = versions.upgrade_hint_node_pool_list(
platform, cluster_ref
)
return node_pool_info_table
def Epilog(self, results_were_displayed):
super(List, self).Epilog(results_were_displayed)
if self._upgrade_hint:
log.status.Print(self._upgrade_hint)

View File

@@ -0,0 +1,87 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to update a node pool in an Anthos cluster on Azure."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import azure as api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import constants
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import flags
# Command needs to be in one line for the docgen tool to format properly.
_EXAMPLES = """
To update a node pool named ``my-node-pool'' in a cluster named ``my-cluster''
managed in location ``us-west1'', run:
$ {command} my-node-pool --cluster=my-cluster --location=us-west1 --node-version=NODE_VERSION
"""
@base.ReleaseTracks(base.ReleaseTrack.GA)
class Update(base.UpdateCommand):
"""Update a node pool in an Anthos cluster on Azure."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
resource_args.AddAzureNodePoolResourceArg(
parser, 'to update', positional=True
)
flags.AddNodeVersion(parser, required=False)
flags.AddAutoscaling(parser, required=False)
flags.AddSSHPublicKey(parser, required=False)
flags.AddAnnotationsForUpdate(parser, 'node pool')
flags.AddValidateOnly(parser, 'update of the node pool')
flags.AddEnableAutoRepair(parser, False)
base.ASYNC_FLAG.AddToParser(parser)
parser.display_info.AddFormat(constants.AZURE_NODE_POOL_FORMAT)
def Run(self, args):
"""Runs the update command."""
location = resource_args.ParseAzureNodePoolResourceArg(args).locationsId
with endpoint_util.GkemulticloudEndpointOverride(location):
node_pool_ref = resource_args.ParseAzureNodePoolResourceArg(args)
node_pool_client = api_util.NodePoolsClient()
message = command_util.NodePoolMessage(
node_pool_ref.azureNodePoolsId,
action='Updating',
cluster=node_pool_ref.azureClustersId,
)
return command_util.Update(
resource_ref=node_pool_ref,
resource_client=node_pool_client,
args=args,
message=message,
kind=constants.AZURE_NODEPOOL_KIND,
)
@base.ReleaseTracks(base.ReleaseTrack.ALPHA)
class UpdateAlpha(Update):
"""Update a node pool in an Anthos cluster on Azure."""
@staticmethod
def Args(parser, track=base.ReleaseTrack.ALPHA):
"""Registers alpha track flags for this command."""
Update.Args(parser)

View File

@@ -0,0 +1,32 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command group for `gcloud container azure operations`."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import util
from googlecloudsdk.core import log
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Operations(base.Group):
"""Manage Anthos Multi-Cloud long running operations for Azure."""
@staticmethod
def Args(parser):
pass

View File

@@ -0,0 +1,58 @@
# -*- coding: utf-8 -*- #
# Copyright 2022 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to cancel an operation."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import operations as op_api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import command_util
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.core import log
_EXAMPLES = """
To cancel an operation in location ``us-west1'', run:
$ {command} OPERATION_ID --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Cancel(base.Command):
"""Cancel an operation."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
"""Registers flags for this command."""
resource_args.AddOperationResourceArg(parser, 'to cancel')
def Run(self, args):
"""Runs the cancel command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseOperationResourceArg(args).locationsId,
self.ReleaseTrack(),
):
op_client = op_api_util.OperationsClient()
op_ref = resource_args.ParseOperationResourceArg(args)
op = op_client.Get(op_ref)
command_util.CancelOperationPrompt(op.name)
op_client.Cancel(op_ref)
log.status.Print(command_util.CancelOperationMessage(op.name, 'azure'))
return op_client.Get(op_ref)

View File

@@ -0,0 +1,52 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to describe an operation."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import operations as op_api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
_EXAMPLES = """
To describe an operation in location ``us-west1'', run:
$ {command} OPERATION_ID --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Describe an operation."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
"""Registers flags for this command."""
resource_args.AddOperationResourceArg(parser, 'to describe')
def Run(self, args):
"""Runs the describe command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseOperationResourceArg(args).locationsId,
self.ReleaseTrack(),
):
op_client = op_api_util.OperationsClient()
op_ref = resource_args.ParseOperationResourceArg(args)
return op_client.Get(op_ref)

View File

@@ -0,0 +1,61 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to list operations."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import operations as op_api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
from googlecloudsdk.command_lib.container.gkemulticloud import operations
_EXAMPLES = """
To list all operations in location ``us-west1'', run:
$ {command} --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class List(base.ListCommand):
"""List operations."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
"""Registers flags for this command."""
resource_args.AddLocationResourceArg(parser, 'to list operations')
operations.AddFormat(parser)
def Run(self, args):
"""Runs the describe command."""
release_track = self.ReleaseTrack()
location_ref = args.CONCEPTS.location.Parse()
with endpoint_util.GkemulticloudEndpointOverride(
location_ref.locationsId, release_track
):
op_client = op_api_util.OperationsClient()
items, empty = op_client.List(
location_ref, args.page_size, args.limit, parent_field='name'
)
if not empty:
# ListOperations returns AWS, Azure, and attached operations.
# Add a filter for Azure operations.
operations.AddFilter(args, 'azure')
return items

View File

@@ -0,0 +1,57 @@
# -*- coding: utf-8 -*- #
# Copyright 2021 Google LLC. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Command to wait for an operation to complete."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.container.gkemulticloud import operations as op_api_util
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.container.azure import resource_args
from googlecloudsdk.command_lib.container.gkemulticloud import endpoint_util
_EXAMPLES = """
To wait for an operation in location ``us-west1'' to complete, run:
$ {command} OPERATION_ID --location=us-west1
"""
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Wait for an operation to complete."""
detailed_help = {'EXAMPLES': _EXAMPLES}
@staticmethod
def Args(parser):
"""Registers flags for this command."""
resource_args.AddOperationResourceArg(parser, 'to wait for')
def Run(self, args):
"""Runs the wait command."""
with endpoint_util.GkemulticloudEndpointOverride(
resource_args.ParseOperationResourceArg(args).locationsId,
self.ReleaseTrack(),
):
op_client = op_api_util.OperationsClient()
op_ref = resource_args.ParseOperationResourceArg(args)
op_client.Wait(
op_ref,
'Waiting for operation {} to complete'.format(op_ref.RelativeName()),
)
return op_client.Get(op_ref)