相信各位程序员对github已经不陌生了。不知道各位有没有注意到GitHub没有推送通知这个功能。当有人在我的存储库中创建了一个提取请求/问题时,我可以收到电子邮件通知,但当有人stars/forks的时候却没没有通知。

此外,我已经收到了12253封电子邮件通知。。。。。。。。。。这件事好像不是那么酷了。

看,我不是在开玩笑!

作为一个专业的开发人员,这尼玛的就忍不了啊,必须自己上手解决好吗!我决定建立一个Chrome扩展程序,只要有人与我的GitHub存储库进行交互,即可实时发送通知。这是Google Chrome商店中的GitHub通知程序。你也可以在这里找到更多的信息。

实时Chrome通知

当有人执行以下任何操作时,你会看到上述通知之一:

  • 在问题上创建问题或意见
  • 创建拉请求
  • 为你的repository点forks
  • 为你的repository 点stars
  • 将代码推送到你的存储库

如何实现

最初,我以为建立起来真的很简单。在我的印象中这简直就是小儿科嘛,毕竟姐可是有建立Chrome apps的经验哟。

但是一如往常,魔鬼在细节上。这里是工具,框架,以及我用来获取和运行的其他东西:

  • GitHub应用程式
  • Express和NodeJS
  • Firebase
  • Google Cloud Messaging
  • Chrome扩展程序

GitHub Apps

要实时向用户发送通知,只要有任何用户交互,我们就需要使用webhook来ping通。有效载荷将包含信息,例如与你的存储库进行交互的人员,采取的操作(是star还是fork)以及存储库的名称。

为此,请注册一个GitHub应用程序。它将允许你选择你的GitHub应用程序将检测哪些webhook事件。

GitHub应用程式的权限

填写你的webhook URL,稍后我将介绍。

进一步阅读:GitHub应用程序

Express和NodeJS

在定义webhook触发器的事件之后,你需要一个服务器来接收和处理有效负载。由于独立的Chrome扩展程序无法启动服务器,因此我们需要为此创建一个单独的项目。

在Express和NodeJS项目中创建一个POST端点,它将处理webhook。

app.post('/ watch',function(req,res,next){
.....
});

对于webhook,我喜欢使用ngrok - 一个免费的工具(拥有30个用户的上限),它创建一个可公开访问的URL来配置webhook服务。

一旦你已经安装了ngrok,你可以用它为应用程序选择运行的通道,比如,端口3000。这将和打字一样简单

ngrok http 3000

ngrok然后产生两种一个URL http和https 。您可以使用它们临时填写GitHub应用程序中的webhook URL,直到您托管它们。

进一步阅读:ngrok

Chrome扩展程序

接下来,为不的Chrome扩展程序创建一个单独的项目。Chrome扩展本身很容易构建。首先,创建一个manifest.json包含扩展名,描述,版本号等属性的文件。

我们还需要一个popup.html文件,当有人下载​​并点击你的Chrome扩展程序时,该文件显示弹出式窗口。弹出窗口提示用户填写他们的GitHub用户名,如下所示:

popup.html

保存你的GitHub用户名后,将你的GitHub用户名连接到将收到通知的计算机。

我们同时使用Google Cloud Messaging和Firebase。

进一步阅读:入门:构建Chrome扩展

Google Cloud Messaging和Firebase

Google Cloud Messaging(GCM)是一项移动通知服务,可让开发人员在服务器和客户端应用之间发送消息。

Firebase是由Google开发的实时云端托管数据库。我选择了Firebase,因为它很容易设置。

在Chrome扩展程序中,创建一个popup.js文件。这将使用GCM和Firebase。将你的用户名保存在弹出窗口后,使用GCM生成一个注册ID来标识你的浏览器。将registrationID作为ID来区分你的计算机与其他用户。

注册ID和GitHub用户名将被保存为Firebase中的条目。

进一步阅读:FirebaseGoogle Cloud Messaging

这一切如何工作?

Github通知程序如何构建的总结图

总结上图,每当有人与GitHub存储库进行交互时,都会发生以下情况:

  • 有效载荷将从GitHub Apps发送到Express和NodeJS服务器。
  • 服务器接收有效载荷,并从有效载荷中提取GitHub用户名。
  • 从GitHub用户名查询关联的registrationID的Firebase。
  • Google Cloud Messaging用于根据注册ID将服务器的消息发送到Chrome扩展。
  • Chrome扩展程序收到Google Cloud Messaging的邮件后,会创建一个Chrome通知并将其推送给用户。

