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,35 @@
# -*- coding: utf-8 -*- #
# Copyright 2025 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.
"""Commands for Compute Engine reservation sub blocks."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.calliope import base
@base.UniverseCompatible
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA,
base.ReleaseTrack.GA)
class ReservationSubBlocks(base.Group):
"""Manage Compute Engine reservation sub blocks."""
category = base.COMPUTE_CATEGORY
detailed_help = {
'DESCRIPTION': """
Manage Compute Engine reservation sub blocks.
""",
}

View File

@@ -0,0 +1,83 @@
# -*- coding: utf-8 -*- #
# Copyright 2025 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 for describing reservation sub-blocks."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.compute import base_classes
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.compute import flags as compute_flags
from googlecloudsdk.command_lib.compute import scope as compute_scope
from googlecloudsdk.command_lib.compute.reservations import resource_args
from googlecloudsdk.command_lib.compute.reservations.sub_blocks import flags
@base.UniverseCompatible
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA,
base.ReleaseTrack.GA)
class Describe(base.DescribeCommand):
"""Describe a Compute Engine reservation sub-block."""
@staticmethod
def Args(parser):
Describe.ReservationArg = (
resource_args.GetReservationResourceArg()
)
Describe.ReservationArg.AddArgument(parser, operation_type='describe')
flags.AddDescribeFlags(parser)
flags.AddFullViewFlag(parser)
def Run(self, args):
holder = base_classes.ComputeApiHolder(self.ReleaseTrack())
client = holder.client
reservation_ref = Describe.ReservationArg.ResolveAsResource(
args,
holder.resources,
default_scope=compute_scope.ScopeEnum.ZONE,
scope_lister=compute_flags.GetDefaultScopeLister(client))
parent_name = f'reservations/{reservation_ref.reservation}/reservationBlocks/{args.block_name}'
view_enum = None
if args.IsSpecified('full_view'):
view_enum_type = (
client.messages.ComputeReservationSubBlocksGetRequest.ViewValueValuesEnum
)
view_enum = view_enum_type(args.full_view)
request = (
client.messages.ComputeReservationSubBlocksGetRequest(
parentName=parent_name,
zone=reservation_ref.zone,
project=reservation_ref.project,
reservationSubBlock=args.sub_block_name,
view=view_enum,)
)
return client.MakeRequests([(client.apitools_client.reservationSubBlocks,
'Get', request)])[0]
Describe.detailed_help = {
'EXAMPLES':
"""\
To describe a reservation sub-block in reservation exr1 in my-zone
with block name my-block and sub-block name my-sub-block, run:
$ {command} exr1 --zone=my-zone --block-name=my-block --sub-block-name=my-sub-block
""",
}

View File

@@ -0,0 +1,104 @@
# -*- coding: utf-8 -*- #
# Copyright 2025 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 for listing reservation sub-blocks."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.compute import base_classes
from googlecloudsdk.api_lib.compute import request_helper
from googlecloudsdk.api_lib.compute import utils
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.compute import flags as compute_flags
from googlecloudsdk.command_lib.compute import scope as compute_scope
from googlecloudsdk.command_lib.compute.reservations import resource_args
from googlecloudsdk.command_lib.compute.reservations.sub_blocks import flags
DETAILED_HELP = {
'DESCRIPTION':
"""\
{command} displays all Compute Engine reservation sub-blocks in an extended reservation's block.
""",
'EXAMPLES':
"""\
To list all reservation sub-blocks in an extended reservation's block my-block in table form,
run:
$ {command} extended-reservation --block-name=my-block --zone=us-central1-a --project=my-project
To list the URIs of all reservation blocks in an extended reservation, run:
$ {command} extended-reservation --block-name=my-block --zone=us-central1-a --project=my-project --uri
"""
}
@base.UniverseCompatible
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA,
base.ReleaseTrack.GA)
class List(base.ListCommand):
"""List Compute Engine reservation sub-blocks."""
detailed_help = DETAILED_HELP
@classmethod
def Args(cls, parser):
List.ReservationArg = resource_args.GetReservationResourceArg()
List.ReservationArg.AddArgument(parser, operation_type='list')
flags.AddListFlags(parser)
def _Run(self, args, holder):
client = holder.client
reservation_ref = (
List.ReservationArg.ResolveAsResource(
args,
holder.resources,
default_scope=compute_scope.ScopeEnum.ZONE,
scope_lister=compute_flags.GetDefaultScopeLister(client)))
parent_name = f'reservations/{reservation_ref.reservation}/reservationBlocks/{args.block_name}'
service = client.apitools_client.reservationSubBlocks
request = (client.messages.
ComputeReservationSubBlocksListRequest(
parentName=parent_name,
zone=reservation_ref.zone,
project=reservation_ref.project))
errors = []
results = list(request_helper.MakeRequests(
requests=[(service, 'List', request)],
http=client.apitools_client.http,
batch_url=client.batch_url,
errors=errors))
if errors:
utils.RaiseToolException(errors)
return results
def Run(self, args):
"""Creates and issues a reservationSubBlocks.list request.
Args:
args: the argparse arguments that this command was invoked with.
Returns:
List of reservation sub-blocks.
"""
holder = base_classes.ComputeApiHolder(self.ReleaseTrack())
return self._Run(args, holder)

View File

@@ -0,0 +1,75 @@
# -*- coding: utf-8 -*- #
# Copyright 2025 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 for performing maintenance on a reservation sub-block."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.compute import base_classes
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.compute import flags as compute_flags
from googlecloudsdk.command_lib.compute import scope as compute_scope
from googlecloudsdk.command_lib.compute.reservations import resource_args
from googlecloudsdk.command_lib.compute.reservations.sub_blocks import flags
@base.UniverseCompatible
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA,
base.ReleaseTrack.GA)
class PerformMaintenance(base.UpdateCommand):
"""Perform maintenance on a reservation sub-block."""
@staticmethod
def Args(parser):
resource_args.GetReservationResourceArg().AddArgument(
parser, operation_type='perform-maintenance')
flags.AddDescribeFlags(parser)
def Run(self, args):
holder = base_classes.ComputeApiHolder(self.ReleaseTrack())
client = holder.client
reservation_ref = resource_args.GetReservationResourceArg(
).ResolveAsResource(
args,
holder.resources,
default_scope=compute_scope.ScopeEnum.ZONE,
scope_lister=compute_flags.GetDefaultScopeLister(client))
parent_name = f'reservations/{reservation_ref.reservation}/reservationBlocks/{args.block_name}'
request = (
client.messages.ComputeReservationSubBlocksPerformMaintenanceRequest(
parentName=parent_name,
zone=reservation_ref.zone,
project=reservation_ref.project,
reservationSubBlock=args.sub_block_name
)
)
return client.MakeRequests([(client.apitools_client.reservationSubBlocks,
'PerformMaintenance', request)])
PerformMaintenance.detailed_help = {
'EXAMPLES':
"""\
To perform maintenance on a reservation sub-block in reservation exr-1
in ZONE with block name block-1 and sub-block name sub-block-1, run:
$ {command} exr-1 --zone=ZONE --block-name=block-1
--sub-block-name=sub-block-1
""",
}

View File

@@ -0,0 +1,129 @@
# -*- coding: utf-8 -*- #
# Copyright 2025 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 for reporting a faulty reservation sub-block."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.compute import base_classes
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.compute import flags as compute_flags
from googlecloudsdk.command_lib.compute import scope as compute_scope
from googlecloudsdk.command_lib.compute.reservations import resource_args
from googlecloudsdk.command_lib.compute.reservations.sub_blocks import flags
from googlecloudsdk.command_lib.compute.reservations.sub_blocks import util
from googlecloudsdk.core.console import console_io
def _GetReportFaultyRequest(args, reservation_ref, holder):
"""Create Update Request for report faulty."""
client = holder.client
parent_name = f'reservations/{reservation_ref.reservation}/reservationBlocks/{args.block_name}'
fault_reasons = []
if args.fault_reasons:
for reason in args.fault_reasons:
fault_reasons.append(
client.messages.ReservationSubBlocksReportFaultyRequestFaultReason(
behavior=util.MakeFaultBehavior(
client.messages, reason.get('behavior')
),
description=reason.get('description'),
)
)
disruption_schedule = util.MakeDisruptionSchedule(
client.messages, args.disruption_schedule
)
failure_component = util.MakeFailureComponent(
client.messages, args.failure_component
)
report_faulty_body = client.messages.ReservationSubBlocksReportFaultyRequest(
disruptionSchedule=disruption_schedule,
faultReasons=fault_reasons,
failureComponent=failure_component,
)
request = client.messages.ComputeReservationSubBlocksReportFaultyRequest(
parentName=parent_name,
zone=reservation_ref.zone,
project=reservation_ref.project,
reservationSubBlock=args.sub_block_name,
reservationSubBlocksReportFaultyRequest=report_faulty_body,
)
return request
@base.UniverseCompatible
@base.ReleaseTracks(
base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA, base.ReleaseTrack.GA
)
class ReportFaulty(base.UpdateCommand):
"""Report a sub-block within a reservation as faulty."""
@staticmethod
def Args(parser):
resource_args.GetReservationResourceArg(
help_text=(
'The name of the reservation containing the sub-block to report as'
' faulty'
)
).AddArgument(parser, operation_type='report-subblock-as-faulty')
flags.AddDescribeFlags(parser)
flags.GetDisruptionScheduleFlag().AddToParser(parser)
flags.GetFaultReasonsFlag().AddToParser(parser)
flags.GetFailureComponentFlag().AddToParser(parser)
def Run(self, args):
holder = base_classes.ComputeApiHolder(self.ReleaseTrack())
client = holder.client
reservation_ref = resource_args.GetReservationResourceArg(
).ResolveAsResource(
args,
holder.resources,
default_scope=compute_scope.ScopeEnum.ZONE,
scope_lister=compute_flags.GetDefaultScopeLister(client))
prompt_message = (
'WARNING: This action is highly disruptive and will immediately '
'terminate all running VMs within this sub-block.'
)
console_io.PromptContinue(
message=prompt_message,
prompt_string='Do you want to continue?',
throw_if_unattended=True,
cancel_on_no=True,
)
request = _GetReportFaultyRequest(args, reservation_ref, holder)
return client.MakeRequests([(client.apitools_client.reservationSubBlocks,
'ReportFaulty', request)])
ReportFaulty.detailed_help = {
'EXAMPLES':
"""\
To report reservation exr-1 in ZONE with block name block-1 and
sub block name sub-block-1 as faulty, run:
$ {command} exr-1 --zone=ZONE --block-name=block-1 \
--sub-block-name=sub-block-1 \
--disruption-schedule=IMMEDIATE \
--fault-reasons=behavior=PERFORMANCE,description="performance issues" \
--failure-component=NVLINK_SWITCH
""",
}