简体   繁体   English

将用户添加到组织存储库github API

[英]Add user to organization repository github API

I'm trying to add multiple users to a team in a private group team using curl and the github API. 我正在尝试使用curl和github API将多个用户添加到私有组团队中的团队。 However, something is off with my syntax and I'm not sure what it is. 但是,我的语法有些不对劲,我不确定它是什么。

I've tried: 我试过了:

curl --user "groupowner:password" -X PUT -d "" "https://api.github.com/orgs/ORGNAME/teams/TEAMNAME/members/USERNAMETOBEADDED/"

The github documentation, eg, here is helpful, but I'm missing something.Looking here it seems that another syntax may be possible. github文档,例如, 这里是有帮助的,但我遗漏了一些东西。 在这里看来似乎可能有另一种语法。

摆脱尾部斜杠并使用团队成员资格API应该可以解决问题:

curl --user "groupowner:password" -X PUT -d "" "https://api.github.com/teams/TEAMID/memberships/USERNAMETOBEADDED"

OAuth, Organizations, etc. OAuth,组织等

Building on the answer from Hans Z. I'll show you how to invite an email address to join an organization and assign them to a team, all in one shot. 以Hans Z的答案为基础。我将向您展示如何邀请一个电子邮件地址加入一个组织并将其分配给一个团队。 You will also notice that I use an OAuth "Personal Access" Token header instead of a username and password. 您还会注意到我使用OAuth“个人访问”令牌标头而不是用户名和密码。 You can (and should) do this whether you are acting as an organization or a personal account holder. 无论您是作为组织还是个人账户持有人,您都可以(而且应该)这样做

# Assuming you have `export GITHUB_OAUTH_TOKEN=...` in your .bash_profile

# Define inputs
email="user@example.com"
org_name=DecaturMakers
team_name=Administrators

# Derive request data
team_id="$(
    curl -s                                                               \
         -H "Authorization: token $GITHUB_OAUTH_TOKEN"                    \
         "https://api.github.com/orgs/$org_name/teams"                   |\
      jq 'map(select(.name=="'$team_name'")) | .[].id'
)"
json='{
  "role": "direct_member",
  "team_ids":['$team_id'],
  "email":"'$email'"
}'

# Send invitation
curl -s                                                                   \
     -H "Authorization: token $GITHUB_OAUTH_TOKEN"                        \
     -H "Accept: application/vnd.github.dazzler-preview+json"             \
     -d "$json"                                                           \
     "https://api.github.com/orgs/$org_name/invitations"

output 产量

{
  "id": 12345678,
  "node_id": "MDIyOk9yZ2FuaXphdGlvbkludml0YXRpb24xNjcwNTEwNg==",
  "login": null,
  "email": "user@example.com",
  "role": "direct_member",
  "created_at": "2019-08-20T20:53:49Z",
  "inviter": {
    "login": "RichardBronosky",
    "id": 12345,
    "node_id": "MDQ6VXNlcjEzNjIw",
    "avatar_url": "https://avatars3.githubusercontent.com/u/12345?v=4",
    "gravatar_id": "",
    "url": "https://api.github.com/users/RichardBronosky",
    "html_url": "https://github.com/RichardBronosky",
    "followers_url": "https://api.github.com/users/RichardBronosky/followers",
    "following_url": "https://api.github.com/users/RichardBronosky/following{/other_user}",
    "gists_url": "https://api.github.com/users/RichardBronosky/gists{/gist_id}",
    "starred_url": "https://api.github.com/users/RichardBronosky/starred{/owner}{/repo}",
    "subscriptions_url": "https://api.github.com/users/RichardBronosky/subscriptions",
    "organizations_url": "https://api.github.com/users/RichardBronosky/orgs",
    "repos_url": "https://api.github.com/users/RichardBronosky/repos",
    "events_url": "https://api.github.com/users/RichardBronosky/events{/privacy}",
    "received_events_url": "https://api.github.com/users/RichardBronosky/received_events",
    "type": "User",
    "site_admin": false
  },
  "team_count": 1,
  "invitation_teams_url": "https://api.github.com/organizations/01234567/invitations/12345678/teams"
}

You may notice the extra header in the curl that sends the invitation. 您可能会注意到发送邀请的curl中的额外标头。 That is explained here . 这在这里解释

Bonus 奖金

Get pending invitations for an organization : 获取组织的待处理邀请

(You can use this to verify the results of the command above.) (您可以使用它来验证上面命令的结果。)

# Verify results
curl -s                                                                   \
     -H "Authorization: token $GITHUB_OAUTH_TOKEN"                        \
      "https://api.github.com/orgs/$org_name/invitations"                |\
  jq '[.[].email]'

output 产量

[
  "user@example.com",
  "previous_user@example.com"
]

Get the teams for an organization : 获取组织的团队

org_name=DecaturMakers
curl -sH "Authorization: token $GITHUB_OAUTH_TOKEN"   \
     "https://api.github.com/orgs/$org_name/teams"

output 产量

[
  {
    "name": "Administrators",
    "id": 123456,
    "node_id": "H4ShH4ShH4ShH4ShH4==",
    "slug": "administrators",
    "description": null,
    "privacy": "secret",
    "url": "https://api.github.com/teams/123456",
    "html_url": "https://github.com/orgs/DecaturMakers/teams/administrators",
    "members_url": "https://api.github.com/teams/123456/members{/member}",
    "repositories_url": "https://api.github.com/teams/123456/repos",
    "permission": "pull"
  }
]

Filter out the id of a team in an organization: 过滤掉组织中团队的ID

team_name=Administrators
curl -sH "Authorization: token $GITHUB_OAUTH_TOKEN"   \
     "https://api.github.com/orgs/$org_name/teams"   |\
     jq 'map(select(.name=="'$team_name'")) | .[].id'

output 产量

123456

Get orgs you are a member of: 获取orgs您是以下成员:

curl -sH "Authorization: token $GITHUB_OAUTH_TOKEN"   \
     "https://api.github.com/user/orgs"

output 产量

[
  {
    "login": "DecaturMakers",
    "id": 1234567,
    "node_id": "H4ShH4ShH4ShH4ShH4ShH4ShH4ShH4S=",
    "url": "https://api.github.com/orgs/DecaturMakers",
    "repos_url": "https://api.github.com/orgs/DecaturMakers/repos",
    "events_url": "https://api.github.com/orgs/DecaturMakers/events",
    "hooks_url": "https://api.github.com/orgs/DecaturMakers/hooks",
    "issues_url": "https://api.github.com/orgs/DecaturMakers/issues",
    "members_url": "https://api.github.com/orgs/DecaturMakers/members{/member}",
    "public_members_url": "https://api.github.com/orgs/DecaturMakers/public_members{/member}",
    "avatar_url": "https://avatars1.githubusercontent.com/u/1234567?v=4",
    "description": "Code projects associated with Decatur Makers"
  }
]

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM