Git 学习笔记:6 GitHub

Git 学习笔记:6 GitHub

  • 账户的 创建和配置
    • SSH访问
    • 头像
    • 邮件地址
    • 两步验证
  • 对项目做贡献
    • 派生(fork)项目
    • GitHub 流程
      • 创建合并请求
      • 利用合并请求
    • 合并请求的进阶用法
      • 将合并请求制作成补丁
      • 与上游保持同步
      • 参考
      • Markdown
      • GitHub 风格的 Markdown
  • 维护项目
    • 创建新的版本仓库
    • 添加合作者
    • 管理合并请求
      • 邮件通知
      • 在合并请求上进行合作
      • 合并请求引用
      • 合并请求之上的合并请求
    • 提醒和通知
      • 网页通知
      • 邮件通知
    • 特殊文件
      • README
      • 贡献 CONTRIBUTING
    • 项目管理
      • 改变默认分支
      • 移交项目
  • 管理组织
    • 组织的基本知识
    • 团队
    • 审计日志
  • 脚本 GitHub
    • 钩子
    • 服务
    • 钩子
    • GitHub API
      • 基本用途
      • 在一个问题上评论
      • 修改Pull Request 的状态
    • Octokit

账户的 创建和配置

GitHub是最大的 Git 版本库托管商,是成千上万的开发者和项目能够合作进行的中心。大部分 Git 版本库都托管在 GitHub 上,很多开源项目使用 GitHub 实现 GIt 托管、问题追踪、代码审查以及其它事情。所以,尽管这不是 Git 开源项目的直接部分,但如果想要 专业地使用 Git ,你将不可避免地与 GitHub 打交道,所以这依然是一个绝好的学习机会。

你所需要做的第一件事就是创建一个免费账户。直接访问 https://github.com,选择一个未被占用的用户名,提供一个电子邮件地址和密码,点击写着 “Sign up for GitHub” 的绿色大按钮即可。

Git 学习笔记:6 GitHub_第1张图片
你将看到的下一个页面是升级计划的价格页面,目前我们可以直接忽略这个页面。GitHub 会给你提供的电子邮件发送一封邮件。尽快到你的邮箱进行验证,这是非常重要的。

注意:GitHub 为免费账户提供了完整功能,限制是你的项目都将被完全公开(每个人都具有读权限)。GitHub 的付费计划可以让你拥有一定数目的私有项目。

SSH访问

现在,你完全可以使用 https:// 协议,通过你刚刚创建的用户名和密码访问 Git 版本库。但是,如果仅仅克隆共有项目,你甚至不需要注册——刚刚我们创建的账户是为了以后fork 其他项目,以及推送我们自己的修改。

如果你习惯使用SSH 远程,你需要配置一个公钥。(如果你没有公钥,请参考 生成 SSH 公钥)使用窗口右上角的链接打开你的账户设置:

Git 学习笔记:6 GitHub_第2张图片
然后在左侧选择 “SSH keys” 部分。

Git 学习笔记:6 GitHub_第3张图片
在这个页面点击 “Add an SSH key”按钮,给你的公钥起一个名字,将你的 ~/.ssh/id_rsa.pub(或者自定义的其他名字)公钥文件的内容粘贴到文本区,然后点击“Add key”

注意:确保给你的SSH密钥起一个能够记得住的名字。你可以为每一个密钥起名字(例如,我的笔记本电脑或者 工作账户等),一遍以后需要吊销密钥时能够方便区分。

头像

下一步,如果愿意的话,你可以将生成的头像换成你喜欢的图片。首先,来到“Profile”标签页(在 “SSH Keys”标签页上方),点击“upload new picture”。

Git 学习笔记:6 GitHub_第4张图片

我们选择了本地磁盘上的一个 Git 图标,上传之后还可以对其进行裁剪。

Git 学习笔记:6 GitHub_第5张图片
现在,在网站任意由你参与的位置,人们都可以在你的用户名旁边看到你的头像。

如果你已经把头像上传到了流行的Gravatar 托管服务(Wordpress账户经常使用),默认就会使用这个头像,因此,见你就不需要进行这一步骤了。

邮件地址

GitHub 使用用户邮件地址区分 Git 提交。如果你在自己的提交中使用了多个邮件地址,希望 Git Hub 可以正确地将它们连接起来,你需要在管理页面的Emails 部分添加你拥有的所有邮箱地址。

Git 学习笔记:6 GitHub_第6张图片
在 添加邮件地址 中我们可以看到一些不同的状态。顶部的地址是通过验证的,并且被设置为主要地址,这意味着该地址会接收到所有的通知和回复。第二个地址是通过验证的,如果 愿意的话,可以将其设置为主要地址。最后一个地址是未通过验证的,这意味着你不能将其设置为主要地址。当 GitHub 发现任意版本库中的任意提交信息包含了这些地址,它就会将其链接到你的账户。

两步验证

最后,为了额外的安全性,你绝对应当设置两步验证,简写为 “2FA”。两步验证是一种用于降低因你的密码被盗而带来的账户风险的验证机制,现在已经变得越来越流行。开启两步验证,GitHub会要求你用两种不同的验证方法,这样,即使其中一个被攻破,攻击者也不能访问你的账户。

你可以在 Account setting 页面的 Security 标签页中找到 Two-factor Authentication 设置。

Git 学习笔记:6 GitHub_第7张图片

点击 Set up two-factor authentication 按钮,会跳转到设置页面。该页面允许你选择是要在登录时使用手机app 生成辅助码,还是要GitHub 通过 SMS 发送辅助码。

选择合适的方法后,按照提示步骤设置 2FA , 你的账户会变得安全,每次登录 GitHub 时都需要提供除密码外的辅助码。

对项目做贡献

账户建立好了,现在我们来了解一些能帮助你对现有的项目做出贡献的知识。

派生(fork)项目

如果你想要参与某个项目,但是并没有推送权限,这时可以对这个项目进行“派生”。派生的意思是指,GitHub 将在你的空间中创建一个完全属于你的项目副本,且你对其具有推送权限。

注意:在以前,“fork”是一个贬义词,指的是某个人使开源项目向不同的方向发展,或者创建一个竞争项目,使得原项目的贡献者分裂。在GitHub,“fork”使的是你自己的空间中创建的项目副本,这个副本允许你以一种更开放对其进行修改。

通过这种方式,项目的管理者不在需要忙着把用户添加到贡献者列表并给予他们推送权限。人们合一派生这个项目,将修改推送到派生出的项目副本中,并通过创建合并请求(Pull Request)来让他们的改动进入原版本库,下文我们会详细说明。创建了合并请求后,就会开启一个可供审查代码的板块,项目的拥有者和贡献者可以在此讨论修改,直到此昂木拥有者对其感到满意,并且认为这些修改可以合并到版本库。

你可以通过点击项目页面右上角的“Fork”按钮,来派生这个项目。

在这里插入图片描述

稍等片刻,你将被转到新项目页面,该项目包含可写的代码副本。

GitHub 流程

GitHub 设计了一个以合并请求为中心的特殊合作流程。它基于我们在Git 分支上的特性分支中提到的工作流程。不管你是在一个紧密的团队中使用单独的版本库,或者使用许多的“Fork” 来为一个由陌生人组成的国际企业或网络做出贡献,这种合作流程都能应付。

流程通常如下:

  1. 从 master 分支中创建一个新分支
  2. 提交一些修改来改进项目
  3. 将这个分支推送到 GitHub 上
  4. 创建一个合并请求
  5. 讨论,根据实际情况继续修改
  6. 项目的拥有者合并或关闭你的合并请求

这基本和 集成管理者工作流 中的一体化管理流程差不多,但是团队可以使用 GItHub 提供的网页工具替代电子邮件来交流和审查修改。

现在我们来看一个使用这个流程的例子。

创建合并请求

Tony 在找一些能在他的Arduino 微控制器上运行的代码,他觉得 https://github.com/schacon/blink 中的代码不错。
Git 学习笔记:6 GitHub_第8张图片

但是有个问题,这个代码中的闪烁频率太高,我们觉得 3秒一次比 1秒一次更好一些。所以让我们来改进这个程序,并将修改后的代码提交给这个项目。

首先,单击 “Fork” 按钮来获得这个项目的副本。我们使用的用户名是 “Tonychacon”,所以这个项目副本的访问地址是: https://github.com/tonychacon/blink 。我们将它克隆到本地,创建一个分支,修改代码,最后将改动推送到 GitHub。

$ git clone https://github.com/tonychacon/blink (1)
Cloning into 'blink'...

$ cd blink
$ git checkout -b slow-blink (2)
Switched to a new branch 'slow-blink'

$ sed -i '' 's/1000/3000/' blink.ino (3)

