Administra recursos con restricciones personalizadas

En esta página, se muestra cómo usar las restricciones personalizadas del servicio de políticas de la organización para restringir operaciones específicas en los siguientes Google Cloud recursos:

  • cloudresourcemanager.googleapis.com/Project
  • cloudresourcemanager.googleapis.com/Folder

Para obtener más información sobre la política de la organización, consulta Políticas de la organización personalizadas.

Acerca de las políticas y restricciones de la organización

El Google Cloud Servicio de políticas de la organización te brinda un control centralizado y programático sobre los recursos de tu organización. Como administrador de políticas de la organización, puedes definir una política de la organización, que es un conjunto de limitaciones llamadas restricciones que se aplican a los recursos deGoogle Cloud y a sus descendientes en la jerarquía de recursos deGoogle Cloud . Puedes aplicar políticas de la organización a nivel de la organización, carpeta o proyecto.

La política de la organización proporciona restricciones predefinidas para varios servicios de Google Cloud . Sin embargo, si deseas un control más detallado y personalizable sobre los campos específicos que están restringidos en las políticas de tu organización, también puedes crear restricciones personalizadas y usarlas en una política de la organización.

Herencia de políticas

De forma predeterminada, las políticas de la organización se heredan según los subordinados de los recursos en los que se aplica la política. Por ejemplo, si aplicas una política en una carpeta, Google Cloud aplica la política en todos los proyectos de la carpeta. Para obtener más información sobre este comportamiento y cómo cambiarlo, consulta Reglas de evaluación de la jerarquía.

Beneficios

Para la seguridad, el cumplimiento y la administración, puedes usar políticas personalizadas de la organización de las siguientes maneras:

  • Administra los patrones de nombres de los proyectos: Puedes crear una restricción personalizada en el ID del proyecto. Por ejemplo, en una carpeta de recursos de etapa de pruebas, permite las operaciones de creación y actualización en un proyecto solo si el ID del proyecto comienza con staging-.
  • Restringir la mutación de proyectos y carpetas seguros: Puedes crear una restricción personalizada para rechazar las actualizaciones de proyectos y carpetas si el elemento superior es una carpeta o organización segura.

Limitaciones

  • Es posible que las operaciones de creación o actualización en los recursos de Apps Script, Firebase o la solución de Contact Center fallan si se configuró una restricción personalizada en las carpetas o los proyectos. En esos casos, verifica las condiciones de las restricciones personalizadas que están causando el error. Asegúrate de que estas restricciones estén actualizadas y, luego, vuelve a intentar la operación que falló.
  • Al igual que todas las restricciones de políticas de la organización, los cambios de política no se aplican de forma retroactiva a las instancias existentes.
  • Es posible que la creación de proyectos y carpetas en Google Cloud console no proporcione el motivo específico del mensaje de error PERMISSION_DENIED. Para confirmar los detalles sobre las restricciones específicas que causan la falla, puedes verificar los registros de auditoría.

