Acl: insert

Cria uma regra de controle de acesso. Faça um teste agora ou veja um exemplo.

Solicitação

Solicitação HTTP

POST https://www.googleapis.com/calendar/v3/calendars/calendarId/acl

Parâmetros

Nome do parâmetro Valor Descrição
Parâmetros de caminho
calendarId string Identificador da agenda. Para extrair os IDs de agenda, chame o método calendarList.list. Se você quiser acessar a agenda principal do usuário conectado, use a palavra-chave primary.
Parâmetros de consulta opcionais
sendNotifications boolean Se é necessário enviar notificações sobre a mudança de compartilhamento da agenda. Opcional. O padrão é "true".

Autorização

Esta solicitação requer autorização com pelo menos um dos seguintes escopos:

Escopo
https://www.googleapis.com/auth/calendar
https://www.googleapis.com/auth/calendar.acls

Para mais informações, consulte a página de autenticação e autorização.

Corpo da solicitação

No corpo da solicitação, informe um recurso Acl com as seguintes propriedades:

Nome da propriedade Valor Descrição Observações
Propriedades obrigatórias
role string O papel atribuído ao escopo. Os valores possíveis são:
  • "none": não oferece acesso.
  • "freeBusyReader": fornece acesso de leitura às informações de disponibilidade/inisponibilidade.
  • "reader": fornece acesso de leitura à agenda. Os eventos particulares vão aparecer para os usuários com acesso de leitor, mas os detalhes do evento vão ficar ocultos.
  • "writer": concede acesso de leitura e gravação à agenda. Os eventos particulares vão aparecer para usuários com acesso de gravação, e os detalhes do evento vão estar visíveis. Dá acesso de leitura às ACLs da agenda.
  • "owner": fornece a propriedade da agenda. Esse papel tem todas as permissões do papel de redator, além da capacidade de manipular ACLs.
gravável
scope object O nível em que o acesso à agenda é concedido por essa regra de ACL.
scope.type string O tipo de escopo. Os valores possíveis são:
  • "default": o escopo público. Esse é o valor padrão.
  • "user": limita o escopo a um único usuário.
  • "group": limita o escopo a um grupo.
  • "domain": limita o escopo a um domínio.
Observação: as permissões concedidas ao escopo "default", ou público, se aplicam a qualquer usuário, autenticado ou não.
Propriedades opcionais
scope.value string O endereço de e-mail de um usuário ou grupo ou o nome de um domínio, dependendo do tipo de escopo. Omitido para o tipo "default". gravável

Resposta

Se for bem-sucedido, esse método retornará um recurso Acl no corpo da resposta.

Exemplos

Observação: os exemplos de código disponíveis para esse método não representam todas as linguagens de programação compatíveis. Consulte a página de bibliotecas cliente para ver uma lista de linguagens compatíveis.

Java

Usa a biblioteca cliente de Java.

import com.google.api.services.calendar.Calendar;
import com.google.api.services.calendar.model.AclRule;

// ...

// Initialize Calendar service with valid OAuth credentials
Calendar service = new Calendar.Builder(httpTransport, jsonFactory, credentials)
    .setApplicationName("applicationName").build();

// Create access rule with associated scope
AclRule rule = new AclRule();
Scope scope = new Scope();
scope.setType("scopeType").setValue("scopeValue");
rule.setScope(scope).setRole("role");

// Insert new access rule
AclRule createdRule = service.acl().insert('primary', rule).execute();
System.out.println(createdRule.getId());

Python

Usa a biblioteca cliente de Python.

rule = {
    'scope': {
        'type': 'scopeType',
        'value': 'scopeEmail',
    },
    'role': 'role'
}

created_rule = service.acl().insert(calendarId='primary', body=rule).execute()

print created_rule['id']

PHP

Usa a biblioteca cliente de PHP.

$rule = new Google_Service_Calendar_AclRule();
$scope = new Google_Service_Calendar_AclRuleScope();

$scope->setType("scopeType");
$scope->setValue("scopeValue");
$rule->setScope($scope);
$rule->setRole("role");

$createdRule = $service->acl->insert('primary', $rule);
echo $createdRule->getId();

Ruby

Usa a biblioteca de cliente Ruby.

rule = Google::Apis::CalendarV3::AclRule.new(
  scope: {
    type: 'scopeType',
    value: 'scopeEmail',
  },
  role: 'role'
)
result = client.insert_acl('primary', rule)
print result.id

Confira!

Use o APIs Explorer abaixo para chamar esse método em dados ativos e ver a resposta.