然后当当当!这就可以收到GitHub的实时Chrome通知辣!

非常感谢你能阅读到这里!真心希望以上内容可以帮助到你~~~

GitHub没有实时通知怎么办?当然是自己上手写一个啊!的更多相关文章

  1. 微信小程序客服消息实时通知之最佳实践

    我们做微信小程序开发的都知道,只要在小程序页面中添加如下代码即可进入小程序的客服会话界面: <button open-type="contact" >联系我们</ ...

  2. 写一个程序,统计自己C语言共写了多少行代码,Github基本操作

    前言 在上一篇博客中,本人提到了自己的文件操作可以说是几乎没用过.现在想想,这也算是只在OJ上做题的一个弊端吧.虽然通过OJ做题是一个学习代码好手段,但其他方面也要多多涉猎才好,而不是说OJ用不到文件 ...

  3. inotify-java linux系统监听文件发生变化,实时通知java程序

    1 Overview     最近公司的一个任务需要实时监控文件系统中某个文件的内容变化.由于程序本身由Java编写,因此使用了inotify- java(http://code.google.com ...

  4. Sqlserver数据库 通过表触发器 实时通知应用程序

    /* Sqlserver数据库开始相关服务 以下示例显示了如何查看 OLE Automation Procedures 的当前设置.0未启用 */ EXEC sp_configure 'show ad ...

  5. RxJava2-后台执行耗时操作,实时通知 UI 更新(一)

    一.前言 接触RxJava2已经很久了,也看了网上的很多文章,发现基本都是在对RxJava的基本思想介绍之后,再去对各个操作符进行分析,但是看了之后感觉过了不久就忘了. 偶然的机会看到了开源项目 Rx ...

  6. github 关掉邮件通知

  7. 用python 10min手写一个简易的实时内存监控系统

    简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...

  8. 自己写一个网页版的Markdown实时编辑器

    这几天忙着使用Python+Django+sqlite 搭建自己的博客系统,但是单纯的使用H5的TextArea,简直太挫了有木有.所以,就想模仿一下人家内嵌到网页上的Markdown编辑器,从而让自 ...

  9. [转]用python 10min手写一个简易的实时内存监控系统

    简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...

随机推荐

  1. 【Go命令教程】命令汇总

    [Go命令教程]1. 标准命令详解 [Go命令教程]2. go build [Go命令教程]3. go install [Go命令教程]4. go get [Go命令教程]5. go clean [G ...

  2. Parallel Programming--perfbook

    https://www.kernel.org/pub/linux/kernel/people/paulmck/perfbook/perfbook.html

  3. 怎样把XP系统装到USB里?

    怎么样在usb(usb闪存)里面装XP系统? 就是把usb当硬盘用 不买硬盘. U盘肯定装不了系统,装进去了也肯定蓝屏.为什么?因为USB得数据传输太慢,不会超过10M/S的,而你的IDE口或者SAT ...

  4. HDU 4081 Qin Shi Huang&#39;s National Road System(最小生成树/次小生成树)

    题目链接:传送门 题意: 有n坐城市,知道每坐城市的坐标和人口.如今要在全部城市之间修路,保证每一个城市都能相连,而且保证A/B 最大.全部路径的花费和最小,A是某条路i两端城市人口的和,B表示除路i ...

  5. 使用Axure RP原型设计实践03,制作一个登录界面的原型

    本篇体验做一个登录界面的原型. 登录页 首先在Page Style里为页面设置背景色. 如果想在页面中加图片,就把Image部件拖入页面,并设置x和y轴.双击页面中的Image部件可以导入图片.在Im ...

  6. Delphi开发环境中应用层网络协议的实现

    已经进入Internet网络时代了,许多新出的软件都拥有网络功能.其实,在这些软件背后所依靠的技术基础就是一系列的Inernet网络协议标准,亦即TCP/IP系列协议. 下面本人简要介绍一下在Delp ...

  7. IIS7.5标识介绍

    应用程序池的标识是运行应用程序池的工作进程所使用的服务帐户名称.默认情况下,应用程序池以 Network Service 用户帐户运行,该帐户拥有低级别的用户权限.您可以将应用程序池配置为以 Wind ...

  8. eclipse 安装 weblogic server

  9. 媒体文件audio 转 base64 编码 (利用 FileReader & Audio 对象)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  10. Java实现bt文件下载、制作、解析、磁力链接

    首先torrent里面肯定携带的有一些信息,所以就需要我们来解析这些信息. 我们这里做多文件制作torrent,所以首先要针对每一个文件建一个实体类 import java.util.List; pu ...