Users.psm1
function Get-GitlabUser { param ( [Parameter(Mandatory=$false)] [string] $Username, [Parameter(Mandatory=$false)] [string] $EmailAddress ) if ($Username) { $UserId = Invoke-GitlabApi GET "users" @{ username = $Username } | Select-Object -First 1 -ExpandProperty id Invoke-GitlabApi GET "users/$UserId" | New-WrapperObject 'Gitlab.User' } elseif ($EmailAddress) { $UserId = Invoke-GitlabApi GET "search" @{ scope = 'users' search = $EmailAddress } | Select-Object -First 1 -ExpandProperty id Invoke-GitlabApi GET "users/$UserId" | New-WrapperObject 'Gitlab.User' } } function Get-GitlabCurrentUser { Invoke-GitlabApi GET "user" | New-WrapperObject 'Gitlab.User' } function Get-GitlabGroupMembership { param ( [Parameter(Mandatory=$false)] [string] $Username, [Parameter(Mandatory=$false)] [string] $EmailAddress ) $User = Get-GitlabUser -Username $Username -EmailAddress $EmailAddress Invoke-GitlabApi GET "users/$($User.Id)/memberships" -MaxPages 10 | New-WrapperObject "Gitlab.GroupMembership" } function Add-GitlabUserToGroup { param ( [Parameter(Position=0, Mandatory=$true)] [string] $GroupName, [Parameter(Position=1, Mandatory=$true)] [string] [ValidateSet("developer", "maintainer")] $AccessLevel, [Parameter(Mandatory=$false)] [string] $Username, [Parameter(Mandatory=$false)] [string] $EmailAddress, [Parameter()] [switch] $WhatIf ) $Group = Get-GitlabGroup -GroupId $GroupName $User = Get-GitlabUser -Username $Username -EmailAddress $EmailAddress Invoke-GitlabApi POST "groups/$($Group.Id)/members" @{ user_id = $User.Id access_level = $Global:GitlabAccessLevels[$AccessLevel] } -WhatIf:$WhatIf | Out-Null if(-not $WhatIf) { Get-GitlabGroupMembership -Username $Username -EmailAddress $EmailAddress } } $Global:GitlabAccessLevels = @{developer = 30; maintainer = 40} |