Skip to content
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

[DDO-3870] Azure account provisioning via propagation #minor #661

Merged
merged 45 commits into from
Oct 2, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
1ad50ac
allow detection of 'effective' removal
jack-r-warren Sep 10, 2024
2617b60
generalize gcp folder role engine
jack-r-warren Sep 11, 2024
e4b28b9
improve init error messages
jack-r-warren Sep 11, 2024
e0a5e6f
add AzureDirectoryRoleEngine
jack-r-warren Sep 12, 2024
4794c52
add AzureInvitedAccountEngine
jack-r-warren Sep 12, 2024
a49cd3b
add dry run capability to all propagators
jack-r-warren Sep 12, 2024
f0bb300
azure invited account engine tests
jack-r-warren Sep 13, 2024
0a85a57
fix past tense
jack-r-warren Sep 13, 2024
9221ef8
azure account engine
jack-r-warren Sep 13, 2024
2063c63
add additional azure fields
jack-r-warren Sep 13, 2024
5406c62
handle template vs directory role id
jack-r-warren Sep 13, 2024
a9487a3
initialize new propagators
jack-r-warren Sep 13, 2024
7d0d486
represent UPN better in AzureAccountEngine
jack-r-warren Sep 18, 2024
33fc1f3
properly handle EXT UPN in AzureInvitedAccountEngine
jack-r-warren Sep 18, 2024
7e182d2
adjust summary text
jack-r-warren Sep 19, 2024
1427631
log better
jack-r-warren Sep 19, 2024
47ecfb5
eventual consistency
jack-r-warren Sep 19, 2024
10b391c
simpler filters
jack-r-warren Sep 20, 2024
e6e8823
page iterator
jack-r-warren Sep 20, 2024
8772187
ridiculous
jack-r-warren Sep 20, 2024
8d4f457
ooOOOooo so fancy hi
jack-r-warren Sep 20, 2024
138bbf5
additional retry regexes
jack-r-warren Sep 24, 2024
4b6353f
align config keys
jack-r-warren Sep 24, 2024
ea1255b
fix member email suffix
jack-r-warren Sep 24, 2024
6f35bc3
fix member email suffix for prod
jack-r-warren Sep 24, 2024
008bb9c
top not supported, whatever
jack-r-warren Sep 24, 2024
aa8e1ec
fix config key
jack-r-warren Sep 24, 2024
a8162a7
fix config key
jack-r-warren Sep 24, 2024
9355409
(also remove the group thing)
jack-r-warren Sep 24, 2024
7f72f93
remove config loading thing, not needed
jack-r-warren Sep 25, 2024
1d3f651
better password generator
jack-r-warren Sep 25, 2024
8802e72
add retry regex
jack-r-warren Sep 25, 2024
36f792f
group members page iterator
jack-r-warren Sep 25, 2024
5cb0968
fix ineffectual assignment
jack-r-warren Sep 25, 2024
db7d334
remove config loading thing, not needed
jack-r-warren Sep 25, 2024
0e32b2b
make the ignored thing actually work
jack-r-warren Sep 25, 2024
f838ed4
properly do the other mails modification
jack-r-warren Sep 27, 2024
a4ddf07
another try
jack-r-warren Sep 27, 2024
b3c5798
Revert "another try"
jack-r-warren Sep 27, 2024
6532145
no invite message body
jack-r-warren Sep 27, 2024
c239478
send slack
jack-r-warren Sep 30, 2024
fe2e029
improved message text
jack-r-warren Sep 30, 2024
4f887c4
describe diff better
jack-r-warren Sep 30, 2024
cf98337
remove nameInferredFromGithub
jack-r-warren Oct 2, 2024
42d9e00
newline
jack-r-warren Oct 2, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions sherlock/.mockery.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ packages:
interfaces:
Identifier:
Fields:
MayBePresentWhileRemovedFields:
github.com/broadinstitute/sherlock/sherlock/internal/role_propagation/propagation_engines:
interfaces:
PropagationEngine:
Expand Down
142 changes: 142 additions & 0 deletions sherlock/config/default_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -362,8 +362,101 @@ rolePropagation:
driftAlignmentStaleThreshold: 5m
propagators:

