Sincronizza diversi sistemi di identità

Il controllo dell'accesso in Google Cloud Search si basa sull'Account Google dell'utente. Durante l'indicizzazione dei contenuti, tutti gli ACL sugli elementi devono risolversi in ID utente o gruppo Google (indirizzi email) validi.

In molti casi un repository non ha una conoscenza diretta degli Account Google. Gli utenti possono essere rappresentati da account locali o utilizzare l'accesso federato con un provider di identità e un ID, diverso dall'indirizzo email dell'utente, per identificare ciascun account. Questo ID è chiamato ID esterno.

Le origini identità, create utilizzando la Console di amministrazione, aiutano a colmare questo divario tra i sistemi di identità in quanto:

Utilizza le origini identità quando:

  • Il repository non conosce l'indirizzo email principale dell'utente in Google Workspace o Google Cloud Directory.
  • Il repository definisce i gruppi per il controllo dell'accesso che non corrispondono a gruppi basati su email in Google Workspace.

Le origini identità migliorano l'efficienza dell'indicizzazione disaccoppiando l'indicizzazione dalla mappatura delle identità. Questo disaccoppiamento ti consente di rimandare la ricerca dell'utente durante la creazione di ACL e l'indicizzazione degli elementi.

Deployment di esempio

La Figura 1 mostra un deployment di esempio in cui un'azienda utilizza repository sia on-premise che cloud. Ogni repository usa un tipo diverso di ID esterno per fare riferimento agli utenti.

Deployment di esempio
Figura 1. Esempio di deployment aziendale con diversi tipi di identità.

Il repository 1 identifica l'utente utilizzando l'indirizzo email dichiarato utilizzando SAML. Poiché il repository 1 è a conoscenza dell'indirizzo email principale dell'utente in Google Workspace o Cloud Directory, non è necessaria un'origine identità.

Il repository 2 si integra direttamente con una directory on-premise e identifica l'utente tramite il suo attributo sAMAccountName. Poiché il repository 2 utilizza un attributo sAMAccountName come ID esterno, è necessaria un'origine identità.

Crea un'origine identità

Se hai bisogno di un'origine identità, consulta Mappare le identità degli utenti in Cloud Search.

Prima di creare un connettore di contenuti, devi creare un'origine identità perché avrai bisogno dell'ID origine identità per creare gli ACL e indicizzare i dati. Come accennato in precedenza, la creazione di un'origine identità crea anche una proprietà utente personalizzata in Cloud Directory. Utilizza questa proprietà per registrare l'ID esterno per ogni utente nel repository. Alla proprietà viene assegnato un nome utilizzando la convenzione IDENTITY_SOURCE_ID_identity.

La tabella seguente mostra due origini identità: una per contenere i nomi degli account SAM (sAMAccountName) come ID esterni e una per gli ID utente (uid) come ID esterni.

Origine identità proprietà utente ID esterno
id1 id1_identity sAMAccountName
id2 id2_identity uid

Crea un'origine identità per ogni possibile ID esterno utilizzato per fare riferimento a un utente nella tua azienda.

La tabella seguente mostra come un utente con un Account Google e due ID esterni (id1_identity e id2_identity) e i relativi valori vengono visualizzati in Cloud Directory:

utente email id1_identity id2_identity
Anna ann@example.com esempio\ann 1001

Puoi fare riferimento allo stesso utente utilizzando i tre diversi ID (email Google, sAMAccountName e uid) quando crei ACL per l'indicizzazione.

Scrivi ACL utente

Utilizza il metodo getUserPrincpal() o getGroupPrincipal() per creare entità utilizzando un ID esterno fornito.

L'esempio seguente mostra come recuperare le autorizzazioni dei file. Queste autorizzazioni includono il nome di ciascun utente che ha accesso al file.

FilePermissionSample.java
/**
 * Sample for mapping permissions from a source repository to Cloud Search
 * ACLs. In this example, POSIX file permissions are used a the source
 * permissions.
 *
 * @return Acl
 * @throws IOException if unable to read file permissions
 */
static Acl mapPosixFilePermissionToCloudSearchAcl(Path pathToFile) throws IOException {
  // Id of the identity source for external user/group IDs. Shown here,
  // but may be omitted in the SDK as it is automatically applied
  // based on the `api.identitySourceId` configuration parameter.
  String identitySourceId = "abcdef12345";

  // Retrieve the file system permissions for the item being indexed.
  PosixFileAttributeView attributeView = Files.getFileAttributeView(
      pathToFile,
      PosixFileAttributeView.class,
      LinkOption.NOFOLLOW_LINKS);

  if (attributeView == null) {
    // Can't read, return empty ACl
    return new Acl.Builder().build();
  }

  PosixFileAttributes attrs = attributeView.readAttributes();
  // ...
}

Il seguente snippet di codice mostra come creare entità che sono proprietari utilizzando l'ID esterno (externalUserName) archiviato negli attributi.

FilePermissionSample.java
// Owner, for search quality.
// Note that for principals the name is not the primary
// email address in Cloud Directory, but the local ID defined
// by the OS. Users and groups must be referred to by their
// external ID and mapped via an identity source.
List<Principal> owners = Collections.singletonList(
    Acl.getUserPrincipal(attrs.owner().getName(), identitySourceId)
);

Infine, lo snippet di codice riportato di seguito mostra come creare entità lettori del file.

FilePermissionSample.java
// List of users to grant access to
List<Principal> readers = new ArrayList<>();

