Skip to content

Commit

Permalink
fix: verify & set parent team after creation (integrations#1449)
Browse files Browse the repository at this point in the history
* explicitly check & set parent team after creation

* Added comment about setting a parent team

* Fix comment formatting

* comment formatting

Co-authored-by: Nick Floyd <139819+nickfloyd@users.noreply.github.com>
Co-authored-by: Keegan Campbell <me@kfcampbell.com>
  • Loading branch information
3 people authored Jan 11, 2023
1 parent ed4b058 commit 66d5b3f
Showing 1 changed file with 25 additions and 0 deletions.
25 changes: 25 additions & 0 deletions github/resource_github_team.go
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,31 @@ func resourceGithubTeamCreate(d *schema.ResourceData, meta interface{}) error {
return err
}

/*
When using a GitHub App for authentication, `members:write` permissions on the App are needed.
However, when using a GitHub App, CreateTeam will not correctly nest the team under the parent,
if the parent team was created by someone else than the GitHub App. In that case, the response
object will contain a `nil` parent object.
This can be resolved by using an additional call to EditTeamByID. This will be able to set the
parent team correctly when using a GitHub App with `members:write` permissions.
Note that this is best-effort: when running this with a PAT that does not have admin permissions
on the parent team, the operation might still fail to set the parent team.
*/
if newTeam.ParentTeamID != nil && githubTeam.Parent == nil {
_, _, err := client.Teams.EditTeamByID(ctx,
*githubTeam.Organization.ID,
*githubTeam.ID,
newTeam,
false)

if err != nil {
return err
}
}

create_default_maintainer := d.Get("create_default_maintainer").(bool)
if !create_default_maintainer {
log.Printf("[DEBUG] Removing default maintainer from team: %s (%s)", name, ownerName)
Expand Down

0 comments on commit 66d5b3f

Please sign in to comment.