Gérer les champs utilisateur personnalisés

Vous pouvez définir des champs personnalisés pour les utilisateurs de votre domaine en ajoutant des schémas utilisateur personnalisés au domaine. Vous pouvez utiliser ces champs pour stocker des informations telles que les projets sur lesquels travaillent vos utilisateurs, leur lieu de résidence, leur date d'embauche ou tout autre élément adapté à vos besoins métier.

Pour commencer, créez un ou plusieurs schémas afin de définir les champs personnalisés qui ont du sens pour votre domaine. Vous pouvez spécifier un certain nombre d'attributs, tels que le nom du champ, le type (chaîne, booléen, entier, etc.), s'il est à valeur unique ou multiple, et si ses valeurs sont visibles par tous les utilisateurs de votre domaine ou uniquement par les administrateurs et l'utilisateur associé.

Une fois un schéma défini, les champs personnalisés se comportent comme des champs standards. Vous pouvez les définir lorsque vous modifiez les utilisateurs de votre domaine, les récupérer avec users.get et users.list, et également rechercher des champs personnalisés.

Définir des champs personnalisés dans un profil utilisateur

Pour mettre à jour ou créer un schéma, créez une propriété customSchemas et ajoutez-la à la ressource utilisateur. Dans la propriété customSchemas, les champs personnalisés sont regroupés par schéma au format JSON standard:

"customSchemas": {
  "schema1": {
    "field1": "value1",
    "field2": [
      { "value": "value2a" },
      { "value": "value2b" },
      ...
    ],
    ...
  },
  "schema2": {
    "field3": "value3",
    ...
  },
  ...
}

Les champs personnalisés à valeur unique sont définis sous forme de paires clé-valeur simples, comme "field1": "value1". Les champs personnalisés à valeurs multiples sont définis en tant que tableaux d'objets, comme les champs à valeurs multiples standards de l'API, tels que addresses et phones. Ces objets de valeur acceptent les clés suivantes:

Clés
value Valeur à stocker (obligatoire).
type Type de la valeur (facultatif). Les valeurs possibles du champ sont les suivantes :
  • custom
  • home
  • other
  • work
customType Type personnalisé de la valeur (facultatif). Doit être utilisé lorsque type est défini sur custom.

Si un champ personnalisé d'un schéma n'est pas spécifié au moment de la mise à jour, il reste inchangé. Si un schéma lui-même n'est pas spécifié dans customFields au moment de la mise à jour, tous les champs personnalisés de ce schéma restent inchangés. Pour supprimer un champ ou un schéma personnalisé d'un profil, vous devez le définir explicitement sur null:

"schema1": {
  "field1": null // deletes field1 from this profile.
}

Requête JSON

L'appel de l'exemple ci-dessous met à jour un utilisateur et définit des valeurs pour le schéma personnalisé employmentData:

PATCH https://admin.googleapis.com/admin/directory/v1/users/liz@example.com

{
  "customSchemas": {
    "employmentData": {
      "employeeNumber": "123456789",
      "jobFamily": "Engineering"
      "location": "Atlanta",
      "jobLevel": 8,
      "projects": [
        { "value": "GeneGnome" },
        { "value": "Panopticon", "type": "work" },
        { "value": "MegaGene", "type": "custom", "customType": "secret" }
      ]
    }
  }
}

Lire les champs personnalisés d'un profil utilisateur

Vous pouvez extraire des champs personnalisés dans un profil utilisateur en définissant le paramètre projection dans une requête users.get ou users.list sur custom ou full.

Rechercher des champs personnalisés dans un profil utilisateur

Vous pouvez effectuer une recherche dans des champs personnalisés à l'aide du paramètre query dans une requête users.list. Vous demandez le champ personnalisé avec une syntaxe schemaName.fieldName. Exemple :

employmentData.projects:"GeneGnome"

renvoie tous les employés qui travaillent sur le projet GeneGnome. La requête

employmentData.location="Atlanta" employmentData.jobLevel>=7

renvoie tous les employés d'Atlanta dont le niveau d'emploi est supérieur à 7. Pour en savoir plus, consultez la section Rechercher des utilisateurs.

Créer un schéma d'utilisateur personnalisé

Vous pouvez ajouter un schéma utilisateur personnalisé à tous les domaines de votre compte Google Workspace. Pour créer un schéma utilisateur personnalisé dans vos domaines, utilisez la requête POST suivante et incluez l'autorisation décrite dans la section Autoriser les requêtes. Pour en savoir plus sur les propriétés de la chaîne de requête de la requête, consultez la documentation de référence de l'API.

POST https://admin.googleapis.com/admin/directory/v1/customer/my_customer or customerId/schemas

Toutes les demandes de création vous obligent à fournir les informations nécessaires pour les traiter. Si vous utilisez des bibliothèques clientes, elles convertissent les objets de données de la langue de votre choix en objets au format de données JSON.

Requête JSON

L'exemple suivant montre une requête visant à créer un schéma personnalisé. Pour obtenir la liste complète des propriétés de requête et de réponse, consultez la documentation de référence de l'API.

{
  "schemaName": "employmentData",
  "fields": [
    {
      "fieldName": "EmployeeNumber",
      "fieldType": "STRING",
      "multiValued": "false"
    },
    {
      "fieldName": "JobFamily",
      "fieldType": "STRING",
      "multiValued": "false"
    }
  ]
}

Une réponse réussie renvoie un code d'état HTTP 201, ainsi que les propriétés du nouveau schéma personnalisé.

