-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathassignments.tf
68 lines (59 loc) · 4.21 KB
/
assignments.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// one group for all users
data "azuread_user" "current" {
for_each = length(var.firefly_users_emails) > 0 && !var.create_admins_group && length(var.existing_admins_group_name) == 0 && !var.create_viewers_group && length(var.existing_viewers_group_name) == 0 ? toset(var.firefly_users_emails) : toset([])
user_principal_name = each.value
}
resource "azuread_app_role_assignment" "firefly-users" {
for_each = length(var.firefly_users_emails) > 0 && !var.create_admins_group && length(var.existing_admins_group_name) == 0 && !var.create_viewers_group && length(var.existing_viewers_group_name) == 0 ? { for user in data.azuread_user.current : user.id => user } : {}
app_role_id = azuread_application.firefly.app_role_ids["User"]
principal_object_id = each.value.object_id
resource_object_id = azuread_service_principal.firefly-application.object_id
}
// existing groups
data "azuread_group" "existing-admins-group" {
count = length(var.existing_admins_group_name) > 0 && length(var.firefly_users_emails) == 0 && !var.create_admins_group && !var.create_viewers_group ? 1 : 0
display_name = var.existing_admins_group_name
security_enabled = true
}
data "azuread_group" "existing-viewers-group" {
count = length(var.existing_viewers_group_name) > 0 && length(var.firefly_users_emails) == 0 && !var.create_admins_group && !var.create_viewers_group ? 1 : 0
display_name = var.existing_viewers_group_name
security_enabled = true
}
resource "azuread_app_role_assignment" "firefly-existing-admins-group-assignment" {
count = length(var.existing_admins_group_name) > 0 && length(var.firefly_users_emails) == 0 && !var.create_admins_group && !var.create_viewers_group ? 1 : 0
app_role_id = azuread_application.firefly.app_role_ids["User"]
principal_object_id = data.azuread_group.existing-admins-group[count.index].object_id
resource_object_id = azuread_service_principal.firefly-application.object_id
}
resource "azuread_app_role_assignment" "firefly-existing-viewers-group-assignment" {
count = length(var.existing_viewers_group_name) > 0 && length(var.firefly_users_emails) == 0 && !var.create_admins_group && !var.create_viewers_group ? 1 : 0
app_role_id = azuread_application.firefly.app_role_ids["User"]
principal_object_id = data.azuread_group.existing-viewers-group[count.index].object_id
resource_object_id = azuread_service_principal.firefly-application.object_id
}
// new groups
resource "azuread_group" "firefly-admins-group" {
count = var.create_admins_group && length(var.firefly_users_emails) == 0 && length(var.existing_admins_group_name) && length(var.existing_viewers_group_name) == 0 ? 1 : 0
display_name = var.new_admins_group_name
owners = [data.azuread_client_config.current.object_id]
security_enabled = true
}
resource "azuread_group" "firefly-viewers-group" {
count = var.create_viewers_group && length(var.firefly_users_emails) == 0 && length(var.existing_admins_group_name) == 0 && length(var.existing_viewers_group_name) == 0 ? 1 : 0
display_name = var.new_viewers_group_name
owners = [data.azuread_client_config.current.object_id]
security_enabled = true
}
resource "azuread_app_role_assignment" "firefly-new-admins-group-assignment" {
count = var.create_admins_group && length(var.firefly_users_emails) == 0 && length(var.existing_admins_group_name) == 0 && length(var.existing_viewers_group_name) == 0 ? 1 : 0
app_role_id = azuread_application.firefly.app_role_ids["User"]
principal_object_id = azuread_group.firefly-admins-group[count.index].object_id
resource_object_id = azuread_service_principal.firefly-application.object_id
}
resource "azuread_app_role_assignment" "firefly-new-viewers-group-assignment" {
count = var.create_viewers_group && length(var.firefly_users_emails) == 0 && length(var.existing_admins_group_name) == 0 && length(var.existing_viewers_group_name) == 0 ? 1 : 0
app_role_id = azuread_application.firefly.app_role_ids["User"]
principal_object_id = azuread_group.firefly-viewers-group[count.index].object_id
resource_object_id = azuread_service_principal.firefly-application.object_id
}