azure-github-federation-config

Purpose

The purpose of this repository is to simplify the creation of new federated identity credentials and app registrations which allows your GitHub Actions workflows to access resources in Azure, without needing to store the Azure credentials as long-lived GitHub secrets.

See also:

What's inside

  • YAML file app-registrations.yaml containing configuration of all app_registrations created by this repository
  • terraform code to take above YAML file as input variables
  • terraform module to create app registrations, service principals, federated identity as well as role assignments

Adding new app_registrations/integrations

Edit app-registrations.yaml and add new app registration as in below example:

- name: <name for the app registration>
  subjects: # list of github repositories authorised to use this app registration
    - 'repo:<org>/<repo>:ref:refs/heads/master'
    - 'repo:<org>/<repo>:pull_request'
  permissions: # list of azure builtin-roles to assign to each of scopes defined within it.
    - role_definition_name: Reader
      scopes: # list of scopes to assign
        - /subscriptions/<subscription id>
        - /subscriptions/<subscription id>/resourceGroups/<resource group>
        - /subscriptions/<subscription id>/resourceGroups/<resource group>/<resource>
    - role_definition_name: Contributor
      scopes:
        - /subscriptions/<subscription id>
        - /subscriptions/<subscription id>/resourceGroups/<resource group>
        - /subscriptions/<subscription id>/resourceGroups/<resource group>/<resource>
        ...

License

This project is licensed under the MIT License - see the LICENSE file for details

See also: