本文共 1966 字,大约阅读时间需要 6 分钟。
GitHub 的钩子系统是其最灵活的功能之一,允许开发者在仓库事件发生时触发自定义操作。服务则为钩子提供了更具体的处理方式,例如配置持续集成工具(如Jenkins)或问题追踪系统。
在“Webhooks and Services”标签下,可以找到服务与钩子的配置区域。选择“Add Service”后,可以看到类似电子邮件配置的界面。例如,设置邮件服务时,每次仓库推送都会向指定邮箱发送通知。
对于更复杂的需求,可以使用钩子系统。通过指定一个URL,GitHub会在特定事件(如push事件)发生时发送HTTP请求。例如,可以设置一个简单的web服务监听钩子请求,并根据需要执行操作。
GitHub API为开发者提供了强大的操作能力。通过API,可以实现许多自动化任务,如创建或修改问题、Pull Request、搜索仓库内容等。
获取用户信息:可以通过curl命令获取用户详细信息,例如:
curl https://api.github.com/users/schacon
返回结果包含用户的登录名、ID、头像链接等信息。
获取Markdown渲染:使用API渲染Markdown文件,例如获取Java.gitignore模板:
curl https://api.github.com/gitignore/templates/Java
返回的内容包括忽略项列表。
要执行需要授权的操作(如在问题上评论),需要使用访问令牌。访问令牌可以在“Applications”标签下生成,确保令牌的作用域明确。例如,发送评论可以通过以下命令实现:
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 通过API可以动态更新Pull Request的状态。例如,检查提交是否签名:
require 'httparty'require 'sinatra'require 'json'post '/payload' do push = JSON.parse(request.body.read) repo_name = push['repository']['full_name'] push["commits"].each do |commit| if /Signed-off-by/.match(commit['message']) state = 'success' description = 'Successfully signed off!' else state = 'failure' description = 'No signoff found.' end status_url = "https://api.github.com/repos/#{repo_name}/statuses/#{commit['id']}" status = { "state" => state, "description" => description, "target_url" => "http://example.com/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']}" } ) endend 对于需要更方便地使用GitHub API的开发者,Octokit是一个开源库,提供了对GitHub API的封装调用,支持多种语言,包括Ruby、Go等。通过Octokit,可以更加简洁地实现各种GitHub操作。
转载地址:http://dsg.baihongyu.com/