Com a política da organização doGoogle Cloud , você controla de forma centralizada e programática os recursos da sua organização. Um administrador de políticas da organização pode definir políticas da organização, ou seja, conjuntos de restrições que se aplicam aos recursos doGoogle Cloud e aos elementos que descendem dele na hierarquia de recursos doGoogle Cloud . É possível aplicar políticas da organização no nível da organização, de pastas ou de projetos.
A política da organização fornece restrições predefinidas para diversos serviços doGoogle Cloud . No entanto, se você desejar um controle mais detalhado e personalizável sobre os campos específicos restritos nas políticas da organização, é possível criar restrições personalizadas e aplicá-las em uma política da organização própria.
Herança de políticas
Por padrão, as políticas da organização são herdadas pelos elementos que descendem dos recursos em que elas são aplicadas. Por exemplo, se você aplicar uma política a uma pasta, o Google Cloud vai aplicá-la a todos os projetos desta pasta. Para saber mais sobre esse comportamento e como fazer alterações, confira Regras para a avaliação da hierarquia.
Recursos compatíveis com o Cloud Armor
Nos recursos do Google Cloud Armor, é possível definir restrições personalizadas para os recursos e campos apresentados a seguir.
-
Política de segurança:
compute.googleapis.com/SecurityPolicy- Nome:
resource.name - Descrição:
resource.description -
Regras:
resource.rules[]-
Ação do cabeçalho:
resource.rules[].headerAction-
Cabeçalhos da solicitação a serem adicionados:
resource.rules[].headerAction.requestHeadersToAdds[]-
Nome do cabeçalho:
resource.rules[].headerAction.requestHeadersToAdds[].headerName -
Valor do cabeçalho:
resource.rules[].headerAction.requestHeadersToAdds[].headerValue
-
Nome do cabeçalho:
-
Cabeçalhos da solicitação a serem adicionados:
-
Correspondente:
resource.rules[].match-
Expressão com controle de versões:
resource.rules[].match.versionedExpr -
Configuração:
resource.rules[].match.config-
Intervalos de IP de origem:
resource.rules[].match.config.srcIpRanges[]
-
Intervalos de IP de origem:
- Expressão:
resource.rules[].match.expr -
Opções para a expressão:
resource.rules[].match.exprOptions-
Opções do reCAPTCHA:
resource.rules[].match.exprOptions.recaptchaOptions-
Chaves do site do token de ação:
resource.rules[].match.exprOptions.recaptchaOptions.actionTokenSiteKeys[] -
Chaves de site para o token de sessão:
resource.rules[].match.exprOptions.recaptchaOptions.sessionTokenSiteKeys[]
-
Chaves do site do token de ação:
-
Opções do reCAPTCHA:
-
Expressão com controle de versões:
-
Correspondente de rede:
resource.rules[].networkMatch-
Correspondência de campo definida pelo usuário:
resource.rules[].networkMatch.userDefinedFieldMatch-
Nome:
resource.rules[].networkMatch.userDefinedFieldMatch.name -
Valores:
resource.rules[].networkMatch.userDefinedFieldMatch.values
-
Nome:
-
Intervalos de IP de origem:
resource.rules[].networkMatch.srcIpRanges -
Intervalos de IP de destino:
resource.rules[].networkMatch.destIpRanges -
Protocolos IP:
resource.rules[].networkMatch.ipProtocols -
Portas de origem:
resource.rules[].networkMatch.srcPorts -
Portas de destino:
resource.rules[].networkMatch.destPorts -
Códigos da região de origem:
resource.rules[].networkMatch.srcRegionCodes -
ASNs de origem:
resource.rules[].networkMatch.srcAsns
-
Correspondência de campo definida pelo usuário:
-
Configuração pré-configurada do WAF:
resource.rules[].preconfiguredWafConfig-
Exclusões:
resource.rules[].preconfiguredWafConfig.exclusions[]-
Conjunto de regras de destino:
resource.rules[].preconfiguredWafConfig.exclusions[].targetRuleSet -
IDs das regras de destino:
resource.rules[].preconfiguredWafConfig.exclusions[].targetRuleIds[] -
Cabeçalhos da solicitação a serem excluídos:
resource.rules[].preconfiguredWafConfig.exclusions[].requestHeadersToExclude[]-
Valor:
resource.rules[].preconfiguredWafConfig.exclusions[].requestHeadersToExclude[].val -
Operação:
resource.rules[].preconfiguredWafConfig.exclusions[].requestHeadersToExclude[].op
-
Valor:
-
Cookies da solicitação a serem excluídos:
resource.rules[].preconfiguredWafConfig.exclusions[].requestCookiesToExclude[]-
Valor:
resource.rules[].preconfiguredWafConfig.exclusions[].requestCookiesToExclude[].val -
Operação:
resource.rules[].preconfiguredWafConfig.exclusions[].requestCookiesToExclude[].op
-
Valor:
-
Parâmetros de consulta da solicitação a serem excluídos:
resource.rules[].preconfiguredWafConfig.exclusions[].requestQueryParamsToExclude[]-
Valor:
resource.rules[].preconfiguredWafConfig.exclusions[].requestQueryParamsToExclude[].val -
Operação:
resource.rules[].preconfiguredWafConfig.exclusions[].requestQueryParamsToExclude[].op
-
Valor:
-
URIs de solicitação a serem excluídos:
resource.rules[].preconfiguredWafConfig.exclusions[].requestUrisToExclude[]-
Valor:
resource.rules[].preconfiguredWafConfig.exclusions[].requestUrisToExclude[].val -
Operação:
resource.rules[].preconfiguredWafConfig.exclusions[].requestUrisToExclude[].op
-
Valor:
-
Conjunto de regras de destino:
-
Exclusões:
-
Opções de redirecionamento:
resource.rules[].redirectOptions[]- Tipo:
resource.rules[].redirectOptions[].type -
Destino:
resource.rules[].redirectOptions[].target
- Tipo:
-
Opções para a limitação de taxa:
resource.rules[].rateLimitOptions[]-
Valor limite para a limitação de taxa:
resource.rules[].rateLimitOptions[].rateLimitThreshold-
Contagem:
resource.rules[].rateLimitOptions[].rateLimitThreshold.count -
Intervalo em segundos:
resource.rules[].rateLimitOptions[].rateLimitThreshold.intervalSec
-
Contagem:
-
Ação para conformidade:
resource.rules[].rateLimitOptions[].conformAction -
Ação para excesso:
resource.rules[].rateLimitOptions[].exceedAction -
Opções para o redirecionamento quando houver excesso:
resource.rules[].rateLimitOptions[].exceedRedirectOptions-
Tipo:
resource.rules[].rateLimitOptions[].exceedRedirectOptions.type -
Destino:
resource.rules[].rateLimitOptions[].exceedRedirectOptions.target
-
Tipo:
-
Status de RPC da ação para excesso:
resource.rules[].rateLimitOptions[].exceedActionRpcStatus-
Código:
resource.rules[].rateLimitOptions[].exceedActionRpcStatus.code -
Mensagem:
resource.rules[].rateLimitOptions[].exceedActionRpcStatus.message
-
Código:
-
Ação para aplicar na chave:
resource.rules[].rateLimitOptions[].enforceOnKey -
Ação para aplicar no nome da chave:
resource.rules[].rateLimitOptions[].enforceOnKeyName -
Ação para aplicar nas configurações da chave:
resource.rules[].rateLimitOptions[].enforceOnKeyConfigs-
Ação para aplicar no tipo de chave:
resource.rules[].rateLimitOptions[].enforceOnKeyConfigs.enforceOnKeyType -
Ação para aplicar no nome da chave:
resource.rules[].rateLimitOptions[].enforceOnKeyConfigs.enforceOnKeyName
-
Ação para aplicar no tipo de chave:
-
Limite de proibição:
resource.rules[].rateLimitOptions[].banThreshold-
Contagem:
resource.rules[].rateLimitOptions[].banThreshold.count -
Intervalo em segundos:
resource.rules[].rateLimitOptions[].banThreshold.intervalSec
-
Contagem:
-
Duração da proibição em segundos:
resource.rules[].rateLimitOptions[].banDurationSec
-
Valor limite para a limitação de taxa:
-
Destino para redirecionamento:
resource.rules[].redirectTarget - Número da regra:
resource.rules[].ruleNumber
-
Ação do cabeçalho:
-
Configuração da proteção adaptativa:
resource.adaptiveProtectionConfig-
Configuração de defesa contra DDoS na Camada 7:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig-
Ativar:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.enable -
Visibilidade da regra:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.ruleVisibility -
Configurações de limite:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[]-
Nome:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].name -
Limite de carga para implantação automática:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].autoDeployLoadThreshold -
Limite de confiança para implantação automática:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].autoDeployConfidenceThreshold -
Limite de impacto no valor de referência para implantação automática:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].autoDeployImpactedBaselineThreshold -
Tempo de expiração da implantação automática em segundos:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].autoDeployExpirationSec -
Limite de carga para detecção:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].detectionLoadThreshold -
QPS absolutas para detecção:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].detectionAbsoluteQps -
QPS para detecção em relação ao valor de referência:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].detectionRelativeToBaselineQps -
Configurações de granularidade do tráfego:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].trafficGranularityConfigs[]-
Tipo:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].trafficGranularityConfigs[].type -
Valor:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].trafficGranularityConfigs[].value -
Ação para ativar cada valor único:
resource.adaptiveProtectionConfig.layer7DdosDefenseConfig.thresholdConfigs[].trafficGranularityConfigs[].enableEachUniqueValue
-
Tipo:
-
Nome:
-
Ativar:
-
Configuração de implantação automática:
resource.adaptiveProtectionConfig.autoDeployConfig-
Limite de carga:
resource.adaptiveProtectionConfig.autoDeployConfig.loadThreshold -
Limite de confiança:
resource.adaptiveProtectionConfig.autoDeployConfig.confidenceThreshold -
Limite do valor de referência afetado:
resource.adaptiveProtectionConfig.autoDeployConfig.impactedBaselineThreshold -
Segundos de expiração:
resource.adaptiveProtectionConfig.autoDeployConfig.expirationSec
-
Limite de carga:
-
Configuração de defesa contra DDoS na Camada 7:
-
Configuração de opções avançadas:
resource.advancedOptionsConfig-
Análise JSON:
resource.advancedOptionsConfig.jsonParsing -
Configuração personalizada em JSON:
resource.advancedOptionsConfig.jsonCustomConfig-
Tipos de conteúdo:
resource.advancedOptionsConfig.jsonCustomConfig.contentTypes[]
-
Tipos de conteúdo:
-
Nível do registro:
resource.advancedOptionsConfig.logLevel -
Cabeçalhos da solicitação de IP do usuário:
resource.advancedOptionsConfig.userIpRequestHeaders[]
-
Análise JSON:
-
Configuração de proteção contra DDoS:
resource.ddosProtectionConfig-
Proteção contra DDoS:
resource.ddosProtectionConfig.ddosProtection
-
Proteção contra DDoS:
-
Configuração de opções para o reCAPTCHA:
resource.recaptchaOptionsConfig-
Chave do site para redirecionamento:
resource.recaptchaOptionsConfig.redirectSiteKey
-
Chave do site para redirecionamento:
- Tipo:
resource.type -
Campos definidos pelo usuário:
resource.userDefinedFields[]- Nome:
resource.userDefinedFields[].name - Base:
resource.userDefinedFields[].base - Deslocamento:
resource.userDefinedFields[].offset - Tamanho:
resource.userDefinedFields[].size - Máscara:
resource.userDefinedFields[].mask
- Nome:
- Nome:
-
Serviço de segurança de borda na rede:
compute.googleapis.com/NetworkEdgeSecurityService- Nome:
resource.name - Descrição:
resource.description - Política de segurança:
resource.securityPolicy
- Nome:
Como definir restrições personalizadas
Uma restrição personalizada é definida pelos recursos, métodos, condições e ações compatíveis com o serviço no qual a política da organização é aplicada. Você define as condições das restrições personalizadas usando a Common Expression Language (CEL). Para saber como definir condições em restrições personalizadas usando a CEL, confira a seção sobre CEL em Como criar e gerenciar políticas da organização.
Antes de começar
-
Configure a autenticação, caso ainda não tenha feito isso.
Com isso, você confirma sua identidade para acesso a serviços e APIs do Google Cloud . Para executar
códigos ou amostras de um ambiente de desenvolvimento local, autentique-se no
Compute Engine selecionando uma das seguintes opções:
Selecione a guia para como planeja usar as amostras nesta página:
Console
Quando você usa o console Google Cloud para acessar serviços Google Cloud e APIs, não é necessário configurar a autenticação.
gcloud
-
Instale a CLI do Google Cloud. Após a instalação, inicialize a Google Cloud CLI executando o seguinte comando:
gcloud initAo usar um provedor de identidade (IdP) externo, primeiro faça login na gcloud CLI com sua identidade federada.
-
- Defina uma região e uma zona padrão.
REST
Para usar as amostras da API REST desta página em um ambiente de desenvolvimento local, use as credenciais fornecidas para gcloud CLI.
Instale a CLI do Google Cloud.
Ao usar um provedor de identidade (IdP) externo, primeiro faça login na gcloud CLI com sua identidade federada.
Saiba mais em Autenticar para usar REST na documentação de autenticação do Google Cloud .
Funções exigidas
Para receber as permissões necessárias para gerenciar políticas da organização em recursos do Cloud Armor, solicite ao seu administrador que conceda os seguintes papéis do IAM:
-
Administrador de políticas da organização (
roles/orgpolicy.policyAdmin) no recurso da organização -
Para testar as restrições:
-
Administrador de segurança do Compute (
roles/compute.securityAdmin) no projeto -
Usuário da conta de serviço (
roles/iam.serviceAccountUser) no projeto
-
Administrador de segurança do Compute (
Para mais informações sobre a concessão de papéis, confira Gerenciar o acesso a projetos, pastas e organizações.
Os papéis predefinidos fornecem as permissões necessárias para gerenciar as políticas da organização em recursos do Cloud Armor. Para acessar as permissões específicas necessárias, expanda a seção Permissões necessárias:
Permissões necessárias
Para gerenciar políticas da organização em recursos do Cloud Armor, são requeridas as seguintes permissões:
-
orgpolicy.constraints.list -
orgpolicy.policies.create -
orgpolicy.policies.delete -
orgpolicy.policies.list -
orgpolicy.policies.update -
orgpolicy.policy.get -
orgpolicy.policy.set
Essas permissões também podem ser concedidas por meio de papéis personalizados ou outros papéis predefinidos.
Configurar uma restrição personalizada
É possível criar uma restrição personalizada e configurá-la para uso nas políticas da organização usando o console do Google Cloud ou a CLI do Google Cloud.Console
No console do Google Cloud , acesse a página Políticas da organização.
Selecione o Seletor de projetos na parte de cima da página.
No seletor de projetos, selecione o projeto em que você quer definir a política da organização.
Clique em Restrição personalizada.
Na caixa Nome de exibição, digite um nome legível para a restrição. Esse campo pode ter no máximo 200 caracteres. Não use PII ou dados sensíveis nos nomes de restrições, porque eles podem ser expostos em mensagens de erro.
Na caixa ID da restrição, digite o nome que você quer para a nova restrição personalizada. Uma restrição personalizada precisa começar com
custom.e só pode incluir letras maiúsculas, minúsculas ou números, por exemplo, custom.requireSecurityPolicyWithStandardJsonParsing. O tamanho máximo desse campo é de 70 caracteres, sem contar o prefixo (por exemplo,organizations/123456789/customConstraints/custom.).Na caixa Descrição, digite uma descrição legível a ser exibida como uma mensagem de erro quando a política for violada. Esse campo pode ter no máximo 2.000 caracteres.
Na caixa Tipo de recurso, selecione o nome do recurso REST do Google Cloudque contém o objeto e o campo que você quer restringir. Por exemplo,
compute.googleapis.com/SecurityPolicy.Em Método de restrição, selecione se a restrição será aplicada apenas ao método REST
CREATEou também aos métodos RESTCREATEeUPDATE.Para definir uma condição, clique em Editar condição.
No painel Adicionar condição, crie uma condição CEL que se refira a um recurso de serviço compatível. Esse campo pode ter no máximo 1.000 caracteres.
Clique em Salvar.
Em Ação, selecione se você quer permitir ou negar o método avaliado quando a condição acima é atendida.
Clique em Criar restrição.
Quando você digita um valor em cada campo, a configuração YAML equivalente à restrição personalizada é exibida à direita.
gcloud
Para criar uma restrição personalizada usando a CLI do Google Cloud, crie um arquivo YAML.
name: organizations/ORGANIZATION_ID/customConstraints/CONSTRAINT_NAME resource_types: compute.googleapis.com/RESOURCE_NAME method_types: – METHOD1 – METHOD2 condition: "CONDITION" action_type: ACTION display_name: DISPLAY_NAME description: DESCRIPTION
Substitua:
ORGANIZATION_ID: o ID da organização, como123456789.CONSTRAINT_NAME: o nome da nova restrição personalizada. Uma restrição personalizada precisa começar comcustom.e só pode incluir letras maiúsculas, minúsculas ou números, por exemplo, custom.requireSecurityPolicyWithStandardJsonParsing. O tamanho máximo desse campo é de 70 caracteres, sem contar o prefixo (por exemplo,organizations/123456789/customConstraints/custom).RESOURCE_NAME: o nome (não o URI) do recurso REST da API Compute Engine que contém o objeto e o campo que você quer restringir. Por exemplo, compute.googleapis.com/SecurityPolicy.METHOD1,METHOD2,...: uma lista de métodos RESTful nos quais a restrição será aplicada. Pode serCREATEouCREATEeUPDATE.CONDITION: uma condição de CEL gravada com base na representação de um recurso de serviço compatível. Este campo pode ter, no máximo, 1.000 caracteres. Confira Recursos compatíveis para mais informações sobre os recursos disponíveis para a gravação de condições.ACTION: a ação a ser realizada ao atender acondition. Pode serALLOWouDENY.DISPLAY_NAME: um nome legível para a restrição. Esse campo pode ter no máximo 200 caracteres.DESCRIPTION: uma descrição legível da restrição, a ser exibida como mensagem de erro quando a política é violada. Esse campo pode ter no máximo 2.000 caracteres.
Para saber como criar uma restrição personalizada, consulte Como definir restrições personalizadas.
Console
Para criar uma restrição personalizada, faça o seguinte:
- No console do Google Cloud , acesse a página Políticas da organização.
- No seletor de projetos, selecione o projeto em que você quer definir a política da organização.
- Clique em Restrição personalizada.
- Na caixa Nome de exibição, insira um nome legível para a restrição. Esse nome é usado em mensagens de erro e pode ser usado para identificação e depuração. Não use informações de identificação pessoal (PII) ou dados sensíveis em nomes de exibição, porque eles podem ser expostos em mensagens de erro. Esse campo pode ter até 200 caracteres.
-
Na caixa ID da restrição, insira o ID que você quer para a nova restrição personalizada. Uma restrição personalizada só pode conter letras (maiúsculas e minúsculas) ou
números, por exemplo,
custom.requireSecurityPolicyWithStandardJsonParsing. Esse campo pode conter até 70 caracteres, sem contar o prefixo (custom.), por exemplo,organizations/123456789/customConstraints/custom. Não inclua PII ou dados sensíveis no ID da restrição, porque eles podem ser expostos em mensagens de erro. - Na caixa Descrição, insira uma descrição legível da restrição. Essa descrição é usada como uma mensagem de erro quando a política é violada. Inclua detalhes sobre o motivo da violação e como resolver o problema. Não inclua PII ou dados sensíveis na descrição, porque eles podem ser expostos em mensagens de erro. Esse campo pode conter até 2.000 caracteres.
-
Na caixa Tipo de recurso, selecione o nome do recurso REST do Google Cloud que contém o objeto e o campo que você quer restringir. Por exemplo,
container.googleapis.com/NodePool. A maioria dos tipos de recursos aceita até 20 restrições personalizadas. Se você tentar criar mais restrições personalizadas, a operação vai falhar. -
Essa restrição só pode ser aplicada no método REST
CREATE. - Para definir uma condição, clique em Editar condição.
-
No painel Adicionar condição, crie uma condição de CEL que se refira a um recurso de serviço compatível, por exemplo,
resource.management.autoUpgrade == false. Esse campo pode ter até 1.000 caracteres. Para detalhes sobre o uso da CEL, consulte Common Expression Language. Para mais informações sobre os recursos de serviço que você pode usar nas restrições personalizadas, consulte Serviços compatíveis com restrição personalizada. - Clique em Salvar.
- Em Ação, selecione se você quer permitir ou negar o método avaliado quando a condição é atendida.
- Clique em Criar restrição.
Para ver os métodos compatíveis para cada serviço, encontre o serviço em Serviços que aceitam restrições personalizadas.
A ação de negação significa que a operação para criar ou atualizar o recurso será bloqueada se a condição for avaliada como verdadeira.
A ação de permissão significa que a operação para criar ou atualizar o recurso só é permitida se a condição for avaliada como verdadeira. Todos os outros casos, exceto os listados explicitamente na condição, estão bloqueados.
Quando você digita um valor em cada campo, a configuração YAML equivalente à restrição personalizada aparece à direita.
gcloud
- Para criar uma restrição personalizada, crie um arquivo YAML com o seguinte formato:
-
ORGANIZATION_ID: o ID da organização, como123456789. -
CONSTRAINT_NAME: o nome da sua nova restrição personalizada. Uma restrição personalizada só pode conter letras (maiúsculas e minúsculas) ou números, por exemplo,custom.requireSecurityPolicyWithStandardJsonParsing. Esse campo pode conter até 70 caracteres, sem contar o prefixo (custom.), por exemplo,organizations/123456789/customConstraints/custom. Não inclua PII ou dados sensíveis no ID da restrição, porque eles podem ser expostos em mensagens de erro. -
RESOURCE_NAME: o nome totalmente qualificado do recurso Google Cloud que contém o objeto e o campo que você quer restringir. Por exemplo,compute.googleapis.com/SecurityPolicy. A maioria dos tipos de recursos aceita até 20 restrições personalizadas. Se você tentar criar mais restrições personalizadas, a operação vai falhar. -
methodTypes: os métodos REST em que a restrição é aplicada. Só pode serCREATE. -
CONDITION: uma condição de CEL gravada em uma representação de um recurso de serviço compatível. Esse campo pode conter até 1.000 caracteres. Por exemplo,"resource.advancedOptionsConfig.jsonParsing != 'STANDARD'". -
ACTION: a ação a ser realizada se oconditionfor atendido. Só pode serALLOW. -
DISPLAY_NAME: um nome legível para a restrição. Esse nome é usado em mensagens de erro e pode ser usado para identificação e depuração. Não use PII ou dados sensíveis em nomes de exibição, porque eles podem ser expostos em mensagens de erro. Esse campo pode ter até 200 caracteres. -
DESCRIPTION: uma descrição legível da restrição a ser exibida como uma mensagem de erro quando a política for violada. Esse campo pode conter até 2.000 caracteres. -
Depois de criar o arquivo YAML para uma nova restrição personalizada, faça a configuração
necessária para disponibilizá-la para as políticas da organização. Para configurar uma restrição personalizada,
use o
comando
gcloud org-policies set-custom-constraint: -
Para verificar se a restrição personalizada existe, use o
comando
gcloud org-policies list-custom-constraints:
name: organizations/ORGANIZATION_ID/customConstraints/CONSTRAINT_NAME resourceTypes: RESOURCE_NAME methodTypes: - CREATE condition: "CONDITION" actionType: ACTION displayName: DISPLAY_NAME description: DESCRIPTION
Substitua:
Para ver os métodos compatíveis com cada serviço, encontre o serviço em Serviços que aceitam restrições personalizadas.
Para mais informações sobre os recursos disponíveis para gravação de condições, consulte Recursos compatíveis.
A ação "permitir" significa que, se a condição for avaliada como verdadeira, a operação para criar ou atualizar o recurso será permitida. Isso também significa que todos os outros casos, exceto o listado explicitamente na condição, estão bloqueados.
gcloud org-policies set-custom-constraint CONSTRAINT_PATH
Substitua CONSTRAINT_PATH pelo caminho completo do arquivo de restrição personalizada. Por exemplo, /home/user/customconstraint.yaml.
Após a conclusão, as restrições personalizadas vão estar disponíveis como políticas da organização na lista de políticas da organização do Google Cloud .
gcloud org-policies list-custom-constraints --organization=ORGANIZATION_ID
Substitua ORGANIZATION_ID pelo ID do recurso da organização.
Para mais informações, consulte Como visualizar políticas da organização.
Aplicar uma restrição personalizada
Para aplicar uma restrição, crie uma política da organização que faça referência a ela e aplique essa política a um recurso do Google Cloud .Console
- No console do Google Cloud , acesse a página Políticas da organização.
- No seletor de projetos, selecione o projeto em que você quer definir a política da organização.
- Na lista da página Políticas da organização, selecione uma restrição para acessar a página Detalhes da política associada.
- Para configurar a política da organização nesse recurso, clique em Gerenciar política.
- Na página Editar política, selecione Substituir a política do recurso pai.
- Clique em Adicionar uma regra.
- Na seção Aplicação, selecione se essa política da organização é aplicada ou não.
- Opcional: para tornar a política da organização condicional em uma tag, clique em Adicionar condição. Se você adicionar uma regra condicional a uma política da organização, inclua pelo menos uma regra não condicional para que a política seja salva. Para mais informações, consulte Definir o escopo das políticas da organização com tags.
- Clique em Testar mudanças para simular o efeito da política da organização. Para mais informações, consulte Testar mudanças na política da organização com o Simulador de política.
- Para aplicar a política da organização no modo de teste, clique em Definir política de simulação. Para mais informações, consulte Testar políticas da organização.
- Depois de verificar se a política da organização no modo de simulação funciona como esperado, clique em Definir política para definir a política ativa.
gcloud
- Para criar uma política da organização com regras booleanas, crie um arquivo YAML para a política que faça referência à restrição:
-
PROJECT_ID: o projeto em que você quer aplicar a restrição. -
CONSTRAINT_NAME: o nome definido para a restrição personalizada. Por exemplo,custom.requireSecurityPolicyWithStandardJsonParsing. -
Para aplicar a política da organização no modo de teste, execute o seguinte comando com a flag
dryRunSpec: -
Depois de verificar se a política da organização no modo de simulação funciona conforme o esperado, defina a política ativa com o comando
org-policies set-policye a flagspec:
name: projects/PROJECT_ID/policies/CONSTRAINT_NAME spec: rules: - enforce: true dryRunSpec: rules: - enforce: true
Substitua:
gcloud org-policies set-policy POLICY_PATH --update-mask=dryRunSpec
Substitua POLICY_PATH pelo caminho completo para o arquivo YAML da
política da organização. A política leva até 15 minutos para entrar em vigor.
gcloud org-policies set-policy POLICY_PATH --update-mask=spec
Substitua POLICY_PATH pelo caminho completo para o arquivo YAML da
política da organização. A política leva até 15 minutos para entrar em vigor.
Exemplo: criar uma restrição que exija a ativação da análise JSON padrão em todas as políticas de segurança
Esta restrição impede a criação de políticas de segurança que não tenham a análise JSON padrão ativada.
gcloud
Crie um arquivo de restrição
requireStandardJsonParsing.yamlcom as informações apresentadas a seguir.name: organizations/ORGANIZATION_ID/customConstraints/custom.requireStandardJsonParsing resource_types: compute.googleapis.com/SecurityPolicy condition: "resource.advancedOptionsConfig.jsonParsing != 'STANDARD'" action_type: DENY method_types: [CREATE, UPDATE] display_name: Security policies must have standard JSON parsing enabled.
Substitua
ORGANIZATION_IDpelo ID da sua organização.Defina a restrição personalizada.
gcloud org-policies set-custom-constraint requireStandardJsonParsing.yaml
Crie um arquivo de política
requireStandardJsonParsing-policy.yamlcom as informações fornecidas no exemplo a seguir e aplique a restrição no nível do projeto. Também é possível definir essa restrição no nível da organização ou da pasta.name: projects/PROJECT_ID/policies/custom.requireStandardJsonParsing spec: rules: – enforce: true
Substitua
PROJECT_IDpela ID do seu projeto.Aplique a política.
gcloud org-policies set-policy requireStandardJsonParsing-policy.yaml
Para testar a restrição, crie uma política de segurança sem configurar o campo de análise JSON.
gcloud compute security-policies create my-policy \ --type=CLOUD_ARMORO resultado deve ser parecido com o seguinte:
ERROR: (gcloud.compute.securityPolicies.create) Could not fetch resource: - Operation denied by custom org policy: [customConstraints/custom.requireStandardJsonParsing] : Security policies must have standard JSON parsing enabled.
Preços
O serviço de políticas da organização, incluindo as políticas da organização predefinidas e personalizadas, é oferecido sem custos financeiros.
A seguir
- Introdução ao Organization Policy Service.
- Criar e gerenciar políticas da organização
- Restrições das políticas da organização