# -*- 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