Service Account Management
Why Service Account Management?
Service Accounts are identities that are tied to an application instead of a human. Service Accounts are used when automating tasks in the cloud.
Controlling access permissions is a central measure to minimize security risks in the cloud. Service Account Management means staying in control of access permissions. This is similar to the care with which access for human users is controlled.
Careful Service Account Management is especially relevant for cloud platforms where the creation of service accounts requires global administrative privileges. Take Azure for example: Creating a Service Principal requires AAD permissions. Therefore teams cannot create service accounts in self-service inside an isolated cloud tenant.
The approach to Service Account Management needs to be documented in Identity and Access Management Alignment.
Enable Self-Service and Control Access Permissions
Service Account Management for central enforcement of compliance policies for technical users like re-certification, credential strength and credential rotation.
Learn more βProven Patterns for Service Account Management
Self-Service Is King
Time-to-cloud does not stop with a created tenant. Make it easy for application teams to create scoped Service Accounts, preferably self-service (See Modular Landing Zones ).
Decide if You Need to Document Permissions
Documentation of access rights is a common requirement for organizations in the finance or healthcare industries. If your organization requires access to be documented in an external system, it is worth automating the documentation system. This frees application teams from the burden of figuring out where to go after the account is created.
Clarify Who Is Responsible
There are multiple ways to do this:
Make the security owner of the project responsible for establishing proper use of service accounts
Make the person creating them accountable for their use. Centralized audit logs always contain a log finding out who created a Service Account.
Monitor Service Account Usage
Especially anti-patterns like lack of key rotation, extensive permissions (e.g. service accounts should never use default roles like GCP roles/editor) and unused service accounts should be detected and actions should be taken.
Related Tools
- GCP Fabric FAST
With the project factory, project configuration can also include service accounts provisioning alongside their permissions. By default, iam.disableServiceAccountKeyCreation organization policy is enforced on organization-level. This is a best practice that makes use of Workload Identity Federation (WIF) as an alternative to key creation.
Learn More - GCP CFT - Example Foundation
One service account seems to be created per project. This SA can then be impersonated by the Cloud Build SA to perform CI/CD tasks within the project. By default, iam.disableServiceAccountKeyCreation organization policy is enforced on organization-level. This is a best practice that makes use of Workload Identity Federation (WIF) as an alternative to key creation.
Learn More