# devAzureAccount correlates to models.Role.GrantsDevAzureAccount.
devAzureAccount:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
tenantID: fad90753-2022-4456-9b0a-c7e5b934e408 # azure.dev.envs-terra.bio
# The path on disk that Sherlock should expect to find a token for federated workload identity.
tokenFilePath: /azure-federation/projected-ksa-token.jwt
# The suffix of all accounts in the tenant that Sherlock should manage.
tenantEmailSuffix: "@test.firecloud.org"
# Suffixes of Sherlock users' emails that should be swapped out with the memberEmailSuffix to match
# Sherlock users to Azure Entra ID user emails.
userEmailSuffixesToReplace:
- "@broadinstitute.org"
# prodAzureAccount correlates to models.Role.GrantsProdAzureAccount.
prodAzureAccount:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
tenantID: 66bb90ac-8857-4a8a-aa0a-be2186dfa5f9 # firecloud.org
# The path on disk that Sherlock should expect to find a token for federated workload identity.
tokenFilePath: /azure-federation/projected-ksa-token.jwt
# The suffix of all accounts in the tenant that Sherlock should manage.
memberEmailSuffix: "@firecloud.org"
# Suffixes of Sherlock users' emails that should be swapped out with the memberEmailSuffix to match
# Sherlock users to Azure Entra ID user emails.
userEmailSuffixesToReplace:
- "@broadinstitute.org"

# devAzureB2CAccount correlates to models.Role.GrantsDevAzureAccount. It invites the account
# provisioned by devAzureAccount.
devAzureInvitedB2CAccount:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication against the home tenant.
homeClientID:
# The UUID of the home Azure AD tenant to work with.
homeTenantID: fad90753-2022-4456-9b0a-c7e5b934e408 # azure.dev.envs-terra.bio
# The path on disk that Sherlock should expect to find a token for federated workload identity
# to use against the home tenant.
homeTokenFilePath: /azure-federation/projected-ksa-token.jwt
# The client ID of the Azure AD app to use for authentication against the tenant to invite to.
inviteClientID:
# The UUID of the Azure AD tenant to invite home tenant users to.
inviteTenantID: fd0bc0ef-1747-4ee6-ab3e-d4d6bb882d40 # terradevb2c.onmicrosoft.com
# The path on disk that Sherlock should expect to find a token for federated workload identity
# to use against the tenant to invite to.
inviteTokenFilePath: /azure-federation/projected-ksa-token.jwt
# The domain of the email addresses in the home tenant. Should match the user principal names in
# the home tenant.
homeTenantEmailDomain: "test.firecloud.org"
# The domain of the identities in the invite tenant. Should match the end of the user principal names
# in the invite tenant, so that they're like <prefix>_<homeTenantEmailDomain>#EXT#@<inviteTenantIdentityDomain>.
inviteTenantIdentityDomain: "terradevb2c.onmicrosoft.com"
# Domains of Sherlock users' emails that should be swapped out with the home tenant email domain
# to match Sherlock users to Azure Entra ID user emails.
userEmailDomainsToReplace:
- "broadinstitute.org"
# prodAzureB2CAccount correlates to models.Role.GrantsProdAzureAccount. It invites the account
# provisioned by prodAzureAccount.
prodAzureInvitedB2CAccount:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication against the home tenant.
homeClientID:
# The UUID of the home Azure AD tenant to work with.
homeTenantID: 66bb90ac-8857-4a8a-aa0a-be2186dfa5f9 # firecloud.org
# The path on disk that Sherlock should expect to find a token for federated workload identity
# to use against the home tenant.
homeTokenFilePath: /azure-federation/projected-ksa-token.jwt
# The client ID of the Azure AD app to use for authentication against the tenant to invite to.
inviteClientID:
# The UUID of the Azure AD tenant to invite home tenant users to.
inviteTenantID: 35ea5de9-1786-4bbb-89cf-25b88261643d # terraprodb2c.onmicrosoft.com
# The path on disk that Sherlock should expect to find a token for federated workload identity
# to use against the tenant to invite to.
inviteTokenFilePath: /azure-federation/projected-ksa-token.jwt
# The domain of the email addresses in the home tenant. Should match the user principal names in
# the home tenant.
homeTenantEmailDomain: "firecloud.org"
# The domain of the identities in the invite tenant. Should match the end of the user principal names
# in the invite tenant, so that they're like <prefix>_<homeTenantEmailDomain>#EXT#@<inviteTenantIdentityDomain>.
inviteTenantIdentityDomain: "terraprodb2c.onmicrosoft.com"
# Domains of Sherlock users' emails that should be swapped out with the home tenant email domain
# to match Sherlock users to Azure Entra ID user emails.
userEmailDomainsToReplace:
- "broadinstitute.org"

