-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathterraform.tf
138 lines (114 loc) · 3.33 KB
/
terraform.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
resource "github_repository" "terraform" {
name = "terraform"
description = "Infrastructure as code: we configure GitHub via Terraform configuration files"
allow_merge_commit = false
allow_rebase_merge = true
allow_squash_merge = true
allow_auto_merge = true
delete_branch_on_merge = true
has_issues = true
has_downloads = false
has_projects = false
has_wiki = false
vulnerability_alerts = true
homepage_url = "https://app.terraform.io/app/nl-design-system/workspaces"
visibility = "public"
squash_merge_commit_title = "PR_TITLE"
squash_merge_commit_message = "PR_BODY"
lifecycle {
prevent_destroy = true
}
}
resource "github_branch_protection" "terraform-main" {
repository_id = github_repository.terraform.node_id
pattern = "main"
enforce_admins = true
allows_deletions = false
require_signed_commits = false
required_linear_history = true
require_conversation_resolution = true
allows_force_pushes = false
lock_branch = false
# Restrict merging PRs to admins
restrict_pushes {
blocks_creations = false
push_allowances = [
"nl-design-system/${github_team.kernteam-admin.name}",
]
}
required_status_checks {
# Require branches to be up to date before merging
strict = true
contexts = [
"Terraform Cloud/nl-design-system/repo-id-1TeEm4rfMfsg6Y6G",
"Terraform format check"
]
}
required_pull_request_reviews {
dismiss_stale_reviews = true
require_code_owner_reviews = true
restrict_dismissals = false
}
}
resource "github_repository_collaborators" "terraform" {
repository = github_repository.terraform.name
# Restrict merging PRs to admins
team {
permission = "admin"
team_id = github_team.kernteam-admin.id
}
team {
permission = "triage"
team_id = github_team.kernteam-dependabot.id
}
team {
permission = "push"
team_id = github_team.kernteam-maintainer.id
}
# Allow maintainers of community teams to make PRs and review PRs
team {
permission = "push"
team_id = github_team.frameless-maintainer.id
}
team {
permission = "push"
team_id = github_team.logius-maintainer.id
}
team {
permission = "push"
team_id = github_team.rvo-maintainer.id
}
team {
permission = "push"
team_id = github_team.tilburg-acato-maintainer.id
}
team {
permission = "push"
team_id = github_team.tilburg-ditp-maintainer.id
}
team {
permission = "push"
team_id = github_team.quintor-rijkshuisstijl-maintainer.id
}
team {
permission = "push"
team_id = github_team.blueriq-maintainer.id
}
team {
permission = "push"
team_id = github_team.gemeente-rotterdam-maintainer.id
}
team {
permission = "push"
team_id = github_team.vng-services-maintainer.id
}
team {
permission = "push"
team_id = github_team.rivm-maintainer.id
}
# Restrict pushes to infrastructure as code to admins and maintainers
team {
permission = "triage"
team_id = github_team.kernteam-triage.id
}
}