Chaque projet Apps Script utilise Google Cloud pour gérer l'autorisation, les services avancés et d'autres détails. Pour configurer et gérer ces paramètres, chaque projet Apps Script est associé à un projet Google Cloud. Votre projet de script peut utiliser un projet par défaut créé automatiquement par Apps Script ou un projet standard que vous créez vous-même. En règle générale, les projets par défaut sont adaptés aux scripts quotidiens ou simples, mais vous devez utiliser un projet standard pour toute application complexe, de qualité commerciale ou que vous prévoyez de publier.
Vous pouvez passer d'un projet par défaut à un projet standard à tout moment, mais vous ne pouvez pas revenir à un projet par défaut. Il est préférable de sélectionner le projet Cloud utilisé par votre script au début du développement. Passer à un autre système plus tard peut entraîner des complications, par exemple en obligeant vos utilisateurs à réautoriser l'application.
Projets Cloud par défaut
Lorsque vous créez un projet Apps Script, Apps Script crée un projet Cloud par défaut qui s'exécute en arrière-plan.
- Pour la plupart des scripts, vous n'avez jamais besoin d'afficher ni d'ajuster ce projet par défaut. Apps Script gère les interactions nécessaires avec Google Cloud. Par exemple, si vous activez un service avancé dans l'éditeur Apps Script, Apps Script active le service avancé dans le projet Cloud par défaut lorsque vous enregistrez le projet de script.
- Pour certains scripts, vous devez interagir avec la console Google Cloud. Dans ce cas, votre script doit utiliser un projet Cloud standard. Par exemple, pour afficher les journaux Google Cloud dans la console Google Cloud, votre script doit utiliser un projet standard.
Par défaut, les projets Cloud disposent d'une stratégie IAM (Identity and Access Management) avec une seule entrée, un compte de service Google qui agit en tant que propriétaire du projet par défaut. Le compte de service Google est appsdev-apps-dev-script-auth@system.gserviceaccount.com
.
Afficher ou mettre à jour les projets Cloud par défaut
La plupart des utilisateurs ne peuvent pas localiser, afficher ni modifier directement les projets par défaut dans la console Google Cloud. Si vous êtes administrateur, consultez Afficher les projets Google Cloud par défaut.
Si vous avez créé votre projet de script avant le 8 avril 2019, vous pouvez utiliser un projet par défaut auquel vous pouvez accéder dans la console Google Cloud. Pour accéder au projet par défaut, accédez aux paramètres du projet de script, puis cliquez sur le numéro du projet.
Supprimer les projets Cloud par défaut
Si vous êtes administrateur, vous pouvez supprimer les projets Cloud par défaut comme vous le feriez pour les projets Cloud standards. Consultez Supprimer des projets Cloud Apps Script.
Si vous n'êtes pas administrateur, vous ne pouvez pas supprimer les projets par défaut. Toutefois, Apps Script supprime les projets par défaut dans les cas suivants:
- Si vous supprimez le projet de script ou que vous passez à un projet standard, Apps Script supprime le projet par défaut associé au script, ainsi que tous les paramètres ou informations qu'il contient.
- Si un script ne s'exécute pas pendant 180 jours ou plus, Apps Script supprime le projet par défaut associé. Si le script s'exécute après la suppression de son projet par défaut par Apps Script, Apps Script en crée un pour le script.
Projets Cloud standards
Les projets Cloud par défaut sont la meilleure option pour la plupart des projets de script, sauf si vous devez configurer le projet manuellement. Dans ce cas, vous devez passer à un projet standard.
Les sections suivantes décrivent les cas où Apps Script nécessite un projet standard, les propriétés de ces projets et les tâches courantes qui y sont associées. Vous ne pouvez effectuer les tâches ci-dessous qu'avec des projets standards.
Lorsque Apps Script nécessite des projets Cloud standards
Vous devez utiliser un projet standard dans les cas suivants:
- Pour publier votre projet de script en tant que module complémentaire dans Google Workspace Marketplace.
- Pour valider le client OAuth de votre projet de script
- Lorsque vous avez une application qui doit exécuter des fonctions dans votre projet de script à l'aide de la méthode
scripts.run
de l'API Apps Script. - Pour afficher les journaux Google Cloud de votre projet de script dans la console Google Cloud. La console Google Cloud fournit davantage d'outils pour filtrer et afficher les journaux, et peut être plus utile que la vue simplifiée fournie par le tableau de bord Apps Script.
- Pour afficher les rapports d'erreur de votre projet de script à l'aide d'Error Reporting.
- Pour créer une boîte de dialogue d'ouverture de fichier.
- Lorsque vous avez besoin de contrôler manuellement les paramètres Google Cloud du projet.
Propriétés de projet Cloud standards
Les projets standards présentent les propriétés suivantes:
- Vous pouvez accéder à tous les paramètres Google Cloud du projet directement depuis la console Google Cloud. Vous pouvez ainsi activer des API, ajuster les identifiants d'autorisation et configurer d'autres informations.
- Lorsque vous supprimez un projet de script ou que vous passez à un autre projet standard, le projet standard d'origine reste et peut être réutilisé.
- Lorsque vous activez un service avancé dans un projet de script, vous devez activer manuellement l'API correspondante dans le projet standard.
- Plusieurs projets de script et d'autres applications peuvent partager le même projet standard. Si vous souhaitez publier un projet de script sur Google Workspace Marketplace en tant que module complémentaire, il doit disposer de son propre projet standard. Les applications publiées ne peuvent pas partager de projets Cloud avec d'autres applications.
- Si vous souhaitez exécuter des fonctions dans un projet de script à partir d'une autre application à l'aide de la méthode
scripts.run
de l'API Apps Script, le projet de script et l'application appelante doivent partager le même projet standard. - Lorsque Apps Script demande à un utilisateur d'autoriser un script qui utilise un projet standard, le nom du projet Cloud est utilisé pour identifier le script (et non le nom du projet du script). Pour cette raison, veillez à définir un nom de projet Cloud approprié.
Accéder à un projet Cloud standard
Pour accéder au projet standard associé à votre projet de script, procédez comme suit:
- Ouvrez le projet Apps Script.
- Sur la gauche, cliquez sur Paramètres du projet .
- Sous Projet Google Cloud Platform (GCP), cliquez sur le numéro de projet.
Vous pouvez également trouver un projet standard directement sur la page Gérer les ressources de la console Google Cloud.
Activer une API dans un projet Cloud standard
Une application Apps Script a souvent besoin d'accéder à une autre API Google. Pour ce faire, vous devez activer l'API dans le projet Cloud correspondant. Pour activer une API, procédez comme suit:
- Ouvrez le projet Cloud.
- Cliquez sur Menu > API et services.
- Cliquez sur Activer les API et les services.
- Dans le champ de recherche, saisissez l'API que vous souhaitez activer, puis appuyez sur Entrée.
- Cliquez sur l'API dans les résultats de recherche, puis sur Enable (Activer) pour activer l'API pour ce projet Cloud.
Vous serez peut-être invité à accepter les conditions d'utilisation des API Google ou de Google Cloud. Lisez attentivement les conditions d'utilisation avant de les accepter.
Selon l'application, vous devrez peut-être également configurer l'API en la sélectionnant dans le tableau de bord API et services.
Déterminer l'ID et le numéro d'un projet Cloud standard
Tous les projets Cloud ont un nom, un ID et un numéro. Vous devez parfois disposer de ces identifiants pour configurer des services ou effectuer d'autres tâches.
Pour déterminer l'ID et le numéro de votre projet standard, procédez comme suit:
- Ouvrez le projet Cloud.
- En haut à droite, cliquez sur Plus > Paramètres du projet.
- Consultez le nom du projet, l'ID du projet et le numéro de projet dans le panneau Paramètres qui s'affiche. Le numéro de projet ne contient que des chiffres, tandis que l'ID de projet est alphanumérique. Vous pouvez modifier le nom du projet, qui s'affiche pour les utilisateurs lors des invites d'autorisation.
Afficher les journaux et les rapports d'erreur Google Cloud dans la console Google Cloud
Si vous utilisez la journalisation Google Cloud ou Error Reporting pour votre projet de script, vous pouvez afficher ces journaux et rapports dans la console Google Cloud en procédant comme suit:
- Ouvrez le projet Cloud.
- Cliquez sur Menu .
- Faites défiler la page jusqu'à la section Opérations, puis cliquez sur Journalisation > Explorateur de journaux.
- Pour afficher les rapports d'erreur, faites défiler la page jusqu'à la section Opérations, puis cliquez sur Signalement d'erreurs. Si vous êtes invité à configurer le signalement des erreurs, cela signifie que votre projet de script n'a encore enregistré aucune exception.
Compléter l'écran de consentement OAuth
Lorsque vous utilisez des services qui nécessitent OAuth, Google invite les utilisateurs à les autoriser. Les paramètres de l'écran de consentement OAuth vous permettent de définir certaines des informations que Google présente aux utilisateurs, comme le nom de l'application et l'URL des conditions d'utilisation.
Les projets Cloud par défaut créent automatiquement un écran de consentement à partir des informations du projet Apps Script. Vous ne pouvez pas ajuster ces paramètres. Les projets Cloud standards vous permettent de personnaliser ces informations. Vous pouvez configurer l'écran de consentement de votre script en procédant comme suit:
- Ouvrez le projet Cloud.
- Cliquez sur Menu > API et services > Identifiants.
- Cliquez sur Configurer l'écran d'autorisation.
- Remplissez chaque section du workflow de l'écran d'autorisation.
- Pour enregistrer vos modifications à chaque étape du workflow, cliquez sur Enregistrer et continuer.
Créer des identifiants OAuth
Apps Script configure généralement OAuth pour les services utilisés par votre script. Pour certaines applications, vous devez créer des identifiants OAuth supplémentaires (ID client et secrets client). Vous ne pouvez effectuer cette opération qu'avec des projets standards.
Pour créer un ID client et un code secret client pour votre projet de script, procédez comme suit:
- Ouvrez le projet Cloud.
- Cliquez sur Menu > API et services > Identifiants.
- Cliquez sur Créer des identifiants > ID client OAuth.
- Sous Type d'application, sélectionnez votre type d'application et remplissez le formulaire qui s'affiche si nécessaire. Lorsque vous avez terminé, cliquez sur Créer.
- Dans la boîte de dialogue qui s'affiche, cliquez sur Télécharger JSON. Vous pouvez utiliser ce fichier pour configurer OAuth.
Ajouter des propriétaires supplémentaires à un projet Cloud standard
Vous pouvez ajouter des propriétaires ou d'autres rôles à un projet standard. Si vous collaborez sur un projet, cela permet de s'assurer qu'un membre de votre équipe a toujours accès aux paramètres Google Cloud du projet de script.
Pour ajouter des propriétaires ou d'autres rôles à un projet standard, procédez comme suit. Pour effectuer l'une des modifications suivantes, vous devez disposer d'autorisations de modification pour le projet:
- Déterminez qui doivent être vos collaborateurs. Nous vous recommandons de créer ou d'utiliser un groupe Google existant. Vous pouvez également spécifier des domaines dans la liste des collaborateurs pour inclure tous les utilisateurs de ce domaine.
- Ouvrez le projet Cloud du script.
- Cliquez sur Menu > IAM et administration > IAM.
- En haut de la page, cliquez sur Ajouter.
- Suivez les instructions à l'écran pour ajouter un ou plusieurs membres et leurs rôles au projet Cloud. Vous pouvez ajouter des adresses e-mail individuelles, des Google Groupes ou des domaines en tant que nouveaux membres.
- Cliquez sur Enregistrer.
Regrouper plusieurs scripts dans un seul projet Cloud
Vous pouvez faire en sorte que plusieurs projets Apps Script partagent le même projet Cloud standard. Pour ce faire, créez un projet standard, puis passez chaque projet de script à l'utiliser. Vous ne pouvez pas le faire avec les projets par défaut.
Utiliser un autre projet Cloud standard
Vous pouvez modifier un projet de script pour qu'il utilise un autre projet Cloud standard. Si votre script nécessite une configuration manuelle du projet Cloud, vous devez passer d'un projet par défaut à un projet standard. Pour savoir quand utiliser un projet standard, consultez les projets Cloud standards.
Conséquences si vous passez à un autre projet Cloud standard
Si vous passez d'un projet par défaut à un autre projet standard, les effets suivants se produisent:
- Si vous avez activé des services avancés pour votre script, vous devez activer les API correspondantes dans le nouveau projet Cloud. Vous perdez toutes les données associées aux services avancés du projet Cloud précédent. Pour savoir comment activer les API dans votre projet Cloud, consultez Activer les API Google Workspace.
- Si votre script utilise le service Google Drive intégré, vous devez activer l'API Drive dans les projets Cloud standards.
Dans votre projet Cloud standard, activez l'API Drive:
- Tous les utilisateurs qui ont déjà autorisé le script doivent l'autoriser à nouveau. Dans la plupart des cas, tous les utilisateurs qui ont déjà autorisé les applications associées au nouveau projet doivent également les réautoriser.
- Si votre script est associé à une fiche d'application sur Google Workspace Marketplace, votre fiche d'application, vos utilisateurs et vos avis ne sont pas transférés vers le nouveau projet. Vous devez créer une fiche d'application dans le nouveau projet et vos utilisateurs doivent réinstaller votre application. Pour en savoir plus sur la création d'une fiche d'application, consultez Publier une application.
- Vous ne pouvez pas rétablir un projet par défaut pour un script. Apps Script supprime les projets par défaut une fois que vous avez défini le script pour qu'il utilise un projet standard.
Basculer vers un autre projet Cloud standard
Pour passer d'un projet Cloud existant d'un script à un autre projet Cloud:
- Si vous ne disposez pas d'un projet Cloud approprié, créez-en un en suivant les instructions de la section Créer un projet. Définissez un nom de projet facile à retenir pour pouvoir le trouver sur la page Gérer les ressources de la console Google Cloud. Apps Script utilise ce nom lorsqu'il demande aux utilisateurs d'autoriser le script.
- Si vous souhaitez utiliser un projet existant, accédez à la page Gérer les ressources de la console Google Cloud et recherchez un projet existant à utiliser. Vous devez disposer des rôles "Project Browser" (Navigateur de projet) et "OAuth Config Editor" (Éditeur de configuration OAuth) ou de rôles avec des autorisations équivalentes pour le projet. Vous ne pouvez pas utiliser un projet créé automatiquement par Apps Script.
- Déterminez le numéro de projet de votre projet Cloud.
- Ouvrez le script dont vous souhaitez remplacer le projet Cloud.
- Sur la gauche, cliquez sur Paramètres du projet .
- Sous Projet Google Cloud Platform (GCP), cliquez sur Changer de projet.
- Saisissez le nouveau numéro de projet, puis cliquez sur Définir le projet.
Projets cloud et Drive partagés
Les Drive partagés (anciennement "Drive d'équipe") sont des espaces partagés où des groupes d'utilisateurs Drive peuvent collaborer sur des projets Apps Script et des documents Drive. Les lecteurs partagés sont utiles lorsque vous développez des scripts, des modules complémentaires et des applications Web avec une équipe, mais ils imposent certaines restrictions sur ce que vous pouvez faire avec les anciens projets Cloud par défaut.
La liste de restrictions suivante décrit comment les projets Cloud interagissent avec les disques partagés:
- Si votre projet de script utilise un projet standard, aucune restriction supplémentaire ne s'applique lorsque le projet de script se trouve dans un Drive partagé.
- Si votre projet de script utilise un projet par défaut créé le 8 avril 2019 ou après, aucune restriction supplémentaire ne s'applique lorsque le projet de script se trouve dans un Drive partagé.
- Si votre projet de script utilise un projet par défaut créé avant le 8 avril 2019, les restrictions suivantes s'appliquent lorsque le projet de script se trouve sur un disque partagé :
- Vous ne pouvez pas accéder au projet par défaut à l'aide de l'UI Apps Script ni de la console Google Cloud. Cette restriction vous empêche d'effectuer des actions qui nécessitent un accès direct au projet.
- Vous ne pouvez pas activer les services avancés. Pour activer les services avancés, passez à un projet standard.
- Lorsque vous déplacez un projet Apps Script existant vers un drive partagé, Google limite l'accès au projet Cloud par défaut. Vous pouvez toujours accéder au projet par défaut si vous y aviez accès avant le transfert. Par exemple, si vous avez créé un script dans votre dossier Mon Drive, puis l'avez déplacé vers un Drive partagé, vous pouvez toujours accéder au projet Cloud du script. Vos collaborateurs dans le Drive partagé ne pourront peut-être pas le faire.
- Un script conserve le nom du projet Cloud qu'il avait avant d'être déplacé vers un disque partagé. Même si vous modifiez le nom du projet sur le disque partagé, les utilisateurs qui autorisent le script voient toujours l'ancien nom dans les boîtes de dialogue d'autorisation.
Pour éviter les restrictions ci-dessus pour les anciens scripts, passez à un projet standard.
Obtenir la liste des projets Cloud Apps Script
Si vous disposez de l'autorisation resourcemanager.projects.list
pour le dossier de projet Apps Script de votre organisation, vous pouvez afficher tous les projets Cloud Apps Script standards et par défaut dans le dossier.
- Ouvrez la page Gérer les ressources de la console Google Cloud.
- À côté du dossier Apps Script, copiez l'ID.
- Cliquez sur Filtrer > ID parent, puis collez l'ID du dossier Apps Script.
Supprimer des projets Cloud Apps Script
Pour supprimer un projet Cloud Apps Script, suivez la procédure décrite dans Obtenir la liste des projets Cloud Apps Script, sélectionnez le projet que vous souhaitez supprimer, puis cliquez sur Supprimer.
Pour supprimer un projet Apps Script à l'aide de gcloud
, utilisez les commandes suivantes.
gcloud projects list --filter='parent.id=APPS_SCRIPT_FOLDER_ID'
gcloud projects delete PROJECT_ID
Pour en savoir plus sur la suppression de projets Cloud, consultez la section Arrêter (supprimer) des projets.