devFirecloudGroup:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "test.firecloud.org"
Expand All @@ -373,6 +466,7 @@ rolePropagation:
- "@broadinstitute.org"
qaFirecloudGroup:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "quality.firecloud.org"
Expand All @@ -382,6 +476,7 @@ rolePropagation:
- "@broadinstitute.org"
prodFirecloudGroup:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "firecloud.org"
Expand All @@ -392,6 +487,7 @@ rolePropagation:

devFirecloudFolderOwner:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "test.firecloud.org"
Expand All @@ -401,6 +497,7 @@ rolePropagation:
- "@broadinstitute.org"
qaFirecloudFolderOwner:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "quality.firecloud.org"
Expand All @@ -410,6 +507,7 @@ rolePropagation:
- "@broadinstitute.org"
prodFirecloudFolderOwner:
enable: false
dryRun: false
# The domain of the Google Workspace, assumed to be the email domain of all members. This should
# not contain a leading "@".
workspaceDomain: "firecloud.org"
Expand All @@ -420,6 +518,7 @@ rolePropagation:

devAzureGroup:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
Expand All @@ -436,6 +535,7 @@ rolePropagation:
- "@broadinstitute.org"
prodAzureGroup:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
Expand All @@ -451,8 +551,50 @@ rolePropagation:
userEmailSuffixesToReplace:
- "@broadinstitute.org"

# devAzureB2CReader correlates to models.Role.GrantsDevAzureDirectoryRoles. It's the only role we grant currently.
# Additional roles can be granted by correlating additional propagators with different instantiations and
# configurations to the same boolean field.
devAzureB2CReader:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
tenantID: fd0bc0ef-1747-4ee6-ab3e-d4d6bb882d40 # terradevb2c.onmicrosoft.com
# The path on disk that Sherlock should expect to find a token for federated workload identity.
tokenFilePath: /azure-federation/projected-ksa-token.jwt
# The suffix of all member emails. This can be thought of as a filter for what Azure users Sherlock
# will attempt to propagate roles to. This may contain a "@" (especially useful for "#EXT#@" emails);
# if it does, then the userEmailSuffixesToReplace must as well.
memberEmailSuffix: "@test.firecloud.org"
# Suffixes of Sherlock users' emails that should be swapped out with the memberEmailSuffix to match
# Sherlock users to Azure Entra ID users.
userEmailSuffixesToReplace:
- "@broadinstitute.org"
# prodAzureB2CReader correlates to models.Role.GrantsDevAzureDirectoryRoles. It's the only role we grant currently.
# Additional roles can be granted by correlating additional propagators with different instantiations and
# configurations to the same boolean field.
prodAzureB2CReader:
enable: false
dryRun: false
# The client ID of the Azure AD app to use for authentication.
clientID:
# The UUID of the Azure AD tenant to work with.
tenantID: 35ea5de9-1786-4bbb-89cf-25b88261643d # terraprodb2c.onmicrosoft.com
# The path on disk that Sherlock should expect to find a token for federated workload identity.
tokenFilePath: /azure-federation/projected-ksa-token.jwt
# The suffix of all member emails. This can be thought of as a filter for what Azure users Sherlock
# will attempt to propagate roles to. This may contain a "@" (especially useful for "#EXT#@" emails);
# if it does, then the userEmailSuffixesToReplace must as well.
memberEmailSuffix: "@firecloud.org"
# Suffixes of Sherlock users' emails that should be swapped out with the memberEmailSuffix to match
# Sherlock users to Azure Entra ID users.
userEmailSuffixesToReplace:
- "@broadinstitute.org"

broadInstituteGroup:
enable: false
dryRun: false