Antes de comenzar

  • Asegúrate de conocer el ID de la organización.
  • Instala y, luego, inicializa Google Cloud CLI.
    1. Install the Google Cloud CLI.
    2. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.

    3. To initialize the gcloud CLI, run the following command:

      gcloud init
  • Roles obligatorios

    Para obtener los permisos que necesitas para administrar las políticas de la organización personalizadas, pídele a tu administrador que te otorgue el rol de IAM de administrador de políticas de la organización (roles/orgpolicy.policyAdmin) en el recurso de organización. Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.

    También puedes obtener los permisos necesarios mediante roles personalizados o cualquier otro rol predefinido.

    Crea una restricción personalizada

    Una restricción personalizada se define en un archivo YAML mediante los recursos, los métodos, las condiciones y las acciones que son compatibles con el servicio en el que aplicas la política de la organización. Las condiciones para tus restricciones personalizadas se definen con Common Expression Language (CEL). Si deseas obtener más información para compilar condiciones en restricciones personalizadas mediante CEL, consulta la sección CEL de Crea y administra restricciones personalizadas.

    Para crear una restricción personalizada, crea un archivo YAML con el siguiente formato:

    name: organizations/ORGANIZATION_ID/customConstraints/CONSTRAINT_NAME
    resourceTypes:
    - RESOURCE_NAME
    methodTypes:
    - CREATE
    - UPDATE
    condition: "CONDITION"
    actionType: ACTION
    displayName: DISPLAY_NAME
    description: DESCRIPTION
    

    Reemplaza lo siguiente:

    • ORGANIZATION_ID: el ID de la organización, como 123456789.

    • CONSTRAINT_NAME: el nombre que deseas para tu nueva restricción personalizada. Una restricción personalizada debe comenzar con custom. y solo puede incluir letras mayúsculas, minúsculas o números. Por ejemplo, custom.allowProjectForXDepartmentNameOnly. La longitud máxima de este campo es de 70 caracteres.

    • RESOURCE_NAME: El nombre completamente calificado del recursoGoogle Cloud que contiene el objeto y el campo que deseas restringir. Por ejemplo, cloudresourcemanager.googleapis.com/Project.

    • CONDITION: una condición de CEL que se escribe en una representación de un recurso de servicio compatible. La longitud máxima de este campo es 1000 caracteres. Consulta Recursos compatibles con el fin de obtener más información sobre los recursos disponibles para escribir condiciones. Por ejemplo, "resource.projectId.startsWith(\"XDepartment\")".

    • ACTION: la acción que se realiza si se cumple condition. Los valores posibles son ALLOW y DENY.

    • DISPLAY_NAME: un nombre descriptivo para la restricción. La longitud máxima de este campo es 200 caracteres.

    • DESCRIPTION: una descripción fácil de usar de la restricción que se mostrará como un mensaje de error cuando se infringe la política. La longitud máxima de este campo es 2000 caracteres.

    Para obtener más información sobre cómo crear una restricción personalizada, consulta Define restricciones personalizadas.

    Configura una restricción personalizada

    Después de crear el archivo YAML para una nueva restricción personalizada, debes configurarla para que esté disponible para las políticas de la organización de tu organización. Para configurar una restricción personalizada, usa el comando gcloud org-policies set-custom-constraint:
    gcloud org-policies set-custom-constraint CONSTRAINT_PATH
    Reemplaza CONSTRAINT_PATH por la ruta de acceso completa al archivo de restricción personalizado. Por ejemplo, /home/user/customconstraint.yaml. Una vez completadas, tus restricciones personalizadas estarán disponibles como políticas de la organización en tu lista de Google Cloud políticas de la organización. Para verificar que la restricción personalizada exista, usa el comando gcloud org-policies list-custom-constraints:
    gcloud org-policies list-custom-constraints --organization=ORGANIZATION_ID
    Reemplaza ORGANIZATION_ID por el ID del recurso de tu organización. Para obtener más información, consulta Visualiza las políticas de la organización.

    Aplica de manera forzosa una política de la organización personalizada

    Puedes aplicar una restricción booleana si creas una política de la organización que haga referencia a ella y si aplicas esa política a un recurso Google Cloud .

    Console

    1. En la consola de Google Cloud, ve a la página Políticas de la organización.

      Ir a Políticas de la organización

    2. En el selector de proyectos, selecciona el proyecto para el que deseas configurar la política de la organización.
    3. En la lista de la página Políticas de la organización, selecciona tu restricción para ver la página Detalles de la política de esa restricción.
    4. Si deseas configurar las políticas de la organización para este recurso, haz clic en Administrar política.
    5. En la página Editar política, selecciona Anular la política del elemento superior.
    6. Haz clic en Agregar una regla.
    7. En la sección Aplicación, selecciona si la aplicación de esta política de la organización está activada o desactivada.
    8. Opcional: haz clic en Agregar condición para que la política de la organización sea condicional en una etiqueta. Ten en cuenta que si agregas una regla condicional a una política de la organización, debes agregar al menos una regla sin condición o la política no se puede guardar. Para obtener más información, consulta Configura una política de la organización con etiquetas.
    9. Si se trata de una restricción personalizada, puedes hacer clic en Probar cambios para simular el efecto de esta política de la organización. Para obtener más información, consulta Prueba los cambios en las políticas de la organización con Policy Simulator.
    10. Para finalizar y aplicar la política de la organización, haz clic en Establecer política. La política tarda hasta 15 minutos en aplicarse.

    gcloud

    Para crear una política de la organización que aplique una restricción booleana, crea un archivo de política en formato YAML que haga referencia a la restricción:

          name: projects/PROJECT_ID/policies/CONSTRAINT_NAME
          spec:
            rules:
            - enforce: true
        

    Reemplaza lo siguiente:

    • PROJECT_ID: el proyecto en el que deseas aplicar tu restricción.
    • CONSTRAINT_NAME: el nombre que definiste para tu restricción personalizada. Por ejemplo: custom.allowProjectForXDepartmentNameOnly

    Para aplicar la política de la organización que contiene la restricción, ejecuta el siguiente comando:

        gcloud org-policies set-policy POLICY_PATH
        

    Reemplaza POLICY_PATH por la ruta de acceso completa al archivo YAML de la política de la organización. La política tarda hasta 15 minutos en aplicarse.

    Prueba la política de la organización personalizada

    En el siguiente ejemplo, se crea una restricción y una política personalizadas que requieren que todos los IDs de proyecto comiencen con dev_ en tu organización.

    Antes de comenzar, identifica el ID de tu organización.

    Crea la restricción

    1. Para definir una restricción que niegue todas las creaciones y actualizaciones de proyectos si el ID del proyecto no comienza con dev_, crea el constraint-allow-dev-projects.yaml con el siguiente contenido:

      name: organizations/ORGANIZATION_ID/customConstraints/custom.allowProjectForDevIdOnly
      resourceTypes:
      - cloudresourcemanager.googleapis.com/Project
      methodTypes:
      - CREATE
      - UPDATE
      condition: "resource.projectId.startsWith(\"dev_\")"
      actionType: ALLOW
      displayName: Allow dev_ projects
      description: All projects in the org should start with dev_.
      

      Reemplaza ORGANIZATION_ID por el ID de tu organización.

    2. Aplica la restricción:

      gcloud org-policies set-custom-constraint ~/constraint-allow-dev-projects.yaml
      
    3. Verifica que la restricción exista:

      gcloud org-policies list-custom-constraints --organization=ORGANIZATION_ID
      

      El resultado es similar a este:

      CUSTOM_CONSTRAINT                ACTION_TYPE  METHOD_TYPES   RESOURCE_TYPES                                      DISPLAY_NAME
      custom.allowProjectForDevIdOnly  ALLOW        CREATE,UPDATE  cloudresourcemanager.googleapis.com/Project   Allow dev_ projects
      ...
      

    Crea la política

    1. Crea el archivo policy-enable-dev-projects.yaml con la siguiente política:

      Name: organizations/ORGANIZATION_ID/policies/custom.allowProjectForDevIdOnly
      spec:
        rules:
        - enforce: true
      

      Reemplaza ORGANIZATION_ID por el ID de tu organización.

    2. Aplica la política:

      gcloud org-policies set-policy ~/policy-enable-dev-projects.yaml
      
    3. Verifica que la política exista:

      gcloud org-policies list --organization=ORGANIZATION_ID
      

      El resultado es similar a este:

      CONSTRAINT                        LIST_POLICY    BOOLEAN_POLICY    ETAG
      custom.allowProjectForDevIdOnly   -              SET               COCsm5QGENiXi2E=
      

    Después de aplicar la política, Google Cloud tarda unos dos minutos en comenzar a aplicarla.

    Prueba la política

    Crea un proyecto con el ID sampleDemoProject en la organización:

    gcloud projects create sampleDemoProject \
        --organization=ORGANIZATION_ID
    

    Esta es la salida:

    PERMISSION_DENIED: The caller does not have permission
    

    Ejemplos de políticas de la organización personalizadas para casos de uso comunes

    En la siguiente tabla, se proporciona la sintaxis de algunas restricciones personalizadas para casos de uso comunes:

    Descripción Sintaxis de la restricción
    Se deniega la creación de proyectos nuevos en la carpeta 1234 (secure_admin_folder).
          name: organizations/ORGANIZATION_ID/customConstraints/custom.disableNewProjectInSecureAdminFolder
          resourceTypes:
          - cloudresourcemanager.googleapis.com/Project
          methodTypes:
          - CREATE
          condition: "resource.parent == "organizations/1234""
          actionType: DENY
          displayName: Disable new project creation in the secure admin folder
          description: Do not allow creation of new projects in the secure folders.
          
    Inhabilita la creación de una carpeta dentro de otra para controlar la profundidad del árbol de jerarquía de recursos.
          name: organizations/ORGANIZATION_ID/customConstraints/custom.disableFolderCreation
          resourceTypes:
          - cloudresourcemanager.googleapis.com/Folder
          methodTypes:
          - CREATE
          condition: "resource.parent.startsWith("folders")"
          actionType: DENY
          displayName: Disable creation of a folder inside another folder
          description: Do not allow creation of a folder within another folder when
                       the resource hierarchy is set to a maximum value of 1.
          

    Recursos admitidos de Resource Manager

    En la siguiente tabla, se enumeran los recursos de Resource Manager a los que puedes hacer referencia en las restricciones personalizadas.

    Recurso Campo
    cloudresourcemanager.googleapis.com/Folder resource.displayName
    resource.parent
    cloudresourcemanager.googleapis.com/Project resource.parent
    resource.projectId

    ¿Qué sigue?