Ce guide décrit la structure commune de tous les appels d'API.
Si vous utilisez une bibliothèque cliente pour interagir avec l'API, vous n'aurez pas besoin de connaître les détails de la requête sous-jacente. Toutefois, certaines connaissances sur la structure des appels d'API peuvent s'avérer utiles lors des tests et du débogage.
L'API Google Ads est une API gRPC avec des liaisons REST. Cela signifie qu'il existe deux façons d'appeler l'API.
Préféré :
Créez le corps de la requête en tant que tampon de protocole.
Envoyez-le au serveur à l'aide de HTTP/2.
Désérialisez la réponse dans un tampon de protocole.
Interprétez les résultats.
La plupart de notre documentation décrit l'utilisation de gRPC.
Facultatif :
Créez le corps de la requête en tant qu'objet JSON.
Envoyez-le au serveur à l'aide du protocole HTTP 1.1.
Désérialisez la réponse en tant qu'objet JSON.
Interprétez les résultats.
Pour en savoir plus sur l'utilisation de REST, consultez le guide de l'interface REST.
Noms de ressources
La plupart des objets de l'API sont identifiés par leur chaîne de nom de ressource. Ces chaînes servent également d'URL lorsque vous utilisez l'interface REST. Consultez la section Noms de ressources de l'interface REST pour connaître leur structure.
ID composites
Si l'ID d'un objet n'est pas unique au niveau mondial, un ID composite est créé pour cet objet en ajoutant l'ID de son parent et un tilde (~).
Par exemple, comme l'ID d'annonce d'un groupe d'annonces n'est pas unique au niveau mondial, nous lui ajoutons l'ID de son objet parent (groupe d'annonces) pour créer un ID composite unique :
AdGroupIdde123+~+AdGroupAdIdde45678= ID de l'annonce composite du groupe d'annonces123~45678.
En-têtes de requête
Voici les en-têtes HTTP (ou métadonnées gRPC) qui accompagnent le corps de la requête :
Autorisation
Vous devez inclure un jeton d'accès OAuth2 au format Authorization: Bearer
YOUR_ACCESS_TOKEN qui identifie un compte administrateur agissant au nom d'un client ou un annonceur gérant directement son propre compte. Pour savoir comment récupérer un jeton d'accès, consultez le guide OAuth2. Un jeton d'accès est valide pendant une heure après son obtention. Lorsqu'il expire, actualisez-le pour en récupérer un nouveau.
Notez que nos bibliothèques clientes actualisent automatiquement les jetons expirés.
Si vous rencontrez des erreurs d'autorisation, assurez-vous d'utiliser les identifiants appropriés et de disposer des autorisations suffisantes. Une erreur USER_PERMISSION_DENIED indique que l'utilisateur authentifié n'a peut-être pas accès au compte client spécifié dans la requête. Pour en savoir plus sur la gestion des autorisations, consultez Niveaux d'accès Google Ads.
developer-token
Un jeton de développeur est une chaîne de 22 caractères qui identifie de manière unique un développeur de l'API Google Ads. Voici un exemple de chaîne de jeton de développeur : ABcdeFGH93KL-NOPQ_STUv. Le jeton de développeur doit être inclus au format developer-token :
ABcdeFGH93KL-NOPQ_STUv.
login-customer-id
Il s'agit de l'ID client du client autorisé à utiliser dans la requête, sans tirets (-). Si vous accédez au compte client via un compte administrateur, cet en-tête est obligatoire et doit être défini sur l'ID client du compte administrateur. Si vous n'incluez pas login-customer-id lorsque vous vous authentifiez via un compte administrateur, une erreur AuthorizationError.USER_PERMISSION_DENIED se produit. Pour en savoir plus sur ce type d'erreur, consultez Erreurs fréquentes.
https://googleads.googleapis.com/v24/customers/1234567890/campaignBudgets:mutate
Définir le login-customer-id équivaut à choisir un compte dans l'UI Google Ads après vous être connecté ou avoir cliqué sur votre image de profil en haut à droite. Si vous n'incluez pas cet en-tête, la valeur par défaut est operating_customer.
linked-customer-id
Cet en-tête est obligatoire et utilisé par les partenaires (tels que les fournisseurs d'analyses d'applications tierces ou les partenaires de données) lorsqu'ils agissent sur un compte Google Ads associé. Cet en-tête doit spécifier le numéro client du compte Google Ads qui contient le lien vers le produit.
Prenons l'exemple d'un partenaire qui doit effectuer des appels d'API vers un compte Google Ads en fonction d'un lien vers un produit.
- Annonceur : compte Google Ads géré ou mis à jour par l'appel d'API. L'ID du compte annonceur est spécifié dans la demande. Dans REST, il s'agit du paramètre de chemin d'accès
customerId(par exemple,customers/1111111111/...), et dans gRPC, il s'agit du champcustomer_iddans la requête. - Partenaire : compte partenaire (par exemple, un fournisseur tiers d'analyse des applications ou un partenaire pour les données).
- Compte associé : compte Google Ads qui a établi une association de produits avec le partenaire, lui accordant l'accès à l'annonceur.
Un utilisateur ayant accès à Partner effectue des appels d'API pour agir sur des entités dans Advertiser (par exemple, pour importer des conversions ou gérer des listes d'utilisateurs). Le compte associé peut être l'annonceur lui-même ou un compte administrateur de l'annonceur.
Les en-têtes de requête doivent être définis comme suit :
Authorization: jeton OAuth2 pour un utilisateur ayant accès à Partner.developer-token: jeton de développeur pour l'application API, généralement associé à un partenaire.login-customer-id: ID client du partenaire. L'utilisateur authentifié doit avoir accès à ce compte.linked-customer-id: ID client du compte associé. Cet en-tête indique que l'autorisation de cette requête repose sur l'association de produit du compte associé avec le partenaire.
Il existe deux scénarios d'association :
- Si l'Annonceur dispose d'un lien direct vers un produit avec le Partenaire, le compte associé est l'Annonceur et
linked-customer-iddoit être défini sur l'ID client de l'Annonceur. - Si l'annonceur est géré par un compte administrateur associé à un produit avec un partenaire, le compte associé est le compte administrateur et
linked-customer-iddoit être défini sur l'ID client de l'administrateur.
Exemple 1 : Lien direct
Si l'annonceur 1111111111 est directement associé au partenaire 2222222222 et que l'appel d'API cible customers/1111111111/... :
Authorization: Bearer YOUR_ACCESS_TOKEN
developer-token: YOUR_DEVELOPER_TOKEN
login-customer-id: 2222222222
linked-customer-id: 1111111111
Exemple 2 : Lien administrateur
Si l'annonceur 1111111111 est géré par le compte administrateur 3333333333, que le compte administrateur 3333333333 est associé au partenaire 2222222222 et que l'appel d'API cible customers/1111111111/... :
Authorization: Bearer YOUR_ACCESS_TOKEN
developer-token: YOUR_DEVELOPER_TOKEN
login-customer-id: 2222222222
linked-customer-id: 3333333333
En-têtes de réponse
Les en-têtes suivants (ou grpc-trailing-metadata) sont renvoyés avec le corps de la réponse. Nous vous recommandons de consigner ces valeurs à des fins de débogage.
request-id
request-id est une chaîne qui identifie de manière unique cette requête.