suitabilitySynchronization:
enable: true
Expand Down
5 changes: 5 additions & 0 deletions sherlock/config/test_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,11 @@ rolePropagation:
enable: false
workspaceDomain: test.firecloud.org

devFirecloudGroupTestDryRun:
enable: true
workspaceDomain: test.firecloud.org
dryRun: true

devFirecloudGroupTestDefault:
enable: true
workspaceDomain: test.firecloud.org
Expand Down
43 changes: 43 additions & 0 deletions sherlock/db/migrations/000098_add_azure_account_fields.down.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
drop index if exists roles_grants_dev_azure_account_unique;

alter table roles
drop column if exists grants_dev_azure_account;

alter table role_operations
drop column if exists from_grants_dev_azure_account;

alter table role_operations
drop column if exists to_grants_dev_azure_account;

drop index if exists roles_grants_prod_azure_account_unique;

alter table roles
drop column if exists grants_prod_azure_account;

alter table role_operations
drop column if exists from_grants_prod_azure_account;

alter table role_operations
drop column if exists to_grants_prod_azure_account;

drop index if exists roles_grants_dev_azure_directory_roles_unique;

alter table roles
drop column if exists grants_dev_azure_directory_roles;

alter table role_operations
drop column if exists from_grants_dev_azure_directory_roles;

alter table role_operations
drop column if exists to_grants_dev_azure_directory_roles;

drop index if exists roles_grants_prod_azure_directory_roles_unique;

alter table roles
drop column if exists grants_prod_azure_directory_roles;

alter table role_operations
drop column if exists from_grants_prod_azure_directory_roles;

alter table role_operations
drop column if exists to_grants_prod_azure_directory_roles;
51 changes: 51 additions & 0 deletions sherlock/db/migrations/000098_add_azure_account_fields.up.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
alter table roles
add column if not exists grants_dev_azure_account boolean;

create unique index if not exists roles_grants_dev_azure_account_unique
on roles (grants_dev_azure_account)
where deleted_at is null and grants_dev_azure_account is not null and grants_dev_azure_account is true;

alter table role_operations
add column if not exists from_grants_dev_azure_account boolean;

alter table role_operations
add column if not exists to_grants_dev_azure_account boolean;

alter table roles
add column if not exists grants_prod_azure_account boolean;

create unique index if not exists roles_grants_prod_azure_account_unique
on roles (grants_prod_azure_account)
where deleted_at is null and grants_prod_azure_account is not null and grants_prod_azure_account is true;

alter table role_operations
add column if not exists from_grants_prod_azure_account boolean;

alter table role_operations
add column if not exists to_grants_prod_azure_account boolean;

alter table roles
add column if not exists grants_dev_azure_directory_roles boolean;

create unique index if not exists roles_grants_dev_azure_directory_roles_unique
on roles (grants_dev_azure_directory_roles)
where deleted_at is null and grants_dev_azure_directory_roles is not null and grants_dev_azure_directory_roles is true;

alter table role_operations
add column if not exists from_grants_dev_azure_directory_roles boolean;

alter table role_operations
add column if not exists to_grants_dev_azure_directory_roles boolean;

alter table roles
add column if not exists grants_prod_azure_directory_roles boolean;

create unique index if not exists roles_grants_prod_azure_directory_roles_unique
on roles (grants_prod_azure_directory_roles)
where deleted_at is null and grants_prod_azure_directory_roles is not null and grants_prod_azure_directory_roles is true;

alter table role_operations
add column if not exists from_grants_prod_azure_directory_roles boolean;

