2019-05-07 06:42:51 +05:30
// Copyright 2013 The go-github AUTHORS. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package github
import (
"context"
"fmt"
)
// Membership represents the status of a user's membership in an organization or team.
type Membership struct {
URL * string ` json:"url,omitempty" `
// State is the user's status within the organization or team.
// Possible values are: "active", "pending"
State * string ` json:"state,omitempty" `
// Role identifies the user's role within the organization or team.
// Possible values for organization membership:
// member - non-owner organization member
// admin - organization owner
//
// Possible values for team membership are:
// member - a normal member of the team
// maintainer - a team maintainer. Able to add/remove other team
// members, promote other team members to team
// maintainer, and edit the team’ s name and description
Role * string ` json:"role,omitempty" `
// For organization membership, the API URL of the organization.
OrganizationURL * string ` json:"organization_url,omitempty" `
// For organization membership, the organization the membership is for.
Organization * Organization ` json:"organization,omitempty" `
// For organization membership, the user the membership is for.
User * User ` json:"user,omitempty" `
}
func ( m Membership ) String ( ) string {
return Stringify ( m )
}
// ListMembersOptions specifies optional parameters to the
// OrganizationsService.ListMembers method.
type ListMembersOptions struct {
// If true (or if the authenticated user is not an owner of the
// organization), list only publicly visible members.
PublicOnly bool ` url:"-" `
// Filter members returned in the list. Possible values are:
// 2fa_disabled, all. Default is "all".
Filter string ` url:"filter,omitempty" `
// Role filters members returned by their role in the organization.
// Possible values are:
// all - all members of the organization, regardless of role
// admin - organization owners
// member - non-owner organization members
//
// Default is "all".
Role string ` url:"role,omitempty" `
ListOptions
}
// ListMembers lists the members for an organization. If the authenticated
// user is an owner of the organization, this will return both concealed and
// public members, otherwise it will only return public members.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#list-organization-members
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#list-public-organization-members
2020-07-31 19:52:34 +05:30
func ( s * OrganizationsService ) ListMembers ( ctx context . Context , org string , opts * ListMembersOptions ) ( [ ] * User , * Response , error ) {
2019-05-07 06:42:51 +05:30
var u string
2020-07-31 19:52:34 +05:30
if opts != nil && opts . PublicOnly {
2019-05-07 06:42:51 +05:30
u = fmt . Sprintf ( "orgs/%v/public_members" , org )
} else {
u = fmt . Sprintf ( "orgs/%v/members" , org )
}
2020-07-31 19:52:34 +05:30
u , err := addOptions ( u , opts )
2019-05-07 06:42:51 +05:30
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var members [ ] * User
resp , err := s . client . Do ( ctx , req , & members )
if err != nil {
return nil , resp , err
}
return members , resp , nil
}
// IsMember checks if a user is a member of an organization.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#check-organization-membership-for-a-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) IsMember ( ctx context . Context , org , user string ) ( bool , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/members/%v" , org , user )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return false , nil , err
}
resp , err := s . client . Do ( ctx , req , nil )
member , err := parseBoolResponse ( err )
return member , resp , err
}
// IsPublicMember checks if a user is a public member of an organization.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#check-public-organization-membership-for-a-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) IsPublicMember ( ctx context . Context , org , user string ) ( bool , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/public_members/%v" , org , user )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return false , nil , err
}
resp , err := s . client . Do ( ctx , req , nil )
member , err := parseBoolResponse ( err )
return member , resp , err
}
// RemoveMember removes a user from all teams of an organization.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#remove-an-organization-member
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) RemoveMember ( ctx context . Context , org , user string ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/members/%v" , org , user )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}
// PublicizeMembership publicizes a user's membership in an organization. (A
// user cannot publicize the membership for another user.)
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#set-public-organization-membership-for-the-authenticated-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) PublicizeMembership ( ctx context . Context , org , user string ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/public_members/%v" , org , user )
req , err := s . client . NewRequest ( "PUT" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}
// ConcealMembership conceals a user's membership in an organization.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#remove-public-organization-membership-for-the-authenticated-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) ConcealMembership ( ctx context . Context , org , user string ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/public_members/%v" , org , user )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}
// ListOrgMembershipsOptions specifies optional parameters to the
// OrganizationsService.ListOrgMemberships method.
type ListOrgMembershipsOptions struct {
// Filter memberships to include only those with the specified state.
// Possible values are: "active", "pending".
State string ` url:"state,omitempty" `
ListOptions
}
// ListOrgMemberships lists the organization memberships for the authenticated user.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#list-organization-memberships-for-the-authenticated-user
2020-07-31 19:52:34 +05:30
func ( s * OrganizationsService ) ListOrgMemberships ( ctx context . Context , opts * ListOrgMembershipsOptions ) ( [ ] * Membership , * Response , error ) {
2019-05-07 06:42:51 +05:30
u := "user/memberships/orgs"
2020-07-31 19:52:34 +05:30
u , err := addOptions ( u , opts )
2019-05-07 06:42:51 +05:30
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var memberships [ ] * Membership
resp , err := s . client . Do ( ctx , req , & memberships )
if err != nil {
return nil , resp , err
}
return memberships , resp , nil
}
// GetOrgMembership gets the membership for a user in a specified organization.
// Passing an empty string for user will get the membership for the
// authenticated user.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#get-an-organization-membership-for-the-authenticated-user
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#get-organization-membership-for-a-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) GetOrgMembership ( ctx context . Context , user , org string ) ( * Membership , * Response , error ) {
var u string
if user != "" {
u = fmt . Sprintf ( "orgs/%v/memberships/%v" , org , user )
} else {
u = fmt . Sprintf ( "user/memberships/orgs/%v" , org )
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
membership := new ( Membership )
resp , err := s . client . Do ( ctx , req , membership )
if err != nil {
return nil , resp , err
}
return membership , resp , nil
}
// EditOrgMembership edits the membership for user in specified organization.
// Passing an empty string for user will edit the membership for the
// authenticated user.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#update-an-organization-membership-for-the-authenticated-user
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#set-organization-membership-for-a-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) EditOrgMembership ( ctx context . Context , user , org string , membership * Membership ) ( * Membership , * Response , error ) {
var u , method string
if user != "" {
u = fmt . Sprintf ( "orgs/%v/memberships/%v" , org , user )
method = "PUT"
} else {
u = fmt . Sprintf ( "user/memberships/orgs/%v" , org )
method = "PATCH"
}
req , err := s . client . NewRequest ( method , u , membership )
if err != nil {
return nil , nil , err
}
m := new ( Membership )
resp , err := s . client . Do ( ctx , req , m )
if err != nil {
return nil , resp , err
}
return m , resp , nil
}
// RemoveOrgMembership removes user from the specified organization. If the
// user has been invited to the organization, this will cancel their invitation.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#remove-organization-membership-for-a-user
2019-05-07 06:42:51 +05:30
func ( s * OrganizationsService ) RemoveOrgMembership ( ctx context . Context , user , org string ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/memberships/%v" , org , user )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}
// ListPendingOrgInvitations returns a list of pending invitations.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#list-pending-organization-invitations
2020-07-31 19:52:34 +05:30
func ( s * OrganizationsService ) ListPendingOrgInvitations ( ctx context . Context , org string , opts * ListOptions ) ( [ ] * Invitation , * Response , error ) {
2019-05-07 06:42:51 +05:30
u := fmt . Sprintf ( "orgs/%v/invitations" , org )
2020-07-31 19:52:34 +05:30
u , err := addOptions ( u , opts )
2019-05-07 06:42:51 +05:30
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var pendingInvitations [ ] * Invitation
resp , err := s . client . Do ( ctx , req , & pendingInvitations )
if err != nil {
return nil , resp , err
}
return pendingInvitations , resp , nil
}
// CreateOrgInvitationOptions specifies the parameters to the OrganizationService.Invite
// method.
type CreateOrgInvitationOptions struct {
// GitHub user ID for the person you are inviting. Not required if you provide Email.
InviteeID * int64 ` json:"invitee_id,omitempty" `
// Email address of the person you are inviting, which can be an existing GitHub user.
// Not required if you provide InviteeID
Email * string ` json:"email,omitempty" `
// Specify role for new member. Can be one of:
// * admin - Organization owners with full administrative rights to the
// organization and complete access to all repositories and teams.
// * direct_member - Non-owner organization members with ability to see
// other members and join teams by invitation.
// * billing_manager - Non-owner organization members with ability to
// manage the billing settings of your organization.
// Default is "direct_member".
Role * string ` json:"role" `
TeamID [ ] int64 ` json:"team_ids" `
}
// CreateOrgInvitation invites people to an organization by using their GitHub user ID or their email address.
// In order to create invitations in an organization,
// the authenticated user must be an organization owner.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#create-an-organization-invitation
2020-07-31 19:52:34 +05:30
func ( s * OrganizationsService ) CreateOrgInvitation ( ctx context . Context , org string , opts * CreateOrgInvitationOptions ) ( * Invitation , * Response , error ) {
2019-05-07 06:42:51 +05:30
u := fmt . Sprintf ( "orgs/%v/invitations" , org )
2020-07-31 19:52:34 +05:30
req , err := s . client . NewRequest ( "POST" , u , opts )
2019-05-07 06:42:51 +05:30
if err != nil {
return nil , nil , err
}
var invitation * Invitation
resp , err := s . client . Do ( ctx , req , & invitation )
if err != nil {
return nil , resp , err
}
return invitation , resp , nil
}
// ListOrgInvitationTeams lists all teams associated with an invitation. In order to see invitations in an organization,
// the authenticated user must be an organization owner.
//
2021-08-10 15:19:43 +05:30
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/orgs/#list-organization-invitation-teams
2020-07-31 19:52:34 +05:30
func ( s * OrganizationsService ) ListOrgInvitationTeams ( ctx context . Context , org , invitationID string , opts * ListOptions ) ( [ ] * Team , * Response , error ) {
2019-05-07 06:42:51 +05:30
u := fmt . Sprintf ( "orgs/%v/invitations/%v/teams" , org , invitationID )
2020-07-31 19:52:34 +05:30
u , err := addOptions ( u , opts )
2019-05-07 06:42:51 +05:30
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var orgInvitationTeams [ ] * Team
resp , err := s . client . Do ( ctx , req , & orgInvitationTeams )
if err != nil {
return nil , resp , err
}
return orgInvitationTeams , resp , nil
}
2021-08-10 15:19:43 +05:30
// ListFailedOrgInvitations returns a list of failed inviatations.
//
// GitHub API docs: https://docs.github.com/en/rest/reference/orgs#list-failed-organization-invitations
func ( s * OrganizationsService ) ListFailedOrgInvitations ( ctx context . Context , org string , opts * ListOptions ) ( [ ] * Invitation , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/failed_invitations" , org )
u , err := addOptions ( u , opts )
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var failedInvitations [ ] * Invitation
resp , err := s . client . Do ( ctx , req , & failedInvitations )
if err != nil {
return nil , resp , err
}
return failedInvitations , resp , nil
}