Informations d’identification OAuth 2.0 pour GitHub les applications : JWT

  • Rversion finale: Yokohama
  • Mis à jour 30 janv. 2025
  • 8 minutes de lecture
  • Procédez comme suit pour intégrer vos applications GitHub à l’aide du jeton de porteur JWT.

    Avant de commencer

    Rôle requis :

    • oauth_admin dans Vélocité de changement DevOps.
    • Compte administrateur dans GitHub.

    Configurer l’application GitHub dans votre GitHub compte (JWT)

    Créez une application personnalisée GitHub à partir de votre GitHub compte pour activer l’authentification OAuth 2.0 avec votre ServiceNow instance.

    Avant de commencer

    GitHub Condition requise : GitHub application configurée pour s’intégrer à ServiceNow

    Rôle requis : aucun rôle d’instance requis

    Pourquoi et quand exécuter cette tâche

    Suivez ces étapes à partir de votre GitHub compte. Reportez-vous à Bâtiment GitHub Applications sur le site Developer pour obtenir des instructions sur la création et la configuration d’applications GitHub personnalisées.

    Procédure

    1. À partir de votre GitHub compte, créez votre GitHub application en accédant à Paramètres du développeur > Applications GitHub.
    2. Dans le champ URL de la page d’accueil , saisissez https://<nom-instance>.service-now.com.
    3. Dans le champ URL de rappel d’autorisation utilisateur , saisissez https://<nom-instance>.service-now.com/oauth_redirect.do.
    4. Dans la section Identification et autorisation des utilisateurs , désélectionnez le champ Faire expirer les jetons d’autorisation de l’utilisateur .
    5. Dans la section Webhook , sélectionnez le champ Actif .
    6. Dans le champ URL Webhook , saisissez https://<nom-instance>.service-now.com/api/sn_devops/v2/devops/tool/apps?toolId=<ID de l’outil>, où l’ID de l’outil est votre GitHub ID d’outil Vélocité de changement DevOps(sys_id).
      Remarque :
      Si vous créez l’outil pour la première fois et que vous n’avez pas l’ID de l’outil, vous pouvez saisir l’URL Webhook sans l’ID de l’outil et la configurer ultérieurement. Pour configurer ultérieurement :
      1. Accédez à la page d’enregistrement de l’outil connecté.
      2. Sélectionnez Configurer l’application GitHub, puis Configurer automatiquement avec le jeton existant.

        Configurez automatiquement avec le jeton existant.

      Cela configure automatiquement l’URL Webhook de l’application GitHub.
      Vous pouvez obtenir l’ID de l’outil de l’une des façons suivantes :
      • Lors de la connexion avec l’outil dans Vélocité de changement DevOps, l’ID de l’outil est disponible dans l’URL de la page. Par exemple, https://<nom-instance>.service-now.com/.../sn_devops_tool/<ID de l’outil>/....
      • Vous pouvez copier l’URL Webhook à partir de la page d’enregistrement de l’outil GitHub dans Vélocité de changement DevOps, à partir de Configurer > Configurer manuellement. > URL Webhook.
    7. Laissez les champs restants vides (par défaut).
    8. Dans la section Autorisations du référentiel , configurez les paramètres suivants.
      Action Lecture seule
      Vérifications Lecture seule
      Contenus Lecture seule
      Déploiements Lecture et écriture
      Environnements Lecture seule
      Métadonnées Lecture seule
      Demandes d'extraction Lecture seule
      Clés secrètes Lecture seule
      Webhooks Lecture et écriture
      Remarque :
      Des autorisations de lecture et d’écriture sont nécessaires pour configurer les webhooks à partir de ServiceNow.
      Remarque :
      Si vous utilisez déjà une application GitHub et que vous mettez à jour l’une des autorisations, vous devez passer en revue et accepter ces autorisations pour votre application GitHub. Vous pouvez accéder à votre application, puis sélectionner Configurer > Examiner la demande > Accepter de nouvelles autorisations.
    9. Laissez les autorisations restantes sur Aucun accès (par défaut).
    10. Dans la section S’abonner aux événements , sélectionnez l’option Règle de protection du déploiement .
    11. Enregistrez les changements.
    12. Après avoir créé l’application GitHub , générez une nouvelle clé privée et enregistrez-la sur votre ordinateur.
    13. Installez l’application nouvellement créée GitHub sur les comptes de votre choix.
      1. Dans la page des paramètres GitHub Apps, sélectionnez votre application.
      2. Dans la barre latérale gauche, sélectionnez Installer l’application.
      3. Sélectionnez Installer en regard du compte d’organisation ou personnel contenant le référentiel approprié.
      4. Installez l’application sur tous les référentiels ou sélectionnez des référentiels.

    Ajouter un ID client à la propriété DevOps

    Après avoir configuré votre application GitHub, vous devez vous assurer que le préfixe de l’ID client (3 premiers caractères ou plus de l’ID) est ajouté à la propriété DevOps : spécifieur d’ID client pour l’application GitHub.

    Avant de commencer

    Rôle requis : sn_devops.admin

    Procédure

    1. Accédez à la Espaces de travail > Espace de travail de changement DevOps > Administration > Configuration système > Propriétés.
    2. Changez le périmètre de l’application en DevOps Data Model.
    3. Recherchez la propriété : Spécifieur d’ID client pour l’application GitHub [sn_devops.github_oauth_client_id_specifier].
    4. Saisissez le préfixe de l’ID client (3 premiers caractères ou plus de l’ID) de votre application GitHub à la propriété.
    5. Sélectionnez Enregistrer.

    Générer le certificat KeyStore Java pour GitHub

    Générez un certificat Java KeyStore (JKS) pour l’authentification JWT.

    Avant de commencer

    Rôle requis : admin

    Procédure

    1. Créez un certificat signé par une autorité de certification à l’aide de la clé privée de l’application GitHub :
      openssl req -new -x509 -key <file-name>.pem -out <certificate-name>.pem -days 1095
    2. Entrez les détails requis.
    3. Créez le fichier PKCS 12 à l’aide de la clé privée de l’application et du certificat signé par l’autorité GitHub de certification :
      openssl pkcs12 -export -in <certificate-name>.pem -inkey <file-name>.pem -certfile <certificate-name>.pem -out <PKCS-12-file-name>.p12 
    4. Fournir le mot de passe d’exportation.
    5. Créez le fichier JKS :
      keytool -importkeystore -srckeystore <PKCS-12-file-name>.p12 -srcstoretype pkcs12 -destkeystore <JKS-certificate-filename>.jks -deststoretype JKS
    6. Fournissez les mots de passe de magasin de clés de destination et source.

    Joindre le GitHub certificat Java KeyStore à votre instance

    Activez l’authentification par jeton JWT Bearer Grant en joignant le certificat GitHub Java KeyStore (JKS) valide à votre instance ServiceNow.

    Avant de commencer

    Assurez-vous de la disponibilité d’un certificat Java KeyStore valide.

    Rôle requis : admin

    Procédure

    1. Accédez à la Tout > Définition du système > Certificats.
    2. Sélectionnez Nouveau.
    3. Renseignez les champs du formulaire.
      Tableau 1. Champs du formulaire Certificat X.509
      Champ Description
      Nom Nom permettant d'identifier l'enregistrement de façon unique. Par exemple, Mon certificat d’application GitHub.
      Notification à l'expiration Option permettant de spécifier les utilisateurs à notifier lorsque le certificat expire.
      Avertissement avant l'expiration (en jours) Nombre de jours pour envoyer une notification avant l’expiration du certificat.
      Actif Option permettant d’activer le certificat.
      Type Option permettant de sélectionner le type de certificat. Sélectionnez Magasin de clés Java.
      Échéance en jours Nombre de jours jusqu’à l’expiration du certificat.
      Mot de passe de magasin de clés Mot de passe associé au certificat (indice : mot de passe KeyStore de destination précédemment créé).
      Description brève Résumé du certificat.
    4. Sélectionnez l’icône Pièces jointes (icône Pièces jointes) et joignez un certificat JKS.
    5. Sélectionnez Valider les banques/certificats.

    Créer une clé de signature JWT pour le GitHub certificat JKS

    Créez une clé de signature JSON Web Token (JWT) à affecter à votre GitHub certificat Java KeyStore.

    Avant de commencer

    Rôle requis : admin, sn_devops.admin

    Procédure

    1. Accédez à la Tout > OAuth système > Clés JWT.
    2. Sélectionnez Nouveau.
    3. Renseignez les champs du formulaire.
      Tableau 2. Champs du formulaire Clés JWT
      Champ Description
      Nom Nom permettant d’identifier de façon unique la clé de signature JWT. Par exemple, Clé JWT de mon application GitHub.
      Magasin de clés de signature Certificat JKS valide joint à la tâche précédente. Par exemple, Mon certificat d’application GitHub.
      ID de clé ID unique pour identifier la clé utilisée lorsque plusieurs clés sont utilisées pour signer des jetons.
      Algorithme de signature Algorithme pour signer avec la clé JWT (indice : RSA 256).
      Signature avec le mot de passe de clé Mot de passe associé à la clé de signature (indice : mot de passe de magasin de clés source créé précédemment).
      Actif Option permettant d’activer la clé.
    4. Sélectionnez Soumettre.

    Créer un fournisseur JWT pour votre GitHub clé de signature

    Ajoutez un fournisseur de jeton Web JSON (JWT) à votre ServiceNow instance pour GitHub.

    Avant de commencer

    Rôle requis : admin, sn_devops.admin

    Procédure

    1. Accédez à la Tout > OAuth système > Fournisseurs JWT.
    2. Sélectionnez Nouveau.
    3. Renseignez les champs du formulaire.
      Tableau 3. Champs du formulaire Fournisseur JWT
      Champ Description
      Nom Nom permettant d’identifier de façon unique le fournisseur JWT. Par exemple, Mon application GitHub Fournisseur JWT.
      Intervalle d'expiration (s) Nombre en secondes pour définir la durée de vie des jetons de fournisseur JWT (conseil : vous pouvez laisser la valeur par défaut).
      Configuration de la signature Clé de signature JWT valide créée précédemment. Par exemple, Clé JWT de mon application GitHub.
    4. Cliquez avec le bouton droit sur l’en-tête du formulaire, puis sélectionnez Enregistrer.
    5. Saisissez l’ID de l’application de votre GitHub application (disponible dans la section À propos de votre GitHub configuration d’application dans GitHub ) comme valeur de la réclamation ISS, dans la liste connexe Réclamations standard.
    6. Laissez les valeurs aud et sub vides (par défaut).

    S’inscrire GitHub en tant que fournisseur OAuth (JWT)

    Utilisez les informations générées pendant GitHub la configuration du compte d’application pour vous inscrire GitHub en tant que fournisseur OAuth et permettre à l’instance de demander des jetons OAuth 2.0.

    Avant de commencer

    Rôle requis : admin, sn_devops.admin

    Procédure

    1. Accédez à la Tout > OAuth système > Registre d'application.
    2. Sélectionnez Nouveau.
      Le message Quel type d’application OAuth ? s’affiche.
    3. Sélectionnez Se connecter à un fournisseur OAuth tiers.
    4. Renseignez les champs du formulaire.
      Tableau 4. Champs du formulaire Registre d’application
      Champ Description
      Nom Nom permettant d'identifier l'enregistrement de façon unique. Par exemple, saisissez Mon fournisseur d’applications GitHub.
      ID client ID client de votre GitHub application (conseil : disponible dans la section À propos de votre GitHub configuration d’application dans GitHub ).
      Secret client Secret client de votre GitHub application (indice : disponible dans la section À propos de votre GitHub configuration d’application dans GitHub ).
      Script de l’API OAuth Option qui vous permet de référencer un include de script OAuthUtil modifié. Sélectionnez OAuthDevOpsGitHubJWTHandler.
      Type d'accord par défaut Type de subvention associé au registre d’application. Sélectionnez Support JWT.
      URL de jeton Emplacement du point de terminaison du jeton que l’instance utilise pour récupérer et actualiser les jetons.

      Pour la version cloud, saisissez : https://api.github.com/app/installations/<installation_id>/access_tokens.

      Pour la version d’entreprise, saisissez : https://<HOST_URL>/api/v3/app/installations/<installation_id>/access_tokens.

      Pour l’ID d’installation, accédez à la section Installer l’application dans votre configuration d’application GitHub dans GitHub et sélectionnez l’icône d’engrenage pour configurer votre application. L’ID d’installation se trouve dans l’URL de la page Web. Par exemple, https://github.com/settings/installations/<installation_id>.

    5. Laissez les autres champs de formulaire par défaut.
      Formulaire Registre d’application
    6. Cliquez avec le bouton droit sur l’en-tête du formulaire, puis sélectionnez Enregistrer.
    7. Ouvrez le profil par défaut créé dans la liste connexe Profils des entités OAuth .
    8. Renseignez le champ Fournisseur JWT avec le fournisseur JWT précédemment créé et enregistrez le formulaire.
    9. Accédez à la gestion des clés > aux politiques d’accès au module > tout.
    10. Sélectionnez la politique qui a com_snc_platform_security_oauth_glideencrypter comme valeur du champ Module de chiffrement et Include de script : OAuthDevOpsGitHubJWTHandler comme valeur du champ Script cible .
    11. Assurez-vous que le champ Résultat est défini sur Suivre et enregistrez les changements.
      Le formulaire qui indique que le champ de résultat est défini sur suivi.

    Créer un enregistrement d’informations d’identification pour GitHub le fournisseur d’application (JWT)

    Créez un enregistrement d’informations d’identification auprès du fournisseur d’application GitHub précédemment créé pour autoriser des actions.

    Avant de commencer

    Rôle requis : admin, sn_devops.admin

    Procédure

    1. Accédez à la Tout > Connexions et informations d'identification > Informations d'identification.
    2. Sélectionnez Nouveau.
      Le message Quel type d’informations d’identification voulez-vous créer ? s’affiche.
    3. Sélectionnez Informations d'identification OAuth 2.0.
    4. Renseignez les champs du formulaire.
      Tableau 5. Champs du formulaire Informations d’identification OAuth 2.0
      Champ Valeur requise
      Nom Nom permettant d'identifier l'enregistrement de façon unique. Par exemple, saisissez les informations d’identification de mon application GitHub.
      Actif Option permettant d’activer l’enregistrement.
      Profil de l'entité OAuth Profil d’entité OAuth par défaut créé dans le registre d’application.
    5. Enregistrez l'enregistrement.
    6. Sélectionnez le lien connexe Obtenir le jeton OAuth pour générer le jeton OAuth.