alter table role_operations
add column if not exists to_grants_prod_azure_directory_roles boolean;
12 changes: 12 additions & 0 deletions sherlock/internal/api/sherlock/roles_v3.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,12 @@ type RoleV3Edit struct {
GrantsDevFirecloudFolderOwner *string `json:"grantsDevFirecloudFolderOwner,omitempty" form:"grantsDevFirecloudFolderOwner"`
GrantsQaFirecloudFolderOwner *string `json:"grantsQaFirecloudFolderOwner,omitempty" form:"grantsQaFirecloudFolderOwner"`
GrantsProdFirecloudFolderOwner *string `json:"grantsProdFirecloudFolderOwner,omitempty" form:"grantsProdFirecloudFolderOwner"`
GrantsDevAzureAccount *bool `json:"grantsDevAzureAccount,omitempty" form:"grantsDevAzureAccount"`
GrantsProdAzureAccount *bool `json:"grantsProdAzureAccount,omitempty" form:"grantsProdAzureAccount"`
GrantsDevAzureGroup *string `json:"grantsDevAzureGroup,omitempty" form:"grantsDevAzureGroup"`
GrantsProdAzureGroup *string `json:"grantsProdAzureGroup,omitempty" form:"grantsProdAzureGroup"`
GrantsDevAzureDirectoryRoles *bool `json:"grantsDevAzureDirectoryRoles,omitempty" form:"grantsDevAzureDirectoryRoles"`
GrantsProdAzureDirectoryRoles *bool `json:"grantsProdAzureDirectoryRoles,omitempty" form:"grantsProdAzureDirectoryRoles"`
GrantsBroadInstituteGroup *string `json:"grantsBroadInstituteGroup,omitempty" form:"grantsBroadInstituteGroup"`
}

Expand All @@ -46,8 +50,12 @@ func (r RoleV3) toModel() models.Role {
GrantsDevFirecloudFolderOwner: r.GrantsDevFirecloudFolderOwner,
GrantsQaFirecloudFolderOwner: r.GrantsQaFirecloudFolderOwner,
GrantsProdFirecloudFolderOwner: r.GrantsProdFirecloudFolderOwner,
GrantsDevAzureAccount: r.GrantsDevAzureAccount,
GrantsProdAzureAccount: r.GrantsProdAzureAccount,
GrantsDevAzureGroup: r.GrantsDevAzureGroup,
GrantsProdAzureGroup: r.GrantsProdAzureGroup,
GrantsDevAzureDirectoryRoles: r.GrantsDevAzureDirectoryRoles,
GrantsProdAzureDirectoryRoles: r.GrantsProdAzureDirectoryRoles,
GrantsBroadInstituteGroup: r.GrantsBroadInstituteGroup,
},
}
Expand Down Expand Up @@ -80,8 +88,12 @@ func roleFromModel(model models.Role) RoleV3 {
GrantsDevFirecloudFolderOwner: model.GrantsDevFirecloudFolderOwner,
GrantsQaFirecloudFolderOwner: model.GrantsQaFirecloudFolderOwner,
GrantsProdFirecloudFolderOwner: model.GrantsProdFirecloudFolderOwner,
GrantsDevAzureAccount: model.GrantsDevAzureAccount,
GrantsProdAzureAccount: model.GrantsProdAzureAccount,
GrantsDevAzureGroup: model.GrantsDevAzureGroup,
GrantsProdAzureGroup: model.GrantsProdAzureGroup,
GrantsDevAzureDirectoryRoles: model.GrantsDevAzureDirectoryRoles,
GrantsProdAzureDirectoryRoles: model.GrantsProdAzureDirectoryRoles,
GrantsBroadInstituteGroup: model.GrantsBroadInstituteGroup,
},
}
Expand Down
4 changes: 4 additions & 0 deletions sherlock/internal/api/sherlock/roles_v3_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,12 @@ func (s *handlerSuite) Test_roleFromModel() {
GrantsDevFirecloudFolderOwner: model.GrantsDevFirecloudFolderOwner,
GrantsQaFirecloudFolderOwner: model.GrantsQaFirecloudFolderOwner,
GrantsProdFirecloudFolderOwner: model.GrantsProdFirecloudFolderOwner,
GrantsDevAzureAccount: model.GrantsDevAzureAccount,
GrantsProdAzureAccount: model.GrantsProdAzureAccount,
GrantsDevAzureGroup: model.GrantsDevAzureGroup,
GrantsProdAzureGroup: model.GrantsProdAzureGroup,
GrantsDevAzureDirectoryRoles: model.GrantsDevAzureDirectoryRoles,
GrantsProdAzureDirectoryRoles: model.GrantsProdAzureDirectoryRoles,
GrantsBroadInstituteGroup: model.GrantsBroadInstituteGroup,
},
}
Expand Down
Loading
Loading