-
Notifications
You must be signed in to change notification settings - Fork 209
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
GKE WLI to authenticate as another service account #403
Comments
Hi there @halradaideh 👋! Thank you for opening an issue. Our team will triage this as soon as we can. Please take a moment to review the troubleshooting steps which lists common error messages and their resolution steps. |
Hi @halradaideh thank you for opening an issue. I'm not sure I understand what you mean by:
Can you provide an example? What problem are you trying to solve? |
i have a case with GitHub Actions the runner is a pod with a KSA bound to a GSA I am trying to dynamically change who is accessing GCP resources at execution time in this way, I need to grant the pod's SA the ability to impersonate others and manage IAM access per team per the team's SA and thus providing the execution access to the team's resources only |
How is that different from Workload Identity Federation, which does this natively (and If you really want an impersonation chain, you can use the |
Sorry but I may be a bit confused All examples requires workload_identity_provider, I thought there is a default one, but when I checked there is no workloadIdentityPools by default If the federation example supports what I want, what should I fill workload_identity_provider then? |
Can you give some concrete examples of what you're trying to do? You have a GKE cluster that is running some pods. Those pods have an identity, and you want to exchange that pod identity for another identity? Why - what are you trying to do? What workload is running on the pod? |
The workload is a GitHub runner part of GitHub arc regradless of my usecase, if WIF is the way to go, how can I use it without defining new pools/provider in GCP, I want to do the same gcloud do when it applies the impersonation |
It look like your use case is the basic use case for this this action. At this point, you don't need any (gcp) service account linked to your pod. You only want one if you want to give a base access (read only access to standard service ...) Impersonation cannot be limited by a policy, if a policy give the permission on 2 services account to be impersonated by your server service account, then everybody executing things on this server will be able to impersonate the 2 service accounts. To limit what people can do, you have to get an external data(here the id_token), and doing so, setup something on GCP (pool / provider). Now in theory GCP could provide a defaut GitHub pool (it is not done), but it would be a contradiction to the federated service as nobody would be able to put their own additional provider on the pool, nor do any small configuration change on the GitHub provider would be possible. |
I think multiple ideas are being conflated here. This action (google-github-actions/auth) is for taking GitHub-issued OIDC tokens and exchanging them for Google Cloud identities. Those tokens are signed by GitHub when a job is given If you're already on Google Cloud and you already have the desired identity, you can use Application Default Credentials to get the underlying instance identity credentials; this works on GKE too for KSA identities. Neither GitHub-managed runners (on github.com) nor self-hosted runners have a specific "identity"; they have a series of claims for which you can map to identities. Those claims include things like the workflow name, caller, repo, and org, for example: {
// ...
"ref": "refs/heads/main",
"sha": "example-sha",
"repository": "octo-org/octo-repo",
"repository_owner": "octo-org",
"actor_id": "12",
"repository_visibility": "private",
"repository_id": "74",
"repository_owner_id": "65",
"run_id": "example-run-id",
"run_number": "10",
"run_attempt": "2",
"runner_environment": "github-hosted"
"actor": "octocat",
"workflow": "example-workflow",
//...
} If you want to map those claims to specific identities, you can use Workload Identity Federation (WIF) to establish those rules. For example, if you wanted a rule like:
You can create a WIF Pool and Provider that grants the corresponding gcloud projects add-iam-policy-binding "my-project" \
--role "roles/cloudrun.developer" \
--member "principalSet://iam.googleapis.com/projects/416438230019/locations/global/workloadIdentityPools/github/attribute.actor/sethvargo" Then using If you go that route, you should ensure that the KSA/GSA has no permissions on Google Cloud, since that identity is not actually used to interact with Google Cloud resources. I think you might be confusing the Workload Identity for Kubernetes with the per-invocation workflow identity provided by GitHub Actions. |
Thank you both for the clarification. @GregoireW I understand that if there were an identity on the Pod it would be able to access any other service account. @sethvargo What I initially wanted is not related to GitHub-issued OIDC tokens nor the WIF, I simply wanted to exchange the active service account on the pod dynamically based on a mapping I have in mind (map repos to teams), and to achieve that I wanted to use Service Account Impersonation. I managed somehow to do what I had in mind, but still, it is a hack (Poor's man impersonation 😆 ) - name: get SA token for GCP auth
id: token
run: |
#!/bin/bash
set -x
TARGET="[email protected]"
TOKEN_URL="https://iamcredentials.googleapis.com/v1/projects/-/serviceAccounts/${TARGET}:generateAccessToken"
SCOPE_URL="https://www.googleapis.com/auth/cloud-platform"
SOURCE=$(curl -s -H "Metadata-Flavor: Google" "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/email")
TOKEN_REQUEST='{
"delegates": ["'$SOURCE'"],
"scope": "'$SCOPE_URL'"
}'
ACCESS_TOKEN=$(curl -s -H "Metadata-Flavor: Google" "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/token" | jq -r .access_token)
curl -s -X POST -H "Content-Type: application/json" \
-H "Authorization: Bearer $ACCESS_TOKEN" \
-d "$TOKEN_REQUEST" \
"$TOKEN_URL" > /tmp/token.json
file=$(find * | grep gha-kubeconfig)
DATA=$(cat /tmp/token.json | jq .accessToken)
sed -i "s/token: .*/token: $DATA/g" $file so at the end, if the impersonation logic is not considered part of the "auth" action, I think it should be a separated action. anyway, in the WIF you provided, you mapped the principalSet as the user to a role, is it possible to grant it what another SA have (impersonate a GCP SA)? |
Hi @halradaideh I still think you're misunderstanding how WIF works. The underlying configuration for the code snippet you provided indicates that the KSA has permissions to impersonate the superset of all service accounts jobs might need; that means an insider or an attacker can get access to arbitrary identities, regardless of the source job or attributes.
This certainly sounds like you're trying to use GitHub Actions + OIDC as it's intended to be used...
Yes, that's Workload Identity Federation through a Service Account as documented the README. The In general, we recommend using Direct Workload Identity Federation instead of relying on impersonation, since impersonation introduces multiple layers of indirection. |
Yes, I am aware of the security risk as mentioned in the previous comment, it is not managed by the user another step generates the mapping, but yes anyone can get access if they know what is being made underneath. WIF seems the logical way to go. Thank you all for your time and explanation. |
TL;DR
Pod in GKE has a SA, I would like to authenticate as another service account dynamically via utilizing WLI to impersonate the other account.
Detailed design
in the examples,
https://github.com/google-github-actions/auth/blob/main/docs/EXAMPLES.md#workload-identity-federation-through-a-service-account
You can use WLF to authenticate as a service account, I would like to have the same ability to change the pod's identity using its identity which is obtained from WLI, at least for the GitHub action execution.
Using SA impersonation, the KSA/GSA with WLI will have the ability (previously granted with required permission) to impersonate a target SA to dynamically change the identity of the execution.
Additional information
No response
The text was updated successfully, but these errors were encountered: