File: //snap/google-cloud-cli/394/lib/surface/projects/move.py
# -*- coding: utf-8 -*- #
# Copyright 2016 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 move a project into an organization."""
from __future__ import absolute_import
from __future__ import division
from __future__ import unicode_literals
from googlecloudsdk.api_lib.cloudresourcemanager import projects_api
from googlecloudsdk.calliope import base
from googlecloudsdk.command_lib.projects import flags as project_flags
from googlecloudsdk.command_lib.projects import util as command_lib_util
from googlecloudsdk.command_lib.resource_manager import flags as folder_flags
from googlecloudsdk.core import log
from googlecloudsdk.core.console import console_io
@base.ReleaseTracks(base.ReleaseTrack.ALPHA, base.ReleaseTrack.BETA)
class Move(base.Command):
"""Move a project into an organization.
Moves the given project into the given organization.
This command can fail for the following reasons:
* There is no project with the given ID.
* There is no organization with the given ID, if an organization is given
as the destination.
* There is no folder with the given ID, if a folder is given as the
destination.
* More than one of organization or folder is provided.
* The active account does not have the
resourcemanager.projects.update permission for the given
project.
* The active account does not have the
resourcemanager.projects.create permission for the given
organization.
* The given project is already in an organization.
## EXAMPLES
The following command moves a project with the ID `super-awesome-project` into
the organization `25872158`:
$ {command} super-awesome-project --organization=25872158
"""
@staticmethod
def Args(parser):
project_flags.GetProjectIDNumberFlag('move').AddToParser(parser)
folder_flags.AddParentFlagsToParser(parser)
parser.display_info.AddFormat(command_lib_util.LIST_FORMAT)
def Run(self, args):
folder_flags.CheckParentFlags(args)
project_ref = command_lib_util.ParseProject(args.id)
if not console_io.PromptContinue(
'Your project will be moved. This may alter the policies enforced on '
'your Project, either exposing your Project to more security risk '
'through looser polices or cause an outage through stricter polices. '
'See these public notes on policy implications for more information: '
'https://cloud.google.com/resource-manager/docs/'
'creating-managing-folders#moving-folders-policy-considerations and '
'https://cloud.google.com/resource-manager/docs/'
'migrating-projects-billing#note_on_policy_implications. '
'Once moved, you can move the Project again so long as you have the '
'appropriate permissions. See our public documentation for more '
'information: https://cloud.google.com/resource-manager/docs/'
'creating-managing-folders#moving_a_project_into_a_folder'
):
return None
result = projects_api.Update(
project_ref,
parent=projects_api.ParentNameToResourceId(
folder_flags.GetParentFromFlags(args)))
log.UpdatedResource(project_ref)
return result