Google Cloud - Comment déterminer l'ID de clé à partir de P12 ?
Dehttps://console.cloud.google.com/iam-admin/serviceaccounts?project=[id], un utilisateur disposant des autorisations appropriées peut provisionner une clé de compte de service. De nos jours, ils vous le remettent au format JSON, mais ils vous donnaient la possibilité de recevoir un P12 (dont le JSON n'est que le P12 base64'd, avec des métadonnées). J'ai hérité d'un ancien projet à maintenir et j'ai un P12 pour m'authentifier.
Cependant, plusieurs ID de clé sont répertoriés pour le compte de service donné. J'aimerais tous les faire pivoter et tout supprimer à l'exception d'une clé nouvellement provisionnée. Je ne peux pas en créer un nouveau, car le maximum est déjà atteint (10). Mais je ne peux pas supprimer au hasard, car l'application doit toujours fonctionner sans entrave. Un seul est nécessaire, et à moins de roulette, je ne peux pas trouver un moyen de déterminer QUELLE clé j'ai.
Je peux authentifier :
[~/scratch]$ gcloud auth activate-service-account [email protected] --key-file=x.p12 --prompt-for-password
Password:
WARNING: .p12 service account keys are not recomended unless it is necessary for backwards compatability. Please switch to a newer .json service account key for this account.
Activated service account credentials for: [[email protected]]
puis exécutez les commandes. Mais je n'arrive pas à trouver un moyen, que ce soit via Gcloud ou par ruse, pour que Google me dise QUELLE clé j'ai. J'ai essayé un tas de commandes gcloud. Y a-t-il quelque chose dans la journalisation GCP, des appels d'API directs, des commandes non documentées ou quelque chose d'évident que j'ai manqué ?
Réponses
L'ID de clé est l'empreinte SHA1 du certificat qui l'accompagne. Vous pouvez extraire l'empreinte SHA1 du fichier pkcs12 avec la commande suivante :
openssl pkcs12 -in /your/pkcs12/file.p12 -nodes | openssl x509 -noout -fingerprint