Limites des schémas personnalisés

  • Le nombre maximal de schémas personnalisés autorisés dans un compte est de 100.
  • Le nombre maximal de champs personnalisés autorisés dans un compte est de 100.
  • Le nombre maximal de caractères autorisés dans un champ string pour un champ personnalisé à valeur unique est de 500. Pour les champs personnalisés à valeurs multiples, le nombre d'éléments autorisés dépend de la taille des valeurs attribuées. Par exemple, vous pouvez ajouter 150 valeurs de 100 caractères chacune ou 50 valeurs de 500 caractères chacune.
  • Les caractères autorisés dans les schémas et les noms de champs personnalisés sont les caractères alphanumériques, les traits de soulignement (_) et les traits d'union (-).
  • Vous ne pouvez pas modifier le type d'un champ.
  • Un champ à valeur unique peut être rendu multivalué, mais l'opération inverse n'est pas autorisée.
  • Il n'est pas possible de renommer des schémas ou des champs personnalisés.

Mettre à jour un schéma utilisateur personnalisé

Pour mettre à jour un schéma personnalisé, utilisez la requête PUT suivante et incluez l'autorisation décrite dans la section Autoriser les requêtes. schemaKey peut être le nom du schéma ou le schéma unique id. Pour en savoir plus sur les propriétés de requête et de réponse, consultez la documentation de référence de l'API.

PUT https://admin.googleapis.com/admin/directory/v1/customer/my_customer or customerId/schemas/schemaKey

Requête JSON

Dans l'exemple ci-dessous, le schéma employmentData contenait un champ JobFamily lors de sa création initiale. La requête met à jour employmentData pour qu'il ne contienne qu'un champ EmployeeNumber:

PUT https://admin.googleapis.com/admin/directory/v1/customer/my_customer/schemas/employmentData
{
  "kind": "admin#directory#schema",
  "schemaId": "dKaYmUwmSZy5lreXyh75hQ==",
  "etag": "\"St7vIdePbbDsQUvvrssynd-6JLg/PKg63GvWb7bnVSNRomd_O-Vi66w\"",
  "schemaName": "employmentData",
  "fields": [
    {
      "kind": "admin#directory#schema#fieldspec",
      "fieldId": "21_B4iQIRY-dIFGFgAX-Og==",
      "etag": "\"St7vIdePbbDsQUvvrssynd-6JLg/LZxiGaz6_N4R40OpKbDhOcy2qiE\"",
      "fieldType": "STRING",
      "fieldName": "EmployeeNumber",
      "multiValued": "false"
    }
  ]
}

Pour toutes les demandes de mise à jour, vous devez fournir les informations nécessaires pour les traiter.

Une réponse réussie renvoie un code d'état HTTP 200, ainsi que la ressource de schéma mise à jour.

Récupérer un schéma d'utilisateur personnalisé

Pour récupérer un schéma personnalisé, utilisez la requête GET suivante et incluez l'autorisation décrite dans la section Autoriser les requêtes. schemaKey peut être le nom du schéma ou le schéma unique id. Pour en savoir plus sur les propriétés de requête et de réponse, consultez la documentation de référence de l'API.

GET https://admin.googleapis.com/admin/directory/v1/customer/my_customer or customerId/schemas/schemaKey

Une réponse réussie renvoie un code d'état HTTP 200, ainsi que les propriétés du schéma personnalisé.

{
  "kind": "admin#directory#schema",
  "schemaId": "dKaYmUwmSZy5lreXyh75hQ==",
  "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/PKg63GvWb7bnVSNRomd_O-Vi66w\"",
  "schemaName": "employmentData",
  "fields": [
    {
      "kind": "admin#directory#schema#fieldspec",
      "fieldId": "21_B4iQIRY-dIFGFgAX-Og==",
      "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/LZxiGaz6_N4R40OpKbDhOcy2qiE\"",
      "fieldType": "STRING",
      "fieldName": "EmployeeNumber"
    },
    {
      "kind": "admin#directory#schema#fieldspec",
      "fieldId": "ZKy0QtoMRy2QlM-4sAsPtQ==",
      "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/jEULI-ZiqywQIHXgc8evEcTE4Cc\"",
      "fieldType": "STRING",
      "fieldName": "JobFamily"
    }
  ]
}

Récupérez tous les schémas utilisateur personnalisés.

Pour récupérer tous les schémas personnalisés d'un même compte, utilisez la requête GET suivante et incluez l'autorisation décrite dans la section Autoriser les requêtes.Pour en savoir plus sur les propriétés de requête et de réponse, consultez la documentation de référence de l'API.

GET https://admin.googleapis.com/admin/directory/v1/customer/my_customer or customerId/schemas

Une réponse réussie renvoie un code d'état HTTP 200, ainsi que les schémas personnalisés du compte.

{
  "kind": "admin#directory#schemas",
  "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/iJ1eWn5AKuR-xTdwH_2IBlvSSKo\"",
  "schemas": [
    {
      "kind": "admin#directory#schema",
      "schemaId": "dKaYmUwmSZy5lreXyh75hQ==",
      "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/PKg63GvWb7bnVSNRomd_O-Vi66w\"",
      "schemaName": "employmentData",
      "fields": [
        {
          "kind": "admin#directory#schema#fieldspec",
          "fieldId": "21_B4iQIRY-dIFGFgAX-Og==",
          "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/LZxiGaz6_N4R40OpKbDhOcy2qiE\"",
          "fieldType": "STRING",
          "fieldName": "EmployeeNumber"
        },
        {
          "kind": "admin#directory#schema#fieldspec",
          "fieldId": "ZKy0QtoMRy2QlM-4sAsPtQ==",
          "etag": "\"KYnPjBPqr8knK6v7rpxly9BhNeY/jEULI-ZiqywQIHXgc8evEcTE4Cc\"",
          "fieldType": "STRING",
          "fieldName": "JobFamily"
        }
      ]
    }
  ]
}