Un connecteur de contenu est un logiciel permettant de parcourir les données d'un dépôt d'entreprise et de les insérer dans une source de données. Google propose les options suivantes pour développer des connecteurs de contenu:
Le SDK Content Connector. Cette option est une bonne solution si vous programmez en Java. Le SDK Content Connector est un wrapper pour l'API REST qui accélère la création des connecteurs. Pour créer un connecteur de contenu avec ce SDK, reportez-vous à la section Créer un connecteur de contenu à l'aide du SDK Content Connector.
Une API REST de bas niveau ou des bibliothèques d'API. Préférez ces options si vous ne programmez pas en Java, ou si votre base de code est mieux adaptée à une API REST ou à une bibliothèque. Pour créer un connecteur de contenu avec une API REST, consultez la section Créer un connecteur de contenu à l'aide de l'API REST.
Un connecteur de contenu standard effectue les tâches suivantes:
- Lecture et traitement des paramètres de configuration
- Extraction de fragments distincts de données indexables, appelées éléments, à partir du dépôt de contenu tiers
- Combine les LCA, les métadonnées et les données de contenu dans des éléments indexables.
- Indexation des éléments dans la source de données Cloud Search
- (Facultatif) Écoute des notifications de modification en provenance du dépôt de contenu tiers. Ces notifications sont converties en requêtes d'indexation afin que la source de données Cloud Search soit synchronisée avec le dépôt tiers. Le connecteur exécute cette tâche à condition que le dépôt autorise la détection des modifications.
Créer un connecteur de contenu à l'aide du SDK Content Connector
Les sections suivantes expliquent comment créer un connecteur de contenu à l'aide du SDK Content Connector.
Configurer des dépendances
Pour utiliser le SDK, vous devez ajouter des dépendances dans le fichier de compilation. Cliquez sur un onglet ci-dessous afin d'afficher les dépendances pour votre environnement de compilation:
Maven
<dependency>
<groupId>com.google.enterprise.cloudsearch</groupId>
<artifactId>google-cloudsearch-indexing-connector-sdk</artifactId>
<version>v1-0.0.3</version>
</dependency>
Gradle
compile group: 'com.google.enterprise.cloudsearch',
name: 'google-cloudsearch-indexing-connector-sdk',
version: 'v1-0.0.3'
Créer votre configuration de connecteur
Chaque connecteur dispose d'un fichier de configuration contenant ses paramètres (comme l'ID de votre dépôt), Les paramètres sont définis sous forme de paires clé-valeur, par exemple api.sourceId=1234567890abcdef
.
Le SDK Google Cloud Search contient plusieurs paramètres de configuration fournis par Google qui sont utilisés par tous les connecteurs. Les paramètres suivants (fournis par Google) sont à déclarer dans votre fichier de configuration:
- Pour un connecteur de contenu, vous devez déclarer
api.sourceId
etapi.serviceAccountPrivateKeyFile
, car ces paramètres identifient l'emplacement de votre dépôt et du fichier contenant la clé privée nécessaire pour y accéder.
- Pour un connecteur d'identité, vous devez déclarer
api.identitySourceId
, car ce paramètre identifie l'emplacement de la source d'identité externe. En cas de synchronisation des utilisateurs, déclarez égalementapi.customerId
comme ID unique pour le compte Google Workspace de votre entreprise.
À moins que vous souhaitiez remplacer les valeurs par défaut d'autres paramètres fournis par Google, il est inutile de déclarer ces paramètres dans votre fichier de configuration. Pour plus d'informations sur les paramètres de configuration fournis par Google, concernant la génération de certains ID et de certaines clés, entre autres, reportez-vous à la page Paramètres de configuration fournis par Google.
Vous pouvez également définir des paramètres personnalisés propres au dépôt dans votre fichier de configuration.
Transmettre le fichier de configuration au connecteur
Définissez la propriété système config
de manière à transmettre le fichier de configuration à votre connecteur. Pour ce faire, utilisez l'argument -D
lors du démarrage du connecteur. Par exemple, la commande suivante permet de démarrer le connecteur avec le fichier de configuration MyConfig.properties
:
java -classpath myconnector.jar;... -Dconfig=MyConfig.properties MyConnector
Si cet argument n'est pas transmis, le SDK tente d'accéder à un fichier de configuration par défaut nommé connector-config.properties
.
Déterminer votre stratégie de balayage
La fonction principale d'un connecteur de contenu consiste à balayer un dépôt et à en indexer les données. Vous devez mettre en place une stratégie de balayage adaptée à la taille des données et à leur disposition dans votre dépôt. Deux options s'offrent à vous : soit vous élaborez votre propre stratégie, soit vous en choisissez une parmi celles proposées dans le SDK.
- Stratégie de balayage complet
La stratégie de balayage complet consiste à analyser le dépôt entier et à en indexer automatiquement chaque élément. Cette stratégie est couramment employée avec les dépôts de petite taille, lorsque l'entreprise peut se permettre cette opération à chaque indexation.
Cette stratégie de balayage est indiquée pour les dépôts de petite taille, renfermant principalement des données statiques non hiérarchisées. Elle convient également lorsque la détection des modifications est complexe ou incompatible avec le dépôt.
- Stratégie de balayage de liste
La stratégie de balayage de liste consiste à analyser le dépôt entier, y compris les nœuds enfants, tout en déterminant l'état de chaque élément. Puis, lors d'une seconde passe, le connecteur n'indexe que les éléments nouveaux ou mis à jour depuis la dernière indexation. Cette stratégie est couramment utilisée pour actualiser progressivement un index existant (et éviter ainsi un balayage complet à chaque mise à jour de l'index).
Cette stratégie de balayage convient dans les situations suivantes : la détection des modifications est complexe ou incompatible avec le dépôt, les données ne sont pas hiérarchisées ou vous travaillez avec des ensembles de données très volumineux.
- Balayage de graphe
La stratégie de balayage de graphe consiste à analyser l'intégralité du nœud parent en déterminant l'état de chaque élément. Puis, lors d'une seconde passe, le connecteur n'indexe que les éléments du nœud racine qui sont nouveaux ou ont été mis à jour depuis la dernière indexation. Il traite enfin les ID des éléments enfants, puis indexe les éléments nouveaux ou mis à jour au niveau de ces nœuds. Il procède ainsi de manière récursive avec chaque nœud enfant jusqu'à ce que tous les éléments aient été traités. Cette stratégie de balayage est généralement retenue avec les dépôts hiérarchiques pour lesquels il est difficile d'établir une liste exhaustive des ID.
Cette stratégie convient pour explorer des données hiérarchisées, comme une série de répertoires ou de pages Web.
Chacune de ces stratégies de balayage est mise en place au moyen d'un modèle de classe de connecteur disponible dans le SDK. Bien que vous puissiez mettre en œuvre votre propre stratégie de balayage, ces modèles accélèrent considérablement le développement de votre connecteur. Pour créer un connecteur à partir d'un modèle, accédez à la section correspondant à votre stratégie de balayage:
- Créer un connecteur de balayage complet à partir d'un modèle de classe
- Créer un connecteur de balayage de liste à l'aide d'un modèle de classe
- Créer un connecteur de balayage de graphe à partir d'un modèle de classe
Créer un connecteur de balayage complet à l'aide d'un modèle de classe
Cette section fait référence aux extraits de code de l'exemple FullTraversalSample.
Implémenter le point d'entrée du connecteur
Le point d'entrée d'un connecteur est la méthode main()
. La fonction principale de cette méthode consiste à créer une instance de la classe Application
et à appeler sa méthode start()
pour exécuter le connecteur.
Avant d'appeler application.start()
, utilisez la classe IndexingApplication.Builder
pour instancier le modèle FullTraversalConnector
. Le modèle FullTraversalConnector
accepte un objet Repository
dont vous utiliserez les méthodes. L'extrait de code suivant montre comment mettre en œuvre la méthode main()
:
En arrière-plan, le SDK appelle la méthode initConfig()
, après que la méthode main()
de votre connecteur a appelé Application.build
.
La méthode initConfig()
accomplit les tâches suivantes:
- appelle la méthode
Configuation.isInitialized()
pour confirmer que l'objetConfiguration
n'a pas été initialisé ; - Initialise un objet
Configuration
avec les paires clé-valeur fournies par Google. Chaque paire clé-valeur est stockée dans un objetConfigValue
au sein de l'objetConfiguration
.
Implémenter l'interface Repository
L'objet Repository
n'a qu'une fonction, qui consiste à balayer les éléments du dépôt et à les indexer. Lorsque vous utilisez un modèle, il vous suffit de remplacer certaines méthodes dans l'interface Repository
pour créer un connecteur de contenu. Ces méthodes dépendent de la stratégie de balayage et du modèle employés. Pour le modèle FullTraversalConnector
, par exemple, vous devez remplacer les méthodes suivantes:
La méthode
init()
. Pour configurer et initialiser un dépôt de données, remplacez la méthodeinit()
.La méthode
getAllDocs()
. Pour balayer et indexer tous les éléments du dépôt de données, remplacez la méthodegetAllDocs()
. Celle-ci est appelée une fois lors de chaque balayage planifié (tel que défini par votre configuration).(Facultatif) La méthode
getChanges()
. Si votre dépôt accepte la détection des modifications, remplacez la méthodegetChanges()
. Celle-ci est appelée une fois lors de chaque balayage incrémentiel planifié (tel que défini par votre configuration) afin d'extraire les éléments modifiés et de les indexer.(Facultatif) La méthode
close()
. Si vous devez procéder au nettoyage du dépôt, remplacez la méthodeclose()
. Cette méthode est appelée une fois lors de l'arrêt du connecteur.
Chaque méthode de l'objet Repository
renvoie un objet ApiOperation
. C'est grâce à l'objet ApiOperation
que le dépôt est effectivement indexé, via un ou plusieurs appels de la méthode IndexingService.indexItem()
.
Obtenir les paramètres de configuration personnalisés
Lorsque vous effectuez la configuration de votre connecteur, vous devez récupérer les éventuels paramètres personnalisés contenus dans l'objet Configuration
. Cette tâche est généralement effectuée dans une méthode init()
de la classe Repository
.
La classe Configuration
comprend plusieurs méthodes qui permettent d'obtenir différents types de données à partir d'une configuration. Chaque méthode renvoie un objet ConfigValue
. Pour récupérer la valeur réelle, utilisez ensuite la méthode get()
de l'objet ConfigValue
.
L'extrait de code suivant (issu du modèle FullTraversalSample
)
montre comment récupérer une valeur entière personnalisée à partir d'un objet Configuration
:
Pour récupérer et analyser un paramètre contenant plusieurs valeurs, utilisez l'un des analyseurs de type de la classe Configuration
, qui permettent d'analyser les données par fragments distincts.
L'extrait de code suivant (issu du connecteur du tutoriel) permet d'obtenir la liste des noms de dépôts GitHub grâce à la méthode getMultiValue
:
Effectuer un balayage complet
Remplacez la méthode getAllDocs()
pour effectuer un balayage complet et indexer votre dépôt. La méthode getAllDocs()
accepte un point de contrôle qui permet de reprendre l'indexation à partir d'un élément donné si le processus est interrompu. Pour chaque élément du dépôt, vous accomplirez les tâches suivantes dans la méthode getAllDocs()
:
- Définissez les autorisations.
- Définissez les métadonnées de l'élément que vous indexez.
- Combinez les métadonnées et l'élément dans un objet
RepositoryDoc
indexable. - Empaquetez chaque élément indexable dans un itérateur renvoyé par la méthode
getAllDocs()
.getAllDocs()
renvoie en fait unCheckpointCloseableIterable
, qui correspond à une itération d'objetsApiOperation
, chaque objet représentant une requête d'API sur un objetRepositoryDoc
(par exemple, une requête d'indexation des éléments).
Si l'ensemble d'éléments est trop volumineux pour être traité via un seul appel, insérez un point de contrôle et définissez hasMore(true)
pour indiquer qu'il reste des éléments à indexer.
Définir les autorisations pour un élément
Votre dépôt s'appuie sur une liste de contrôle d'accès (LCA) pour identifier les utilisateurs ou les groupes ayant accès à un élément. Une LCA est une liste d'ID désignant ces groupes ou ces utilisateurs.
Vous devez dupliquer la LCA utilisée par votre dépôt pour vous assurer que seuls les utilisateurs autorisés à accéder à un élément puissent le voir dans un résultat de recherche. Cette liste doit être incluse lors de l'indexation de l'élément afin que Google Cloud Search dispose des informations nécessaires pour accorder le niveau d'accès qui convient.
Le SDK Content Connector propose un vaste choix de classes et de méthodes pour modéliser les LCA de la plupart des dépôts. Pour chaque élément de votre dépôt, il vous faut analyser la LCA associée et créer une liste correspondante pour Google Cloud Search au moment d'indexer l'élément. Il se peut que la LCA de votre dépôt repose sur des concepts qui compliquent la tâche de modélisation, comme l'héritage de liste. Pour en savoir plus sur les LCA de Google Cloud Search, consultez les informations sur les LCA de Google Cloud Search.
Remarque:L'API Cloud Search Indexing accepte les LCA à domaine unique, mais pas les LCA interdomaines. Utilisez la classe Acl.Builder
pour définir l'accès à chaque élément via une LCA. L'extrait de code suivant, tiré de l'exemple de balayage complet, permet à tous les utilisateurs ou "comptes principaux" (getCustomerPrincipal()
) d'être des "lecteurs" de tous les éléments (.setReaders()
) dans le cadre d'une recherche.
Vous devez savoir comment fonctionnent les LCA afin de les modéliser correctement pour le dépôt. Il se peut que les fichiers à indexer soient stockés dans un système de fichiers basé sur un modèle d'héritage, dans lequel les dossiers enfants héritent des autorisations des dossiers parents. La modélisation du mécanisme d'héritage des LCA nécessite des connaissances supplémentaires. Pour en savoir plus, consultez les informations sur les LCA de Google Cloud Search.
Définir les métadonnées d'un élément
Les métadonnées sont stockées dans un objet Item
. La création d'un objet Item
nécessite un minimum d'informations : un ID de chaîne unique ainsi que le type, la LCA, l'URL et la version de l'élément.
L'extrait de code suivant montre comment créer un objet Item
avec la classe auxiliaire
IndexingItemBuilder
.
Créer l'élément indexable
Après avoir défini les métadonnées de l'élément, vous pouvez créer l'élément indexable avec la classe RepositoryDoc.Builder
. L'exemple suivant vous montre la marche à suivre.
Un RepositoryDoc
est un type d'objet ApiOperation
qui exécute la requête IndexingService.indexItem()
.
Vous pouvez également utiliser la méthode setRequestMode()
de la classe RepositoryDoc.Builder
pour définir le mode de requête d'indexation (ASYNCHRONOUS
ou SYNCHRONOUS
) :
ASYNCHRONOUS
- Le mode asynchrone augmente la latence entre l'indexation et la diffusion des éléments, mais autorise un débit supérieur pour les requêtes d'indexation. Il est recommandé pour l'indexation initiale (le remplissage) de l'ensemble du dépôt.
SYNCHRONOUS
- Le mode synchrone diminue la latence entre l'indexation et la diffusion des éléments, mais autorise un débit moindre. Il est recommandé pour l'indexation des mises à jour et des modifications apportées au dépôt. Si vous n'indiquez pas de mode de requête, la valeur
SYNCHRONOUS
est attribuée par défaut.
Empaqueter chaque élément indexable dans un itérateur
La méthode getAllDocs()
renvoie un Iterator
(plus précisément un CheckpointCloseableIterable
) d'objets RepositoryDoc
. Vous pouvez construire et renvoyer un itérateur à l'aide de la classe CheckpointClosableIterableImpl.Builder
. L'extrait de code suivant montre la marche à suivre.
Le SDK exécute chaque appel d'indexation figurant dans l'itérateur.
Étapes suivantes
Voici quelques étapes que vous pouvez également suivre :
- (Facultatif) Si votre débit d'indexation semble lent, reportez-vous à la section Augmenter le taux d'indexation de
FullTraversalConnector
. - (Facultatif) Ajoutez la méthode
close()
pour libérer les ressources avant l'arrêt du connecteur. - (Facultatif) Créez un connecteur d'identité à l'aide du SDK Content Connector.
Créer un connecteur de balayage de liste à l'aide d'un modèle de classe
La file d'attente d'indexation Cloud Search permet de conserver l'ID de chaque élément du dépôt ainsi que la valeur de hachage associée (le cas échéant). Le connecteur de balayage de liste place les ID d'élément dans la file d'attente d'indexation Google Cloud Search, puis les récupère un par un en vue d'indexer les éléments. Google Cloud Search gère les files d'attente et compare leur contenu afin de déterminer l'état des éléments (si un élément a été supprimé du dépôt, par exemple). Pour en savoir plus sur la file d'attente d'indexation Cloud Search, consultez la section File d'attente d'indexation Cloud Search.
Cette section fait référence aux extraits de code de l'exemple ListTraversalSample.
Implémenter le point d'entrée du connecteur
Le point d'entrée d'un connecteur est la méthode main()
. La fonction principale de cette méthode consiste à créer une instance de la classe Application
et à appeler sa méthode start()
pour exécuter le connecteur.
Avant d'appeler application.start()
, utilisez la classe IndexingApplication.Builder
pour instancier le modèle ListingConnector
. Le modèle ListingConnector
accepte un objet Repository
dont vous utiliserez les méthodes. L'extrait de code suivant montre comment instancier le modèle ListingConnector
et l'objet Repository
associé:
En arrière-plan, le SDK appelle la méthode initConfig()
, après que la méthode main()
de votre connecteur a appelé Application.build
.
La méthode initConfig()
:
- appelle la méthode
Configuation.isInitialized()
pour confirmer que l'objetConfiguration
n'a pas été initialisé ; - Initialise un objet
Configuration
avec les paires clé-valeur fournies par Google. Chaque paire clé-valeur est stockée dans un objetConfigValue
au sein de l'objetConfiguration
.
Implémenter l'interface Repository
L'objet Repository
n'a qu'une fonction, qui consiste à balayer les éléments du dépôt et à les indexer. Lorsque vous utilisez un modèle, il vous suffit de remplacer certaines méthodes dans l'interface Repository
pour créer un connecteur de contenu.
Ces méthodes dépendent de la stratégie de balayage et du modèle employés. Pour le modèle ListingConnector
, par exemple, vous devez remplacer les méthodes suivantes:
La méthode
init()
. Pour configurer et initialiser un dépôt de données, remplacez la méthodeinit()
.La méthode
getIds()
. Pour récupérer les ID et les valeurs de hachage de l'ensemble des enregistrements du dépôt, remplacez la méthodegetIds()
.La méthode
getDoc()
. Pour ajouter des éléments à l'index, ou mettre à jour, modifier ou supprimer des éléments spécifiques, remplacez la méthodegetDoc()
.(Facultatif) La méthode
getChanges()
. Si votre dépôt accepte la détection des modifications, remplacez la méthodegetChanges()
. Celle-ci est appelée une fois lors de chaque balayage incrémentiel planifié (tel que défini par votre configuration) afin d'extraire les éléments modifiés et de les indexer.(Facultatif) La méthode
close()
. Si vous devez procéder au nettoyage du dépôt, remplacez la méthodeclose()
. Cette méthode est appelée une fois lors de l'arrêt du connecteur.
Chaque méthode de l'objet Repository
renvoie un objet ApiOperation
. C'est grâce à l'objet ApiOperation
que le dépôt est effectivement indexé, via un ou plusieurs appels de la méthode IndexingService.indexItem()
.
Obtenir les paramètres de configuration personnalisés
Lorsque vous effectuez la configuration de votre connecteur, vous devez récupérer les éventuels paramètres personnalisés contenus dans l'objet Configuration
. Cette tâche est généralement effectuée dans une méthode init()
de la classe Repository
.
La classe Configuration
comprend plusieurs méthodes qui permettent d'obtenir différents types de données à partir d'une configuration. Chaque méthode renvoie un objet ConfigValue
. Pour récupérer la valeur réelle, utilisez ensuite la méthode get()
de l'objet ConfigValue
.
L'extrait de code suivant (issu du modèle FullTraversalSample
)
montre comment récupérer une valeur entière personnalisée à partir d'un objet Configuration
:
Pour récupérer et analyser un paramètre contenant plusieurs valeurs, utilisez l'un des analyseurs de type de la classe Configuration
, qui permettent d'analyser les données par fragments distincts.
L'extrait de code suivant (issu du connecteur du tutoriel) permet d'obtenir la liste des noms de dépôts GitHub grâce à la méthode getMultiValue
:
Effectuer un balayage de liste
Remplacez la méthode getIds()
pour récupérer les ID et les valeurs de hachage de l'ensemble des enregistrements du dépôt.
La méthode getIds()
accepte un point de contrôle. qui permet de reprendre l'indexation à partir d'un élément donné si le processus est interrompu.
Remplacez ensuite la méthode getDoc()
afin de traiter chaque élément de la file d'attente d'indexation Cloud Search.
Transmettre les ID et valeurs de hachage des éléments
Remplacez getIds()
pour récupérer les ID des éléments et les valeurs de hachage de contenu associées dans le dépôt. Les paires ID/valeur de hachage sont ensuite empaquetées dans une requête de transmission et placées dans la file d'attente d'indexation Cloud Search. Les ID des éléments racines ou parents sont généralement transmis en premier, suivis des ID des éléments enfants, jusqu'à ce que l'arborescence ait été entièrement traitée.
La méthode getIds()
accepte un point de contrôle représentant le dernier élément à indexer. Le point de contrôle permet de reprendre l'indexation à partir d'un élément donné si le processus est interrompu. Pour chaque élément du dépôt, vous accomplirez les tâches suivantes dans la méthode getIds()
:
- Récupérez l'ID et la valeur de hachage associée (le cas échéant) pour chaque élément du dépôt.
- Empaquetez chaque paire ID/valeur de hachage dans un objet
PushItems
. - Combinez chaque objet
PushItems
dans un itérateur renvoyé par la méthodegetIds()
.getIds()
renvoie en fait unCheckpointCloseableIterable
, qui correspond à une itération d'objetsApiOperation
, chaque objet représentant une requête d'API sur un objetRepositoryDoc
(par exemple, une requête de placement des éléments dans la file d'attente).
L'extrait de code suivant montre comment récupérer l'ID et la valeur de hachage de chaque élément, puis insérer ces informations dans un objet PushItems
.
Un objet PushItems
correspond à une requête ApiOperation
visant à placer un élément dans la file d'attente d'indexation Cloud Search.
L'extrait de code suivant montre comment utiliser la classe PushItems.Builder
pour empaqueter les ID et les valeurs de hachage dans un seul objet ApiOperation
de transmission.
Les éléments sont placés dans la file d'attente d'indexation Cloud Search en vue d'être traités.
Récupérer et traiter chaque élément
Remplacez la méthode getDoc()
afin de traiter chaque élément de la file d'attente d'indexation Cloud Search.
Un élément peut avoir été ajouté dans le dépôt source, modifié (ou pas) ou bien avoir été supprimé. Récupérez et indexez chaque élément nouveau ou modifié. Retirez de l'index ceux qui n'existent plus dans le dépôt source.
La méthode getDoc()
accepte un élément de la file d'attente d'indexation Google Cloud Search. Pour chaque élément de la file d'attente, vous accomplirez les tâches suivantes dans la méthode getDoc()
:
Vérifiez si l'élément figure dans le dépôt, d'après son ID dans la file d'attente d'indexation Cloud Search. Si ce n'est pas le cas, supprimez-le de l'index.
Interrogez l'index pour connaître l'état de l'élément. Si celui-ci n'a pas changé (état
ACCEPTED
), ne faites rien.Pour les éléments d'index nouveaux ou modifiés, procédez comme suit:
- Définissez les autorisations.
- Définissez les métadonnées de l'élément que vous indexez.
- Combinez les métadonnées et l'élément dans un objet
RepositoryDoc
indexable. - Renvoyez
RepositoryDoc
.
Remarque:Le modèle ListingConnector
ne permet pas de renvoyer une valeur null
sur la méthode getDoc()
. Le renvoi d'une valeur null
génère une exception NullPointerException.
.
Gérer les éléments supprimés
L'extrait de code suivant indique comment déterminer si un élément figure dans le dépôt et, s'il ne s'y trouve pas, comment le supprimer.
Notez que documents
est une structure de données représentant le dépôt. Si documentID
est introuvable dans documents
, renvoyez APIOperations.deleteItem(resourceName)
pour supprimer l'élément de l'index.
Traiter les éléments non modifiés
L'extrait de code suivant indique comment connaître l'état d'un élément dans la file d'attente d'indexation Cloud Search et comment traiter un élément non modifié.
Pour savoir si un élément a été modifié ou non, vérifiez son état ainsi que les autres métadonnées pouvant signaler une modification. Dans l'exemple, le hachage des métadonnées permet de déterminer si l'élément a été modifié.
Définir les autorisations pour un élément
Votre dépôt s'appuie sur une liste de contrôle d'accès (LCA) pour identifier les utilisateurs ou les groupes ayant accès à un élément. Une LCA est une liste d'ID désignant ces groupes ou ces utilisateurs.
Vous devez dupliquer la LCA utilisée par votre dépôt pour vous assurer que seuls les utilisateurs autorisés à accéder à un élément puissent le voir dans un résultat de recherche. Cette liste doit être incluse lors de l'indexation de l'élément afin que Google Cloud Search dispose des informations nécessaires pour accorder le niveau d'accès qui convient.
Le SDK Content Connector propose un vaste choix de classes et de méthodes pour modéliser les LCA de la plupart des dépôts. Pour chaque élément de votre dépôt, il vous faut analyser la LCA associée et créer une liste correspondante pour Google Cloud Search au moment d'indexer l'élément. Il se peut que la LCA de votre dépôt repose sur des concepts qui compliquent la tâche de modélisation, comme l'héritage de liste. Pour en savoir plus sur les LCA de Google Cloud Search, consultez les informations sur les LCA de Google Cloud Search.
Remarque:L'API Cloud Search Indexing accepte les LCA à domaine unique, mais pas les LCA interdomaines. Utilisez la classe Acl.Builder
pour définir l'accès à chaque élément via une LCA. L'extrait de code suivant, tiré de l'exemple de balayage complet, permet à tous les utilisateurs ou "comptes principaux" (getCustomerPrincipal()
) d'être des "lecteurs" de tous les éléments (.setReaders()
) dans le cadre d'une recherche.
Vous devez savoir comment fonctionnent les LCA afin de les modéliser correctement pour le dépôt. Il se peut que les fichiers à indexer soient stockés dans un système de fichiers basé sur un modèle d'héritage, dans lequel les dossiers enfants héritent des autorisations des dossiers parents. La modélisation du mécanisme d'héritage des LCA nécessite des connaissances supplémentaires. Pour en savoir plus, consultez les informations sur les LCA de Google Cloud Search.
Définir les métadonnées d'un élément
Les métadonnées sont stockées dans un objet Item
. La création d'un objet Item
nécessite un minimum d'informations : un ID de chaîne unique ainsi que le type, la LCA, l'URL et la version de l'élément.
L'extrait de code suivant montre comment créer un objet Item
avec la classe auxiliaire
IndexingItemBuilder
.
Créer un élément indexable
Après avoir défini les métadonnées de l'élément, vous pouvez créer l'élément indexable avec la classe RepositoryDoc.Builder
.
L'exemple suivant vous montre la marche à suivre.
Un RepositoryDoc
est un type d'objet ApiOperation
qui exécute la requête IndexingService.indexItem()
.
Vous pouvez également utiliser la méthode setRequestMode()
de la classe RepositoryDoc.Builder
pour définir le mode de requête d'indexation (ASYNCHRONOUS
ou SYNCHRONOUS
) :
ASYNCHRONOUS
- Le mode asynchrone augmente la latence entre l'indexation et la diffusion des éléments, mais autorise un débit supérieur pour les requêtes d'indexation. Il est recommandé pour l'indexation initiale (le remplissage) de l'ensemble du dépôt.
SYNCHRONOUS
- Le mode synchrone diminue la latence entre l'indexation et la diffusion des éléments, mais autorise un débit moindre. Il est recommandé pour l'indexation des mises à jour et des modifications apportées au dépôt. Si vous n'indiquez pas de mode de requête, la valeur
SYNCHRONOUS
est attribuée par défaut.
Étapes suivantes
Voici quelques étapes que vous pouvez également suivre :
- (Facultatif) Ajoutez la méthode
close()
pour libérer les ressources avant l'arrêt du connecteur. - (Facultatif) Créez un connecteur d'identité à l'aide du SDK Content Connector.
Créer un connecteur de balayage de graphe à l'aide d'un modèle de classe
La file d'attente d'indexation Cloud Search permet de conserver l'ID de chaque élément du dépôt ainsi que la valeur de hachage associée (le cas échéant). Un connecteur de balayage de graphe place les ID d'élément dans la file d'attente d'indexation Google Cloud Search, puis les récupère un par un en vue d'indexer les éléments. Google Cloud Search gère les files d'attente et compare leur contenu afin de déterminer l'état des éléments (si un élément a été supprimé du dépôt, par exemple). Pour en savoir plus sur la file d'attente d'indexation Cloud Search, consultez la section File d'attente d'indexation de Google Cloud Search.
Pendant l'indexation, le contenu des éléments est récupéré dans le dépôt de données et les ID des éléments enfants sont placés dans la file d'attente. Le connecteur procède ainsi de manière récursive avec chaque ID d'élément parent et enfant jusqu'à ce que tous les éléments aient été traités.
Cette section fait référence aux extraits de code de l'exemple GraphTraversalSample.
Implémenter le point d'entrée du connecteur
Le point d'entrée d'un connecteur est la méthode main()
. La fonction principale de cette méthode consiste à créer une instance de la classe Application
et à appeler sa méthode start()
pour exécuter le connecteur.
Avant d'appeler application.start()
, utilisez la classe IndexingApplication.Builder
pour instancier le modèle ListingConnector
. Le modèle ListingConnector
accepte un objet Repository
dont vous utiliserez les méthodes.
L'extrait de code suivant montre comment instancier le modèle ListingConnector
et l'objet Repository
associé:
En arrière-plan, le SDK appelle la méthode initConfig()
, après que la méthode main()
de votre connecteur a appelé Application.build
.
La méthode initConfig()
:
- appelle la méthode
Configuation.isInitialized()
pour confirmer que l'objetConfiguration
n'a pas été initialisé ; - Initialise un objet
Configuration
avec les paires clé-valeur fournies par Google. Chaque paire clé-valeur est stockée dans un objetConfigValue
au sein de l'objetConfiguration
.
Implémenter l'interface Repository
L'objet Repository
n'a qu'une fonction, qui consiste à balayer les éléments du dépôt et à les indexer. Lorsque vous utilisez un modèle, il vous suffit de remplacer certaines méthodes dans l'interface Repository
pour créer un connecteur de contenu. Ces méthodes dépendent de la stratégie de balayage et du modèle employés. Pour le modèle ListingConnector
, par exemple, vous remplacerez les méthodes suivantes:
La méthode
init()
. Pour configurer et initialiser un dépôt de données, remplacez la méthodeinit()
.La méthode
getIds()
. Pour récupérer les ID et les valeurs de hachage de l'ensemble des enregistrements du dépôt, remplacez la méthodegetIds()
.La méthode
getDoc()
. Pour ajouter des éléments à l'index, ou mettre à jour, modifier ou supprimer des éléments spécifiques, remplacez la méthodegetDoc()
.(Facultatif) La méthode
getChanges()
. Si votre dépôt accepte la détection des modifications, remplacez la méthodegetChanges()
. Celle-ci est appelée une fois lors de chaque balayage incrémentiel planifié (tel que défini par votre configuration) afin d'extraire les éléments modifiés et de les indexer.(Facultatif) La méthode
close()
. Si vous devez procéder au nettoyage du dépôt, remplacez la méthodeclose()
. Cette méthode est appelée une fois lors de l'arrêt du connecteur.
Chaque méthode de l'objet Repository
renvoie un objet ApiOperation
. C'est grâce à l'objet ApiOperation
que le dépôt est effectivement indexé, via un ou plusieurs appels de la méthode IndexingService.indexItem()
.
Obtenir les paramètres de configuration personnalisés
Lorsque vous effectuez la configuration de votre connecteur, vous devez récupérer les éventuels paramètres personnalisés contenus dans l'objet Configuration
. Cette tâche est généralement effectuée dans une méthode init()
de la classe Repository
.
La classe Configuration
comprend plusieurs méthodes qui permettent d'obtenir différents types de données à partir d'une configuration. Chaque méthode renvoie un objet ConfigValue
. Pour récupérer la valeur réelle, utilisez ensuite la méthode get()
de l'objet ConfigValue
.
L'extrait de code suivant (issu du modèle FullTraversalSample
)
montre comment récupérer une valeur entière personnalisée à partir d'un objet Configuration
:
Pour récupérer et analyser un paramètre contenant plusieurs valeurs, utilisez l'un des analyseurs de type de la classe Configuration
, qui permettent d'analyser les données par fragments distincts.
L'extrait de code suivant (issu du connecteur du tutoriel) permet d'obtenir la liste des noms de dépôts GitHub grâce à la méthode getMultiValue
:
Effectuer un balayage de graphe
Remplacez la méthode getIds()
pour récupérer les ID et les valeurs de hachage de l'ensemble des enregistrements du dépôt.
La méthode getIds()
accepte un point de contrôle. qui permet de reprendre l'indexation à partir d'un élément donné si le processus est interrompu.
Remplacez ensuite la méthode getDoc()
afin de traiter chaque élément de la file d'attente d'indexation Cloud Search.
Transmettre les ID et valeurs de hachage des éléments
Remplacez getIds()
pour récupérer les ID des éléments et les valeurs de hachage de contenu associées dans le dépôt. Les paires ID/valeur de hachage sont ensuite empaquetées dans une requête de transmission et placées dans la file d'attente d'indexation Cloud Search. Les ID des éléments racines ou parents sont généralement transmis en premier, suivis des ID des éléments enfants, jusqu'à ce que l'arborescence ait été entièrement traitée.
La méthode getIds()
accepte un point de contrôle représentant le dernier élément à indexer. Le point de contrôle permet de reprendre l'indexation à partir d'un élément donné si le processus est interrompu. Pour chaque élément du dépôt, vous accomplirez les tâches suivantes dans la méthode getIds()
:
- Récupérez l'ID et la valeur de hachage associée (le cas échéant) pour chaque élément du dépôt.
- Empaquetez chaque paire ID/valeur de hachage dans un objet
PushItems
. - Combinez chaque objet
PushItems
dans un itérateur renvoyé par la méthodegetIds()
.getIds()
renvoie en fait unCheckpointCloseableIterable
, qui correspond à une itération d'objetsApiOperation
, chaque objet représentant une requête d'API sur un objetRepositoryDoc
(par exemple, une requête de placement des éléments dans la file d'attente).
L'extrait de code suivant montre comment récupérer l'ID et la valeur de hachage de chaque élément, puis insérer ces informations dans un objet PushItems
. Un objet PushItems
correspond à une requête ApiOperation
visant à placer un élément dans la file d'attente d'indexation Cloud Search.
L'extrait de code suivant montre comment utiliser la classe PushItems.Builder
pour empaqueter les ID et les valeurs de hachage dans un seul objet ApiOperation
de transmission.
Les éléments sont placés dans la file d'attente d'indexation Cloud Search en vue d'être traités.
Récupérer et traiter chaque élément
Remplacez la méthode getDoc()
afin de traiter chaque élément de la file d'attente d'indexation Cloud Search.
Un élément peut avoir été ajouté dans le dépôt source, modifié (ou pas) ou bien avoir été supprimé. Récupérez et indexez chaque élément nouveau ou modifié. Retirez de l'index ceux qui n'existent plus dans le dépôt source.
La méthode getDoc()
accepte un élément de la file d'attente d'indexation Cloud Search. Pour chaque élément de la file d'attente, vous accomplirez les tâches suivantes dans la méthode getDoc()
:
Vérifiez si l'élément figure dans le dépôt, d'après son ID dans la file d'attente d'indexation Cloud Search. Si ce n'est pas le cas, supprimez-le de l'index. Si l'élément existe, passez à l'étape suivante.
Pour les éléments d'index nouveaux ou modifiés, procédez comme suit:
- Définissez les autorisations.
- Définissez les métadonnées de l'élément que vous indexez.
- Combinez les métadonnées et l'élément dans un objet
RepositoryDoc
indexable. - Placez les éléments enfants dans la file d'attente d'indexation Cloud Search afin qu'ils soient traités.
- Renvoyez
RepositoryDoc
.
Gérer les éléments supprimés
L'extrait de code suivant indique comment déterminer si un élément figure dans l'index et, s'il ne s'y trouve pas, comment le supprimer.
Définir les autorisations pour un élément
Votre dépôt s'appuie sur une liste de contrôle d'accès (LCA) pour identifier les utilisateurs ou les groupes ayant accès à un élément. Une LCA est une liste d'ID désignant ces groupes ou ces utilisateurs.
Vous devez dupliquer la LCA utilisée par votre dépôt pour vous assurer que seuls les utilisateurs autorisés à accéder à un élément puissent le voir dans un résultat de recherche. Cette liste doit être incluse lors de l'indexation de l'élément afin que Google Cloud Search dispose des informations nécessaires pour accorder le niveau d'accès qui convient.
Le SDK Content Connector propose un vaste choix de classes et de méthodes pour modéliser les LCA de la plupart des dépôts. Pour chaque élément de votre dépôt, il vous faut analyser la LCA associée et créer une liste correspondante pour Google Cloud Search au moment d'indexer l'élément. Il se peut que la LCA de votre dépôt repose sur des concepts qui compliquent la tâche de modélisation, comme l'héritage de liste. Pour en savoir plus sur les LCA de Google Cloud Search, consultez les informations sur les LCA de Google Cloud Search.
Remarque:L'API Cloud Search Indexing accepte les LCA à domaine unique, mais pas les LCA interdomaines. Utilisez la classe Acl.Builder
pour définir l'accès à chaque élément via une LCA. L'extrait de code suivant, tiré de l'exemple de balayage complet, permet à tous les utilisateurs ou "comptes principaux" (getCustomerPrincipal()
) d'être des "lecteurs" de tous les éléments (.setReaders()
) dans le cadre d'une recherche.
Vous devez savoir comment fonctionnent les LCA afin de les modéliser correctement pour le dépôt. Il se peut que les fichiers à indexer soient stockés dans un système de fichiers basé sur un modèle d'héritage, dans lequel les dossiers enfants héritent des autorisations des dossiers parents. La modélisation du mécanisme d'héritage des LCA nécessite des connaissances supplémentaires. Pour en savoir plus, consultez les informations sur les LCA de Google Cloud Search.
Définir les métadonnées d'un élément
Les métadonnées sont stockées dans un objet Item
. La création d'un objet Item
nécessite un minimum d'informations : un ID de chaîne unique ainsi que le type, la LCA, l'URL et la version de l'élément.
L'extrait de code suivant montre comment créer un objet Item
avec la classe auxiliaire
IndexingItemBuilder
.
Créer l'élément indexable
Après avoir défini les métadonnées de l'élément, vous pouvez créer l'élément indexable avec la classe RepositoryDoc.Builder
.
L'exemple suivant vous montre la marche à suivre.
Un RepositoryDoc
est un type d'objet ApiOperation
qui exécute la requête IndexingService.indexItem()
.
Vous pouvez également utiliser la méthode setRequestMode()
de la classe RepositoryDoc.Builder
pour définir le mode de requête d'indexation (ASYNCHRONOUS
ou SYNCHRONOUS
) :
ASYNCHRONOUS
- Le mode asynchrone augmente la latence entre l'indexation et la diffusion des éléments, mais autorise un débit supérieur pour les requêtes d'indexation. Il est recommandé pour l'indexation initiale (le remplissage) de l'ensemble du dépôt.
SYNCHRONOUS
- Le mode synchrone diminue la latence entre l'indexation et la diffusion des éléments, mais autorise un débit moindre. Il est recommandé pour l'indexation des mises à jour et des modifications apportées au dépôt. Si vous n'indiquez pas de mode de requête, la valeur
SYNCHRONOUS
est attribuée par défaut.
Placer les ID des éléments enfants dans la file d'attente d'indexation Cloud Search
L'extrait de code suivant montre comment placer dans la file d'attente les ID des éléments enfants de l'élément parent en cours de traitement. Ces éléments seront traités après que l'élément parent a été indexé.
Étapes suivantes
Voici quelques étapes que vous pouvez également suivre :
- (Facultatif) Ajoutez la méthode
close()
pour libérer les ressources avant l'arrêt du connecteur. - (Facultatif) Créez un connecteur d'identité à l'aide du SDK Identity Connector.
Créer un connecteur de contenu à l'aide de l'API REST
Les sections suivantes expliquent comment créer un connecteur de contenu à l'aide de l'API REST.
Déterminer votre stratégie de balayage
La fonction principale d'un connecteur de contenu consiste à balayer un dépôt et à en indexer les données. Vous devez mettre en place une stratégie de balayage adaptée à la taille des données et à leur disposition dans votre dépôt. Voici trois stratégies de balayage couramment employées:
- Stratégie de balayage complet
La stratégie de balayage complet consiste à analyser le dépôt entier et à en indexer automatiquement chaque élément. Cette stratégie est couramment employée avec les dépôts de petite taille, lorsque l'entreprise peut se permettre cette opération à chaque indexation.
Cette stratégie de balayage est indiquée pour les dépôts de petite taille, renfermant principalement des données statiques non hiérarchisées. Elle convient également lorsque la détection des modifications est complexe ou incompatible avec le dépôt.
- Stratégie de balayage de liste
La stratégie de balayage de liste consiste à analyser le dépôt entier, y compris les nœuds enfants, tout en déterminant l'état de chaque élément. Puis, lors d'une seconde passe, le connecteur n'indexe que les éléments nouveaux ou mis à jour depuis la dernière indexation. Cette stratégie est couramment utilisée pour actualiser progressivement un index existant (et éviter ainsi un balayage complet à chaque mise à jour de l'index).
Cette stratégie de balayage convient dans les situations suivantes : la détection des modifications est complexe ou incompatible avec le dépôt, les données ne sont pas hiérarchisées ou vous travaillez avec des ensembles de données très volumineux.
- Balayage de graphe
La stratégie de balayage de graphe consiste à analyser l'intégralité du nœud parent en déterminant l'état de chaque élément. Puis, lors d'une seconde passe, le connecteur n'indexe que les éléments du nœud racine qui sont nouveaux ou ont été mis à jour depuis la dernière indexation. Il traite enfin les ID des éléments enfants, puis indexe les éléments nouveaux ou mis à jour au niveau de ces nœuds. Il procède ainsi de manière récursive avec chaque nœud enfant jusqu'à ce que tous les éléments aient été traités. Cette stratégie de balayage est généralement retenue avec les dépôts hiérarchiques pour lesquels il est difficile d'établir une liste exhaustive des ID.
Cette stratégie convient pour explorer des données hiérarchisées, comme une série de répertoires ou de pages Web.
Déployer votre stratégie de balayage et vos éléments d'index
Chaque élément indexable destiné à Cloud Search est appelé élément dans l'API Cloud Search. Il peut s'agir d'un fichier, d'un dossier, d'une ligne dans un fichier CSV ou d'un enregistrement de base de données.
Une fois le schéma enregistré, vous pouvez remplir l'index à l'aide de l'une des méthodes suivantes:
(Facultatif) Utilisation de
items.upload
pour importer des fichiers de plus de 100 KiB à indexer. Pour les fichiers plus petits, intégrez le contenu en tant que inlineContent avecitems.index
.(Facultatif) Utilisation de
media.upload
pour importer des fichiers multimédias à indexer.Utilisation de
items.index
pour indexer l'élément. Par exemple, si votre schéma utilise la définition d'objet dans le schéma de film, une requête d'indexation pour un seul élément se présente comme suit:{ "name": "datasource/<data_source_id>/items/titanic", "acl": { "readers": [ { "gsuitePrincipal": { "gsuiteDomain": true } } ] }, "metadata": { "title": "Titanic", "viewUrl": "http://www.imdb.com/title/tt2234155/?ref_=nv_sr_1", "objectType": "movie" }, "structuredData": { "object": { "properties": [ { "name": "movieTitle", "textValues": { "values": [ "Titanic" ] } }, { "name": "releaseDate", "dateValues": { "values": [ { "year": 1997, "month": 12, "day": 19 } ] } }, { "name": "actorName", "textValues": { "values": [ "Leonardo DiCaprio", "Kate Winslet", "Billy Zane" ] } }, { "name": "genre", "enumValues": { "values": [ "Drama", "Action" ] } }, { "name": "userRating", "integerValues": { "values": [ 8 ] } }, { "name": "mpaaRating", "textValues": { "values": [ "PG-13" ] } }, { "name": "duration", "textValues": { "values": [ "3 h 14 min" ] } } ] } }, "content": { "inlineContent": "A seventeen-year-old aristocrat falls in love with a kind but poor artist aboard the luxurious, ill-fated R.M.S. Titanic.", "contentFormat": "TEXT" }, "version": "01", "itemType": "CONTENT_ITEM" }
(Facultatif) Utilisation des appels items.get pour vérifier qu'un élément a été indexé.
Avec une stratégie de balayage complet, vous devez régulièrement réindexer tout le dépôt. Dans le cas d'un balayage de liste ou de graphe, du code doit être ajouté pour pouvoir gérer les modifications du dépôt.
Gérer les modifications du dépôt
Vous pouvez rassembler et indexer régulièrement les différents éléments d'un dépôt afin de procéder à une indexation complète. Votre index sera certes toujours à jour, mais cette technique peut s'avérer coûteuse avec des dépôts plus grands ou hiérarchisés.
Au lieu de multiplier les appels d'index pour indexer un dépôt entier, vous pouvez vous servir de la file d'attente d'indexation Google Cloud Search. Cette file d'attente permet d'effectuer le suivi des modifications des éléments et d'indexer uniquement ceux qui ont changé. Vous pouvez utiliser les requêtes items.push pour placer des éléments dans la file d'attente. Vous pourrez interroger et mettre à jour ces éléments plus tard. Pour en savoir plus sur la file d'attente d'indexation Google Cloud, consultez la section File d'attente d'indexation Google Cloud.
Pour en savoir plus sur l'API Google Cloud Search, consultez la section API Cloud Search.