// Add owner, group, others to readers list if permissions
// exist. For this example, other is mapped to everyone
// in the organization.
Set<PosixFilePermission> permissions = attrs.permissions();
if (permissions.contains(PosixFilePermission.OWNER_READ)) {
  readers.add(Acl.getUserPrincipal(attrs.owner().getName(), identitySourceId));
}
if (permissions.contains(PosixFilePermission.GROUP_READ)) {
  String externalGroupName = attrs.group().getName();
  Principal group = Acl.getGroupPrincipal(externalGroupName, identitySourceId);
  readers.add(group);
}
if (permissions.contains(PosixFilePermission.OTHERS_READ)) {
  Principal everyone = Acl.getCustomerPrincipal();
  readers.add(everyone);
}

Una volta ottenuto un elenco di lettori e proprietari, puoi creare l'ACL:

FilePermissionSample.java
// Build the Cloud Search ACL. Note that inheritance of permissions
// from parents is omitted. See `setInheritFrom()` and `setInheritanceType()`
// methods on the builder if required by your implementation.
Acl acl = new Acl.Builder()
    .setReaders(readers)
    .setOwners(owners)
    .build();

L'API REST sottostante utilizza il pattern identitysources/IDENTITY_SOURCE_ID/users/EXTERNAL_IDper l'ID durante la creazione delle entità. Facendo riferimento alle tabelle precedenti, se crei un ACL con id1_identity di Ann (SAMAccountName), l'ID sarebbe risolto a:

identitysources/id1_identity/users/example/ann

L'intero ID è chiamato ID intermedio dell'utente perché fornisce un bridge tra l'ID esterno e gli ID Google archiviati in Cloud Directory.

Per ulteriori informazioni sulla modellazione degli ACL utilizzati per un repository, consulta ACL.

Gruppi sulla mappa

Le origini identità fungono anche da spazio dei nomi per i gruppi utilizzati negli ACL. Puoi utilizzare questa funzionalità dello spazio dei nomi per creare e mappare i gruppi utilizzati solo a scopo di sicurezza o che sono locali in un repository.

Utilizza l'API Cloud Identity Groups per creare un gruppo e gestire le relative iscrizioni. Per associare il gruppo a un'origine identità, utilizza il nome della risorsa dell'origine identità come spazio dei nomi del gruppo.

Il seguente snippet di codice mostra come creare un gruppo utilizzando l'API Cloud Identity Groups:

CreateGroupCommand.java
String namespace = "identitysources/" + idSource;
Group group = new Group()
    .setGroupKey(new EntityKey().setNamespace(namespace).setId(groupId))
    .setDescription("Demo group")
    .setDisplayName(groupName)
    .setLabels(Collections.singletonMap("system/groups/external", ""))
    .setParent(namespace);
try {
  CloudIdentity service = Utils.buildCloudIdentityService();
  Operation createOperation = service.groups().create(group).execute();

  if (createOperation.getDone()) {
    // Note: The response contains the data for a Group object, but as
    // individual fields. To convert to a Group instance, either populate
    // the fields individually or serialize & deserialize to/from JSON.
    //
    // Example:
    // String json = service.getJsonFactory().toString(response);
    // Group createdGroup =  service.getObjectParser()
    //     .parseAndClose(new StringReader(json), Group.class);
    System.out.printf("Group: %s\n",
        createOperation.getResponse().toString());
  } else {
    // Handle case where operation not yet complete, poll for
    // completion. API is currently synchronous and all operations return
    // as completed.
    // ...
  }
} catch (Exception e) {
  System.err.printf("Unable to create group: %s", e.getMessage());
  e.printStackTrace(System.err);
}

Crea un ACL di gruppo

Per creare un ACL di gruppo, utilizza il metodo getGroupPrincipal() per creare un'entità gruppo utilizzando un ID esterno fornito. Quindi, crea l'ACL utilizzando la classe Acl.Builder come segue:

FilePermissionSample.java
if (permissions.contains(PosixFilePermission.GROUP_READ)) {
  String externalGroupName = attrs.group().getName();
  Principal group = Acl.getGroupPrincipal(externalGroupName, identitySourceId);
  readers.add(group);
}

Connettori di identità

Sebbene sia possibile utilizzare ID esterni non Google per creare ACL ed elementi di indice, gli utenti non possono visualizzare gli elementi di una ricerca finché i loro ID esterni non si risolvono in un ID Google in Cloud Directory. Esistono tre modi per assicurarsi che Cloud Directory conosca sia l'ID Google sia gli ID esterni di un utente:

I connettori di identità sono programmi utilizzati per mappare gli ID esterni dalle identità aziendali (utenti e gruppi) alle identità Google interne utilizzate da Google Cloud Search. Se devi creare un'origine identità, devi creare un connettore di identità.

Google Cloud Directory Sync (GCDS) è un esempio di connettore di identità. Questo connettore di identità mappa le informazioni su utenti e gruppi da Active Directory di Microsoft a Cloud Directory insieme agli attributi utente che potrebbero rappresentare la loro identità in altri sistemi.

Sincronizzazione delle identità con l'API REST

Utilizza il metodo update per sincronizzare le identità utilizzando l'API REST.

Rimappatura delle identità

Dopo aver rimappato l'identità di un elemento a un'altra identità, devi reindicizzare gli elementi affinché la nuova identità possa essere conservata. Ad esempio,

  • se tenti di rimuovere una mappatura da un utente o di rimapparla a un altro utente, il mapping originale viene conservato finché non esegui la reindicizzazione.
  • Se elimini un gruppo mappato presente in un ACL degli elementi e quindi crei un nuovo gruppo con lo stesso groupKey, il nuovo gruppo non fornirà accesso all'elemento finché l'elemento non viene reindicizzato.