$ git diff --word-diff (4)
diff --git a/blink.ino b/blink.ino
index 15b9911..a6cc5a5 100644
--- a/blink.ino
+++ b/blink.ino
@@ -18,7 +18,7 @@ void setup() {
// the loop routine runs over and over again forever:
void loop() {
  digitalWrite(led, HIGH);   // turn the LED on (HIGH is the voltage level)
  [-delay(1000);-]{+delay(3000);+}               // wait for a second
  digitalWrite(led, LOW);    // turn the LED off by making the voltage LOW
  [-delay(1000);-]{+delay(3000);+}               // wait for a second
}

$ git commit -a -m 'three seconds is better' (5)
[slow-blink 5ca509d] three seconds is better
 1 file changed, 2 insertions(+), 2 deletions(-)

$ git push origin slow-blink (6)
Username for 'https://github.com': tonychacon
Password for 'https://[email protected]':
Counting objects: 5, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 340 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
To https://github.com/tonychacon/blink
 * [new branch]      slow-blink -> slow-blink
  1. 将派生出的副本克隆到本地
  2. 创建出名称有意义的分支
  3. 修改代码
  4. 检查代码
  5. 将改动提交到分支中
  6. 将新分支推送到 GitHub 的副本中

现在到GitHub 上查看之前的项目副本,可以看到 GItHub 提示我们有新的分支,并且显示了一个大大的绿色按钮让我们可以检查我们的改动,并给源项目创建合并请求。

你也可以到 “Branches” 页面查看分支并创建合并请求:https://github.com/<用户名>/<项目名>/branches

Git 学习笔记:6 GitHub_第9张图片
如果你点击了那个绿色按钮,就会看到一个新页面,在这里我么可以对改动填写标题和描述,让项目的拥有者考虑一下我们的改动。通常花点时间来编写个清晰有用的描述是个不错的主意,这能让作者明白为什么这个改动可以给他的项目带来好处,并且他接受合并请求。

同时我们也能看到比主分支中所“领先”(ahead)的提交以及所有将会被合并的改动与之前代码的对比。

Git 学习笔记:6 GitHub_第10张图片
当你点击了 “Create pull request”(创建合并请求)的按钮后,这个项目的拥有者将会收到一条包含该改动和合并请求的链接和提醒。

注意:虽然合并请求通常是在贡献者准备好在公开项目中提交改动的时候提交,到那时也常被用在仍处于开发阶段的内部项目中。因为合并请求在提交后 依然可以加入新的改动,他也经常被用来建立团队合作的环境,而不只是在最终阶段使用。

利用合并请求

现在,项目的拥有者可以看到你的改动并合并它,拒绝它或者是发表评论。在这里我们就当作他喜欢这个点子,但是他想要让熄灭的时间比点亮的时间稍长一些。

接下来可能通过电子邮件进行互动,就像我们在 分支式 Git 中提到的工作流程那样,但是在 GitHub ,这些都在线上完成。项目的拥有者可以审查修改,只需要点击某一行,就可以对其发表评论。

Git 学习笔记:6 GitHub_第11张图片
当维护者发表评论后,提交合并请求的人,以及所有正在关注(Watching)这个版本库的用户都会收到通知。我们待会儿将会告诉你如何修改这项这项设置。现在如果 Tony 有开启电子邮件提醒,它将会收到这样的一封这样的邮件:

Git 学习笔记:6 GitHub_第12张图片

每个人都能在合并请求中发表评论。在 合并请求讨论页面 里我们可以看到项目拥有者对某行到吗发表评论,并在讨论区留下了一个普通评论。你可以看到被评论的代码也会在互动中显示出来。

Git 学习笔记:6 GitHub_第13张图片
现在贡献者可以看到如何做才能让他们的改动被接受。幸运的是,这也是一件轻松的事情。如果你使用的是电子邮件进行交流,你需要再次对代码进行修改并重新提交至邮件列表,在GitHub 上,你只需要再次提交到你的分支中并推送即可。

如果贡献者完成了以上的操作,项目的拥有者会再次收到提醒,当他们查看页面时,将会看到最新的改动。事实上,只要提交中有一行代码改动,GitHub 都会注意到并处理掉旧的变更集。

Git 学习笔记:6 GitHub_第14张图片

如果你点开合并请求的“Files Changed” (更改的文件)选项卡,你将会看到“整理过的”差异表——也就是这个分支被合并到主分支之后将会产生的所有改动,其实就是 git diff master …<分支名> 命令的执行结果。你可以浏览 确定引入了哪些东西 莱里阿杰更多关于差异的知识。

你还会注意到,GitHub 会检查你的合并请求是否直接合并,如果可以,将会提供一个按钮来进行合并操作。这个按钮只在你对版本库有写入权限并且可以进行简洁合并时才会显示。你点击后 GitHub 将做出一个“非快进式”(non-fast-forward)合并,即使这个合并 能够 快进式(fast-forward)合并,GitHub 依然会创建一个合并请求。

如果你需要,你好可以将分支拉取并在本地合并。如果你将这个分支合并到 master 分支中并推送到 GitHub ,这个合并回请求会被自动关闭。

这就是大部分 GitHub 项目使用的工作流程。创建分支,基于分支创建合并请求,进行讨论,根据需要继续在分支上进行修改,最终关闭或合并合并请求。

注意:不必总是 Fork。有件很重要的事情:你可以在一个版本库中的不同分支提交合并请求。如果你正在和某人实现某个功能,而且你对项目有写权限,你可以推动分支到版本库,并在 master 分支提交一个合并请求并在此进行代码审查和讨论的操作。不需要进行“Fork”。

合并请求的进阶用法

目前,我们学到了如何在GitHub平台对 一个项目进行最基础的贡献。现在我们会教给你一些小技巧,让你可以更加有效率地使用合并请求。

将合并请求制作成补丁

有一件重要的事情:许多项目并不认为合并请求可以作为补丁,就和通过邮件列表工作的项目对补丁贡献的看法一样。大多数的GitHub 项目将合并请求的分支当做改动的交流方式,并将变更集合起来统一进行合并。

这是个总要的了差异,因为一般来说改动会在代码完成前提出,这和基于邮件列表的补丁贡献者有着天差地别。这使得维护者们可以更早的沟通,由社区中的力量能提出更好的方案。当有人从合并请求提交了一些代码,并且维护者和社区提出了一些意见,这个补丁系列并不需要从头来过,只需要将改动重新提交并推送到分支中,这使得讨论的背景和过程可以齐头并进。

举个例子,你可以回去看看 最终的合并请求,你会注意到工资按者没有变基他的提交再提交一个新的合并请求,而知直接增加了新的提交并推送到已有的分支中。如果你之后再回去查看这个合并请求,你可以轻松地 找到这个修改的原因。点击网页上的“Merge”(合并)按钮后,会建立一个合并提交并指向这个合并请求,你就可以很轻松的研究原来的讨论内容。

与上游保持同步

如果你的合并请求由于过时或其他原因不能干净地合并,你需要进行修复才能让维护者对其进行合并。 GitHub 会对每个提交进行测试,让你知道你的合并请求能否简洁的合并。
在这里插入图片描述
如果你看到了像 不能进行干净合并 中的画面,你就需要修复你的分支让这个提示变成绿色,这样维护者就不需要再做额外的工作。

你有两种方法来解决这个问题。你可以把你的分支变基到目标分支中去(通常是你派生出的版本库中的 master 分支),或者你可以合并目标分支到你的分支中去。

GItHub 上的大多数的开发者会使用后一个方法,基于我们在上一节提到的理由:我们最看重的是历史记录和最后的合并,变基除了给你带来看上去简洁的历史记录,只会让你的工作变得更加困难且容易犯错。

如果你想要合并目标分支来让你的合并请求变得可合并,你需要将源版本库添加为一个新的远端,并从远端抓取内容,合并主分支的内容到你的分支中去,修复所有的问题并最终重新推送回你提交合并请求使用的分支。

在这个例子中,我们在此使用之前的 “tonychacon”童虎来进行示范,源作者提交了一个改动,使得合并请求和它产生了冲突,现在来看我们解决这个问题的步骤。

$ git remote add upstream https://github.com/schacon/blink (1)

$ git fetch upstream (2)
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (3/3), done.
Unpacking objects: 100% (3/3), done.
remote: Total 3 (delta 0), reused 0 (delta 0)
From https://github.com/schacon/blink
 * [new branch]      master     -> upstream/master

$ git merge upstream/master (3)
Auto-merging blink.ino
CONFLICT (content): Merge conflict in blink.ino
Automatic merge failed; fix conflicts and then commit the result.

$ vim blink.ino (4)
$ git add blink.ino
$ git commit
[slow-blink 3c8d735] Merge remote-tracking branch 'upstream/master' \
    into slower-blink

$ git push origin slow-blink (5)
Counting objects: 6, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (6/6), done.
Writing objects: 100% (6/6), 682 bytes | 0 bytes/s, done.
Total 6 (delta 2), reused 0 (delta 0)
To https://github.com/tonychacon/blink
   ef4725c..3c8d735  slower-blink -> slow-blink
  1. 将源版本库添加为一个远端,并命名为“upstream”(上游)
  2. 从远端榨取最新内容
  3. 将主分支的内容合并到你的分支中
  4. 修复产生的冲突
  5. 再推送回同一个分支

你完成了上面的步骤后,合并请求将会自动更新并冲洗检查是否能干净的合并。

Git 学习笔记:6 GitHub_第15张图片
Git 的伟大之处就是你可以一直重复以上操作。如果你有一个运行了十分久的项目,你可以轻松地合并目标分支且只需要处理最近的一次冲突,这使得管理流程更加容易。

如果你一定想对分支做变基操作并进行清理,你可以这么做,但是强烈建议你不要强行的提交到已经提交了合并请求的分支。如果其他人拉去了这个分支井进行一些修改,你将会遇到 变基的风险 中提到的问题。相对的,将变基后的分支推动到 GitHub 上的一个新分支中并创建一个全新的合并请求引用旧的合并请求,然后关闭旧的合并请求。

参考

你的下个问题可能是 “我该如何引用旧的合并请求?”。有许多方法可以让你在 GitHub 上的几乎任何地方引用其他东西。

先从如何对合并请求会议题(Issue)进行相互引用开始。所有的合并请求和议题在项目中都会有一个独一无二的编号。举个例子,你无法同时拥有3 好合并请求 和3 号议题。如果你想要引用任何一个合并请求或议题,你只需要在提交或描述中 输入 #编号 即可。你也可以指定引用其他版本库的议题或合并请求,如果你想要引用其他人对该版本库的“Fork” 中的议题或合并请求,输入 用户名#编号,如果在不同的版本库中,输入 用户名/版本库#编号。

我们来看一个例子。假设我们对上个例子中的分支进行了变基,并为此创建了一个新的合并请求,现在我们希望能在新的合并请求中引用旧的合并请求。我们同时希望引用一个派生出的项目中的议题和一个完全不同的项目中的议题,就可以这样填写描述。

Git 学习笔记:6 GitHub_第16张图片
当我们提交了这个合并请求,我们将会看到以上内容被渲染成这样:

Git 学习笔记:6 GitHub_第17张图片
你会注意到完整的 GitHub 地址被简化了,只留下了必要的信息。

如果 Tony 回去关闭了源合并请求,我们可以看到一个被引用的提示,GitHub 会自动的反向追踪时间并显示在合并请求的时间轴上。这意味着任何查看这个合并请求的人可以轻松地访问新的合并请求。这个链接是这样展示的:

Git 学习笔记:6 GitHub_第18张图片
除了议题编号外,你还可以通过使用提交的 SHA-1 来引用提交。你必须完整的写出 40位 长的SHA,GitHub 会在评论中自动地产生指向这个提交的链接。同样的,你可以像引用议题一样对 “Fork”出的项目中的提交或者其他项目中的提交进行引用。

Markdown

对于在 GitHub 中绝大多数文本框中能够做到的事,引用其他议题只是个开始。在议题和合并请求的描述,评论和代码评论还有其他地方,都可以使用 “GitHub 风格的 Markdown”。Markdown 可以让你输入纯文本,但是渲染出丰富的内容。

查看 下面的例子 来了解如何写评论或文本,并通过 Markdown 进行渲染。

Git 学习笔记:6 GitHub_第19张图片

GitHub 风格的 Markdown

GitHub 风格的 Markdown 增加了一些基础的 Markdown 中做不到的东西。他在创建合并请求和议题中的评论和描述时十分有用。

任务列表

第一个 GitHub 专属的 Markdown 功能,特别是用在合并请求中,就是任务列表。一个任务列表可以展示出了一系列你想要完成的事情,并带有复选框。把它们放在议题或合并请求中时,通常可以展示你想要完成的事情。

你可以这样创建一个任务列表

- [X] 编写代码
- [ ] 编写所有测试程序
- [ ] 为代码编写文档

如果我们将这个列表加入合并请求或议题的描述中,它将会被渲染 成这样:

Git 学习笔记:6 GitHub_第20张图片
在合并请求中,任务列表经常被用来在合并之前展示这个分支要完成的事情,最酷的地方就是,你只需要点击复选框,就能更新评论——你不需要直接修改 Markdown。

不仅如此,GitHub 还会将你在议题和合并请求中的任务列表整理起来集中展示。举个例子,如果你在一个合并请求中有任务清单,你将会在所有合并请求的总览页面上看到它的进度。这使得人们可以把一个合并请求分解成不同的小任务,同时便于其他人了解分支的进度。
Git 学习笔记:6 GitHub_第21张图片

当你在实现一个任务的早期就提交合并请求,并使用任务清单追踪你的进度,这个功能会十分的有用。

摘录代码

你也可以在评论中摘录代码。这在你想要展示尚未提交到分支中的代码时十分有用。它也经常被用在展示无法正常工作的代码或这个合并请求需要的代码。

你需要用“反引号”将需要添加的摘录代码包起来。

```java
for(int i=0 ; i < 5 ; i++)
{
   System.out.println("i is : " + i);
}
```

如果你加入语言的名称,就像我们这里加入的java 一样,GitHub 会自动尝试对摘录的片段进行语法高亮。在下面的例子中,他最终会渲染成这个样子:

Git 学习笔记:6 GitHub_第22张图片

引用

如果你在回复一个很长的评论之中的一小段,你只需要复制你需要的片段,并在每行前添加>符号即可。事实上,因为这个功能会被经常使用,他也有一个快捷键。只要你把你要回应的文字选中,并按下 r 键,选中的问题会自动引用并填入评论框。

引用的部分就像是这样:

> Whether 'tis Nobler in the mind to suffer
> The Slings and Arrows of outrageous Fortune,

How big are these slings and in particular, these arrows?

讲过渲染后,就会变成这样:

Git 学习笔记:6 GitHub_第23张图片

表情符号(EMOJI)

最后,我们可以在评论中使用表情符号。这经常出现在GitHub 的议题和合并请求的评论中。GitHub 上甚至有表情助手。如果你在输入评论以:开头,自动完成器会帮助你找到你需要的表情。

Git 学习笔记:6 GitHub_第24张图片
你也可以在评论的任何地方使用:<表情名称>:来添加表情符号。举个例子,你可以输入以下文字:

I :eyes: that :bug: and I :cold_sweat:.

:trophy: for :microscope: it.

:+1: and :sparkles: on this :ship:, it's :fire::poop:!

:clap::tada::panda_face:

渲染之后,就会变成这样:
Git 学习笔记:6 GitHub_第25张图片
虽然这个功能并不是非常使用,但是它在这种不方便表达感情的媒体里,加入了趣味的元素。

注意:事实上现在已经有大量的在线服务可以使用表情符号,这里有个列表可以让你快速的找到能表达你的情绪的表情符号:http://www.emoji-cheat-sheet.com

图片

从技术层面来说,这并不是GitHub 风格Markdown 的功能,但是也很有用。如果不想使用 Marksown 语法来插入图片,GitHub 允许你通过 拖拽图片到文本区来插入图片。

Git 学习笔记:6 GitHub_第26张图片
如果你回去查看 在合并请求中的交叉引用 ,你活发现文本区上有个 “Parsed as Markdown”的提示。点击它你可以了解所有能在 GitHub 上使用的Markdown 功能。

维护项目

现在我们可以很方便地向一个项目贡献内容,来看一下另一个方面的内容:创建、维护和管理你自己的项目。

创建新的版本仓库

让我们创建一个版本库来分享我们的项目。用过点击面板右侧的“New repository”按钮,或者顶部工具条你用户名旁边的+ 按钮来开始我们的旅程。
Git 学习笔记:6 GitHub_第27张图片

这会带你到“new repository”表单:

Git 学习笔记:6 GitHub_第28张图片
这里除了一个你必须要填的项目名,其它字段都是可选的。现在只需要点击 “Create Repository”按钮,Duang!!!——你就在GitHub上拥有了一个以 / 命名的新仓库了。

因为目前暂无代码,GitHub 会显示有关创建新版本库或者关联到一个已有的 Git 版本库的一些说明。我们不会再这里详细说明此项,如果你需要复习,去看 Git 基础。

现在你的项目就托管在 GitHub 上了,你可以把URL 给任何人你想分享的人。GitHub 上的项目可通过 HTTP 或者 SSH 访问,格式是:HTTP : https://github.com// , SSH : [email protected]:/ 。 Git 可以通过以上两种 URL 进行抓取和推送,但是用户的访问权限又因连接时使用的证书不同而异。

注意:通常对于公开项目可以优先分享基于 HTTP 的URL,因为用户克隆项目不需要有一个GitHub 账号。如果你分享 SSH URL,用户必须有一个账号并且上传 SSH 密钥才能访问你的项目。HTTP URL 与你贴到浏览器里查看项目 用的地址是一样的。

添加合作者

如果你想与他人合作,并想给他们提交的权限,你需要把他们添加为 “Collaborators” 。如果Ben,Jeff,Louise 都在 GitHub上注册了,你想给他们推送的权限,你可以将他们添加到你的项目。这样做会给“推送”权限,就是说他们对项目和Git 版本库都有读写的权限。

点击边栏底部的“Settings” 链接。
Git 学习笔记:6 GitHub_第29张图片
然后从左侧菜单中选择 “Collaborators”。然后,在输入框中填写用户名,点击“Add collaborator”。如果你想授权给多个人,你可以多次重复这个步骤。如果你想收回权限,点击他们同一行右侧的“X”

Git 学习笔记:6 GitHub_第30张图片

管理合并请求

现在你有一个包含一些代码的项目,可能还有几个有推送权限的合作者,下面来看当你收到合并请求时该做什么。

合并请求可以来自仓库副本的一个分支,或者同一仓库的另一个分支。唯一的区别是 fork 过来的通常是和你不能互相推送的人,而内部的推送通常都可以互相访问。

作为例子,假设你是 “tonychacon”,你创建了一个名为 “fade”的 Arduino 项目。

邮件通知

有人来修改了你的代码,给你发了一个合并请求。你会收到一封关于合并请求的提醒邮件,它看起来像这样:

Git 学习笔记:6 GitHub_第31张图片
关于这个邮件有几个要注意的地方。它会给你一个小的变动统计结果——一个包含合并请求中改变的文件和改变了多少的列表。它还会给你一个 GitHub 上进行合并请求操作的链接。好友几个可以在命令行使用的 URL。

如果你注意到 git pull patch-1 这一行,这是一种合并远程分支的简单方式,无需必须添加一个远程分支。我们很快会在 检出远程分支 讲到它。如果你愿意,你可以创建并切换到一个主题分支,然后运行这个命令把合并请求合并进来。

还有一些有趣的 URL ,像 .diff 和 .patch,就像你猜的那样,它们提供 diff 和 patch 的标准版本。你可以技术性地用下面的方法合并请求

$ curl http://github.com/tonychacon/fade/pull/1.patch | git am

在合并请求上进行合作

就像我们在GitHub 流程 说过的,现在你可以跟开启合并的人进行会话。你既可以对某些代码添加注释,也可以对整个提交添加注释或对整个合并请求添加注释,在任何地方都可以用 GitHub Flavored Markdown。

每次有人在合并请求上进行注释你都会收到通知邮件,通知你哪里发生改变。他们都会包含一个到改变位置的链接,你可以直接在邮件中对合并请求进行注释。

Git 学习笔记:6 GitHub_第32张图片
一旦代码符合了你的要求,你想把它合并进来,你可以把代码拉取下来在本地进行合并,也可以用我们之前提到过的 git pull 语法,或者把 fork 添加为一个remote ,然后进行抓取和合并。

对于很琐碎的合并,你也可以用 GitHub 网站上的 “Merge” 按钮。它会做一个 “non-fast-froward” 合并,即使可以快进(fast-froward)合并也会产生一个合并提交记录。就是说无论如何,只要你点击 merge 按钮,就会产生一个合并提交记录。你可以在 看到,如果你点击提示连接,GitHub 会给你所有的这些信息。

Git 学习笔记:6 GitHub_第33张图片

如果你决定不合并它,你可以把合并请求关掉,开启合并请求的人会收到通知。

合并请求引用

如果你正在处理 许多 合并请求,不想添加一堆 remote 或者每次都要做一次拉取,这里有一个可以在 GitHub 上用的小技巧。这是有点高级的技巧,但它相当有用,我们会在 引用规格 有更多的细节说明。

实际上 GItHub 在服务器上把合并请求分支视为一种“假分支”。默认情况下你克隆时不会得到它们,但它们还是隐式地存在,你可以很容易地访问它们。

为了展示这个,我们要用到一个叫做 ls-remote 的低级命令。这命令在日常 GIt 操作操作中不会用到,但在现实服务器上有哪些引用是很管用。

如果在我们之前用过的“blink”版本库上使用这个命令,我们会得到一个版本库路所有的分支,标签和其它引用的列表

$ git ls-remote https://github.com/schacon/blink
10d539600d86723087810ec636870a504f4fee4d	HEAD
10d539600d86723087810ec636870a504f4fee4d	refs/heads/master
6a83107c62950be9453aac297bb0193fd743cd6e	refs/pull/1/head
afe83c2d1a70674c9505cc1d8b7d380d5e076ed3	refs/pull/1/merge
3c8d735ee16296c242be7a9742ebfbc2665adec1	refs/pull/2/head
15c9f4f80973a2758462ab2066b6ad9fe8dcf03d	refs/pull/2/merge
a5a7751a33b7e86c5e9bb07b26001bb17d775d1a	refs/pull/4/head
31a45fc257e8433c8d8804e3e848cf61c9d3166c	refs/pull/4/merge

当然,如果你爱你自己的版本库或其它你想检查的远程版本库中使用 git ls-remote origin ,它会显示相似的内容。

如果版本库在 GitHub 上并且有打开的合并请求,你会得到一些以 refs/pull 开头的引用。它们实际上是分支,但因为它们不在 refs/heads 中,所以正常情况下你克隆时不会从服务器上得到它们——抓取过程正常情况下会忽略它们。

每个合并请求有两个引用——其中以 /head 结尾的引用指向的提交记录与合并请求分支中的最后一个提交记录是同一个。所以如果有人在我们的版本库中开启了一个合并请求,他们的分支叫做 bug-fix ,指向 a5a775 这个提交记录,那么在我们的 版本库中我们没有 bug-fix 分支(因为那是在他们的 fork 中),但我们可以有一个 pull//head指向 a5a775 。这意味着我们可以 很容易滴拉取每一个合并请求分支而不用添加一堆 remote。

现在,你可以像这届抓取应用一样抓取哪些分支或提交。

$ git fetch origin refs/pull/958/head
From https://github.com/libgit2/libgit2
 * branch            refs/pull/958/head -> FETCH_HEAD

这告诉 Git :“连接到 origin 这个 remote,下载名字为 refs/pull/958/head 的引用” Git 高高兴去执行,下载构建那个引用需要的所有内容,然后把指针指向 .git/FETCH_HEAD 下面你想要的提交记录。然后你可以用 git merge FETCH_HEAD 把它合并到你想进行测试的分支,但那个合并的提交信息看起来有点怪。然而,如果你需要审查 一大批 合并请求,这样操作会很麻烦。

还有一种方法可以抓取 所有的合并请求 ,并且在你连接到远程(remote)的时候保持更新。用你喜欢的编辑器打开 .git/config,查找 origin 远程(remote)。看起来差不多像下面这样:

[remote "origin"]
    url = https://github.com/libgit2/libgit2
    fetch = +refs/heads/*:refs/remotes/origin/*

以 fetch= 开头的行是一个 “refspec” 它是一种把 remote 的名称映射到你本地 .git 目录的方法。这一条告诉GIt ,“remote 上 refs/heads” 下面的内容在我本地版本库中都放在 refs/remote/origin 。你可以把这一段修改一下,添加另一个 refspec:

[remote "origin"]
    url = https://github.com/libgit2/libgit2.git
    fetch = +refs/heads/*:refs/remotes/origin/*
    fetch = +refs/pull/*/head:refs/remotes/origin/pr/*

最后一行告诉 Git :所有看起来像 refs/pull/123/head 的引用应该在本地版本库像refs/remote/origin/pr/123 一样存储 。现在,如果你把偶才能那个文件,执行 git fetch:

$ git fetch
# …
 * [new ref]         refs/pull/1/head -> origin/pr/1
 * [new ref]         refs/pull/2/head -> origin/pr/2
 * [new ref]         refs/pull/4/head -> origin/pr/4
# …

现在所有的合并请求在本地像分支一样展现,它们是只读的,当你执行抓取时它们也会更新。这让在本地测试合并请求中代码变得超级简单:

$ git checkout pr/2
Checking out files: 100% (3769/3769), done.
Branch pr/2 set up to track remote branch pr/2 from origin.
Switched to a new branch 'pr/2'

你的鹰眼系统会发现 refspec 的remote 部分的结尾有个 head 。在GItHub 那边也有一个 refs/pull/#/merge 引用,它代表的是如果你在网站上按了 merger 按钮对应的提交记录。这甚至让你可以爱按按钮之前测试这个合并。

合并请求之上的合并请求

你不仅可以在主分支或者说master 分支上开启合并请求,实际上你可以在网络上的任何一个分支上开启合并请求。其实,你甚至可以在另一个合并请求上开启一个合并请求。

如果你看到一个合并请求在向正确的方向发展,然后你想在这个合并请求上做一些修改或者你不太确定这是个好主意,或者你没有目标分支的推送权限,你可以直接在合并请求上看起一个合并请求。

当你开启一个合并请求时,在页面的顶端有一个框框显示你要合并到那个哪个分支和你从哪个分支合并过来的。如果你点击哪个框框右边的 Edit 按钮,你不仅可以改变分支,还可以选择哪个 fork。

Git 学习笔记:6 GitHub_第34张图片
这里你可以很简单地指明合并你的分支到哪一个合并请求或fork。

提醒和通知

Github 内置了一个很好的通知系统,当你需要与别的团队交流时用起来很方便。

在任何评论中你可以先输入一个 “@”,系统会自动补全项目中合作者或贡献者的名字和用户名。

Git 学习笔记:6 GitHub_第35张图片

你也可以提醒不在列表中的用户,但是通常自动补全用起来更快。

当你发布了一个带有用户提醒的评论,那个用户会收到通知。这意味着把人们拉进会话中要比让他们投票有效率的多。对于 GitHub 上的合并请求,人们经常把他们团队或者公司中的其它人拉来审查问题或合并请求。

如果有人收到了合并请求或问题的提醒,他们会“订阅” 它,后面有新的活动发生他们都会持续收到提醒。如果你是合并请求或者问题的发起方你会被订阅上 ,比如你在关注一个版本库或者你评论了什么东西。如果你不想在收到提醒,在页面上有个 “Unsubscribe” 按钮,点一下就不会再收到更新了。

Git 学习笔记:6 GitHub_第36张图片

网页通知

网页通知只在 GitHub 上存在,你也只能在 GitHub 上查看。如果你打开了这个选项并且有一个你的通知,你会在你屏幕上方的通知图标上看到一个小蓝点。参见 通知中心

Git 学习笔记:6 GitHub_第37张图片
如果你点击那个玩意儿,你会看到你被通知到的所有有项目,按照项目分好了组。你可以点击左边栏的项目名字来过滤项目相关的通知。你可以点击通知旁边的对号图标把通知标记为已读,或者点击组上面的图标把项目中 所有的 通知标为已读。在每个对号图标旁边都有一个静音按钮,你可以点一下,以后就不会收到它相关的通知。

所有这些工具对于处理大量通知非常有用。很多 GItHub 资深用户都关闭邮件通知,在这页面上处理他们所有的通知。

邮件通知

邮件通知是你处理 GitHub 通知的另一种方式。如果你打开这个选项,每当有通知时,你会收到一封邮件。

特殊文件

如果你的版本库中有一些特殊文件,GitHub 会提醒你。

README

第一个就是 README 文件,可以是几乎任何 GtiHub 可以识别的格式。例如,它可以是 MEADME,README.md。如果 GitHub 在你的版本库中找到 README 文件,会把它在项目的首页渲染出来。

很多团队在这个文件里放版本库或项目新人需要了解的所有相关的信息。它一般包含这些内容:

  • 该项目的作用
  • 如何配置与安装
  • 有关如何使用和运行的例子
  • 项目的许可证
  • 如何向项目贡献力量

因为 GitHub 会渲染这个文件,你可以在问价哪里植入图片或链接让它更容易理解。

贡献 CONTRIBUTING

另一个 GitHub 可以识别的特殊文件是 CONTRIBUTING。入股哦你有任意扩展名的 CONTRIBUTING 文件,当有人开启一个合并请求时 GitHub 会显示
Git 学习笔记:6 GitHub_第38张图片

这个作用就是你可以在这里指出对于你的项目的合并请求你想要的/不想要的各种事情。这样别人在开启合并请求之前可以读到这些指导方针。

项目管理

对于一个单个项目其实没有很多管理事务要做,但也有几点有趣的。

改变默认分支

如果你想用 master 之外的分支作为你的默认分支,其他人将默认会在这个分支上开启合并请求或进行浏览,你可以在你版本库的设置页面的“options” 标签下修改。

Git 学习笔记:6 GitHub_第39张图片

简单地改变默认分支下拉列表中的选项,他就会作为所有主要操作的默认分支,他人进行克隆时该分支也将被默认检出。

移交项目

如果你想把一个项目移交给 GitHub 中的另一个人或两一个组织,还是设置页面的这个 “options”变迁下有一个 “Transfer ownership”选项可以用来干这个。

Git 学习笔记:6 GitHub_第40张图片

当你正准备放弃一个项目正好有别人想要接手时,或者你的项目壮大了想把它移到一个组织里时,这就管用了。
这么做不仅会把版本库连带它所有的观察和星标都移到另一个地方,他还会将你的URL重定向到新的位置。它也重定向了来自 Git 的克隆和抓取,而不仅仅时网页端请求。

管理组织

除了个人账户之外,GItHub 还提供被称为组织(Organizations)的账户。组织账户和个人账户一样都有一个用于存放所拥有项目的命名空间,但是许多其他的东西是不同的。组织账户代表了一组共同拥有多个项目的人,同时也提供一些工具用于对成员进行分组管理。通常,这种账户被用于开源群组(例如:perl 或者 rails),或者公司(例如:google 或者 twitter)

组织的基本知识

我们可以很简单地创建一个组织,只需要点击任意 GitHub 页面右上角的 + 图标,在菜单中选择 “New Organization” 即可。

Git 学习笔记:6 GitHub_第41张图片
首先你必须提供组织的名称和组织的主要联系邮箱。然后,如果你希望的话,也可以邀请其他用户作为共同的拥有人。

完成以上步骤后,你就会拥有一个全新的组织。类似个人账户,如果组织的所有内容都是开源的,那么你就可以免费试用这个组织。

作为一个组织的拥有者,但你在派生一个版本库的时候,你可以选择把它派生到你的组织的命名空间内。当你新建版本库时,你可以把它存放到你的个人账户或你拥有的组织内。同时,你也会自动地 关注 多有这些组织内的 新版本库。

就像头像,你可以为你的组织上传头像,使它更个性化。同时,也和个人账户类似,组织有一个着陆页(landing page),用于列出该组织所有的版本库,并且页面可供所有人浏览。

下面我们来说一些组织和个人账户不同的地方。

团队

组织使用 团队(Teams)来管理成员,团队就是组织中的一组个人账户和版本库,以及团队成员对这些版本库的访问权限。

例如,假设你的公司有单个版本库:frontend、backend和deployscripts。你会希望你的 前端开发者 有 forntend 或者 backend 的访问权限,操作人员有 backend 和 deployscrpts 的访问权限。团队让这个任务变得简单,而不用为每个版本库管理它的协作者。

组织页面主要由一个面板 构成,这个仪表盘包含了这个组织内的所有版本库,用户和团队。

Git 学习笔记:6 GitHub_第42张图片
你可以点击 组织页面 右边的团队侧边栏 来管理你的团队。点击之后,你会进入一个新页面,在这里你可以添加新成员和版本库到团队中,或者管理团队的访问权限和其它设置。每个团队对于版本库可以有只读、读写 和 管理三种权限。你可以通过点击在 团队页面内的 Settings 按钮更改相应权限等级。

Git 学习笔记:6 GitHub_第43张图片
当你邀请一个用户加入团队,该用户会收到一封通知他被邀请的邮件。

除此之外,团队也类似于个人账户,有 @mentions 的功能,不同之处在于被提及的团队 所有 成员都会成为这个话题的订阅者。当你希望得到团队中某个人的关注,又不知道具体应该问谁的时候,这个功能就显得很有帮助。

一个用户可以加入任意数量的团队,所以别把自己局限于拥有访问控制的团队。对于某一类课题,像 ux,css 或者 refactoring 这样有着特殊关注点的团队就显得很有帮助,而像 legal 和 colorblind 这样的就完全针对它们各自的领域的。

审计日志

组织的拥有者好可以访问组织中发生的事情的所有信息。在 Audit Log 标签页有整个组织的日志,你可以看到谁在世界上那个地方做了什么事。

Git 学习笔记:6 GitHub_第44张图片

你也可以通过选定某一类型的事件、某个地方、某个人对日志进行过滤。

脚本 GitHub

所以现在我们已经介绍了 GitHub 的大部分功能与工作流程,但是任意一个小组或项目都会去自定义,因为他们想要创造或扩展想要整合的服务。

对我们来说很幸运的是,GItHub 在许多方面都真的很方便Hack。在本节中我们将会介绍如何使用 GitHub 钩子系统与 API 接口,使 GitHub 按照我们的设想来工作。

钩子

GitHub 仓库管理中的钩子与服务区块是 GItHub 与 外部系统交互最简单的方式。

服务

首先我们来看一下服务。钩子与服务整合都可以在仓库的设置区块中找到,就在我们之前添加协作者与改变项目的默认分支的地方。在 Webhooks and Services 标签下你会看到与 下面类似的内容。

Git 学习笔记:6 GitHub_第45张图片
有许多可以选择的服务,大多数是整合到其他的商业和开源系统中。它们中的大多数是为了整合持续集成服务、BUG与问题追踪系统、聊天室系统与文档系统。我们将会通过设置一个非常简单的例子来介绍。如果从 Add Service 选择 email ,会得到一个配置页面:

Git 学习笔记:6 GitHub_第46张图片
在本例中,如果我们点击 Add service 按钮,每次有人推送内容到仓库时,指定的电子邮件地址会收到一封邮件。服务可以监听许多不同类型的事件,但是大多数只监听推送事件然后使用那些数据做一些事情。

如果有一个正在使用的系统想要整合到 GItHub,应当先检查这里看有没有已有的可用的服务整合。例如,如果正使用 Jenkins 来测试你的代码库,当每次有人推送到你的仓库时你可以启用 Jenkins 内置的整合启动测试运行。

钩子

如果需要做一些具体的事情,或者想要整合一个不在这个列表中的服务或站点,可以转而使用更通用的钩子系统。GitHub 仓库钩子是非常简单的。指定一个URL 然后 GitHub 在任一期望的事件发生时就会发送一个HTTP 请求到那个URL。

通常做这件事的方式是可以设置一个小的web 服务来监听 GitHub 钩子请求然后使用收到的数据做一些事情。

为了启用一个钩子,点击 Add webhook 按钮。这会将你引导至一个类似下面的页面:

Git 学习笔记:6 GitHub_第47张图片

Web 钩子的设置非常简单。大多数情况下只需要输入一个 URL 与一个密钥然后点击 “Add webhook”。有几个选项可以指定在哪个事件时想要 GitHub 发送请求——默认的行为是只有当某人推送新代码到仓库的任一分支时的push事件获得一个请求。

让我们看一个设置处理 web 钩子的 web 服务的小例子。我们将会使用 Ruby web 框架 Sinatra,因为它相当简洁,应该能够轻松地看到我们正在做什么。

假设我们想要在某个特定的人推送到我们的项目的特性分支并修改一个特定文件时得到一封邮件。我们可以相当容易地使用类似下面的代码做到:

require 'sinatra'
require 'json'
require 'mail'

post '/payload' do
  push = JSON.parse(request.body.read) # parse the JSON

  # gather the data we're looking for
  pusher = push["pusher"]["name"]
  branch = push["ref"]

  # get a list of all the files touched
  files = push["commits"].map do |commit|
    commit['added'] + commit['modified'] + commit['removed']
  end
  files = files.flatten.uniq

  # check for our criteria
  if pusher == 'schacon' &&
     branch == 'ref/heads/special-branch' &&
     files.include?('special-file.txt')

    Mail.deliver do
      from     '[email protected]'
      to       '[email protected]'
      subject  'Scott Changed the File'
      body     "ALARM"
    end
  end
end

这里我们拿到一个 GitHub 传送给我们的Json请求然后查找推送者,他们推送到了什么分支以及推送的所有提交都改动了哪些文件。然后我们检查它是否与我们的条件匹配,如果不匹配则发送一封邮件。

为了开发与测试类似这样的东西,在设置钩子的地方有一个漂亮的开发者控制台。可以看到 GitHub 为那个 webhook 的最后几次请求。对每一个钩子,当它发送后都可以深入挖掘,检测它是否是成功的与请求及回应的消息头与消息体。这使得测试与调试钩子非常容易。
Git 学习笔记:6 GitHub_第48张图片
开发者控制台的另一个很棒的功能是可以轻松地重新发送任何请求来测试你的服务。

关于如何编写 web钩子与所有可监听的不同事件类型的更多信息,请访问在 https://developer.github.com/webhooks/ 的GitHub 开发者文档。

GitHub API

服务与钩子给你提供了一种方式来接收关于在仓库中发生的时间的推送通知,但是如何获取相关事件的详情呢?如何自动化一些诸如添加协作者或给问题加标签的事情呢?

这是 GitHub API 派上用场的地方。在自动化流行的趋势下,GitHub 提供了大量的API 接口,可以进行几乎任何能在网站上进行的操作。在本节中我们将会学习如何授权与连接到 API,如何通过API 在一个问题上评论与如何修改一个 Pull Request 的状态。

基本用途

可以做的最基本的事情是向一个不需要授权的接口上发送一个简单的GET请求。该接口可能是一个用户或开源项目的只读信息。例如,如果我们想要知道更多关于名为 “schacon” 的用户信息,我们可以运行类似下面的东西:

$ curl https://api.github.com/users/schacon
{
  "login": "schacon",
  "id": 70,
  "avatar_url": "https://avatars.githubusercontent.com/u/70",
# …
  "name": "Scott Chacon",
  "company": "GitHub",
  "following": 19,
  "created_at": "2008-01-27T17:19:28Z",
  "updated_at": "2014-06-10T02:37:23Z"
}

有大量类似这样的接口来获得关于组织、项目、问题、提交的信息——差不多就是你能在 GItHub 上看到的所有东西。甚至可以使用 API 来渲染任意 Markdown 或寻找一个 .gitignore 模板。

$ curl https://api.github.com/gitignore/templates/Java
{
  "name": "Java",
  "source": "*.class

# Mobile Tools for Java (J2ME)
.mtj.tmp/

# Package Files #
*.jar
*.war
*.ear

# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*
"
}

在一个问题上评论

然而,如果想要在网站上进行一个操作,如在 Issue 或 Pull Request 上评论,或者想要查看私有内容或与其交互,你需要授权。

这里提供了几种授权方式。你可以使用仅需用户名与密码的基本授权,但是通常更好的注意是使用一个个人访问令牌。可以从设置页的 Application 标签生成访问令牌。

Git 学习笔记:6 GitHub_第49张图片

它会询问这个令牌的作用域与一个描述。确保使用一个好的描述信息,这样当脚本或用用不再使用时你会很放心地移除。

GitHub 只会显示令牌一次,所以记得一定要拷贝它。现在可以在脚本中使用它代替使用用户名和密码来授权。这很漂亮,因为可以限制想要做的范围并且令牌是可废除的。

这也会有一个提高频率上限的附加优点。如果没有授权的话,你会被限制在一小时最多发起60次请求。如果授权则可以一小时最多发起5000 次请求。

所以让我们利用它来对我们的其中一个问题进行评论。想要对一个特定问题 Issue #6 留下一条评论。必须使用刚刚生成的令牌作为 Authorization 头信息,发送一个到

repos///issues//comments 的 HTTP POST 请求。

$ curl -H "Content-Type: application/json" \
       -H "Authorization: token TOKEN" \
       --data '{"body":"A new comment, :+1:"}' \
       https://api.github.com/repos/schacon/blink/issues/6/comments
{
  "id": 58322100,
  "html_url": "https://github.com/schacon/blink/issues/6#issuecomment-58322100",
  ...
  "user": {
    "login": "tonychacon",
    "id": 7874698,
    "avatar_url": "https://avatars.githubusercontent.com/u/7874698?v=2",
    "type": "User",
  },
  "created_at": "2014-10-08T07:48:19Z",
  "updated_at": "2014-10-08T07:48:19Z",
  "body": "A new comment, :+1:"
}

现在如果进入到那个问题,可以看到我们刚刚发布的评论:

在这里插入图片描述

可以使用 API 去做任何可以在往回走哪上做的事情——创建与设置里程碑、指派人员到Issues 与 Pull Requests,创建与修改标签、访问提交数据、创建新的提交与分支、打开关闭或合并Pull Requests、创建与编辑团队、在Pull Request 中评论某行代码、搜索网站等等。

修改Pull Request 的状态

如果使用 Pull Request 的话我们将要看到的最后一个例子会很有用。每一个提交可以有一个或多个与它关联的状态,有API来添加与查询状态。

大多数持续集成与测试服务通过测试推送的到吗后使用这个API 来回应,然后报告提交是否通过了全部测试。你也可以使用该接口来检查提交信息是否经过合适 的格式化、提交者时候遵循额所有你的贡献准则、提交是否经过有效的签名——种种这类事情。

假设在仓库中设置了一个web 钩子 访问一个同来检查提交信息中的 Signed-off-by 字符串的小的 web服务。

require 'httparty'
require 'sinatra'
require 'json'

post '/payload' do
  push = JSON.parse(request.body.read) # parse the JSON
  repo_name = push['repository']['full_name']

  # look through each commit message
  push["commits"].each do |commit|

    # look for a Signed-off-by string
    if /Signed-off-by/.match commit['message']
      state = 'success'
      description = 'Successfully signed off!'
    else
      state = 'failure'
      description = 'No signoff found.'
    end

    # post status to GitHub
    sha = commit["id"]
    status_url = "https://api.github.com/repos/#{repo_name}/statuses/#{sha}"

    status = {
      "state"       => state,
      "description" => description,
      "target_url"  => "http://example.com/how-to-signoff",
      "context"     => "validate/signoff"
    }
    HTTParty.post(status_url,
      :body => status.to_json,
      :headers => {
        'Content-Type'  => 'application/json',
        'User-Agent'    => 'tonychacon/signoff',
        'Authorization' => "token #{ENV['TOKEN']}" }
    )
  end
end

希望这相当容易做。在这个 web 钩子处理器中我们浏览刚刚推送上来的每一个提交,在提交信息中茶渣字符串 Signed-off-by 并且最终使用 HTTP 向 /repos///statuses/ API 接口发送一个带有状态的 POST 请求。

在本例中可以发送一个状态(success、failure、error)、一个发生了什么的描述信息、一个用户可以了解更多信息的目标 URL 与一个 “context” 以防一个单独的提交有多个状态。

如果某人在 GitHub 上打开了一个新的 Pull Request 并且这个钩子已经设置,会看到类似信息:
Git 学习笔记:6 GitHub_第50张图片
现在可看到哦一个小的绿色对勾标记扎提交信息中有 Signed-off-by 的提交旁边,红色的对勾标记在作者额昂及签名的提交旁边。也可以看到 Pull Request 显示在那个分支上的左后提交的状态,如果失败的话会警告你。如果对测试结果使用这个API 那么就不会不小心合并某些未通过测试的最新提交。

Octokit

尽管我们在这些例子中都是通过 curl 与基本的HTTP 请求来做几乎所有的事情,还有一些以更自然的方式利用 API 的开源库存在着。 在写这篇文章的时候,被支持的语言包括Go、Objective-C、Ruby 与 .NET。 访问 http://github.com/octokit 了解更多相关信息,它们帮你处理了更多 HTTP 相关的内容。

希望这些工具能帮助你自定义与修改 GitHub 来更好地为特定的工作流程工作。 关于全部 API 的完整文档与常见任务的指南,请查阅 https://developer.github.com。

你可能感兴趣的:(Git)