开源消息推送服务message-pusher源码

图片[1]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网

搭建专属于你的消息推送服务,支持多种消息推送方式,支持 Markdown,仅单可执行文件,开箱即用

后台截图

图片[2]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[3]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[4]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[5]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[6]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[7]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网 图片[8]小目标分享网-专注资源收集分享平台开源消息推送服务message-pusher源码小目标分享网-专注资源收集分享平台小目标分享网

 

Warning:从 v0.3 版本升级到 v0.4 版本需要手动迁移数据库,具体方法见迁移数据库。

描述
多种消息推送方式:
邮件消息,
微信测试号,
QQ,
企业微信应用号,
企业微信群机器人
飞书自建应用
飞书群机器人,
钉钉群机器人,
Bark App,
WebSocket 客户端(官方客户端,接入文档),
Telegram 机器人,
Discord 群机器人,
腾讯云自定义告警:免费的短信提醒,
群组消息:可以将多个推送通道组合成一个群组,然后向群组发送消息,可以实现一次性推送到多个渠道的功能,
自定义消息:可以自定义消息请求 URL 和请求体格式,实现与其他服务的对接,支持众多第三方服务。
支持自定义 Webhook,反向适配各种调用平台,你可以接入各种已有的系统,而无需修改其代码。
支持在 Web 端编辑 & 管理发送的消息,新消息发送后 Web 端即时刷新。
支持异步消息发送。
支持用户管理,支持多种用户登录注册方式:
邮箱登录注册以及通过邮箱进行密码重置。
GitHub 开放授权。
微信公众号授权(需要额外部署 WeChat Server)。
支持 Markdown。
支持 Cloudflare Turnstile 用户校验。
支持在线发布公告,设置关于界面以及页脚。
API 兼容其他消息推送服务,例如 Server 酱。
用途
整合进自己的博客系统,每当有人登录时发微信消息提醒。
在进行深度学习模型训练时,在每个 epoch 结束后将关键数据发送到微信以方便及时监控。
在各种脚本运行结束后发消息提醒,例如监控 GitHub Star 数量的脚本,又例如自动健康填报的脚本,用来通知运行结果。
为其他系统提供消息推送功能。
部署
通过 Docker 部署
部署:

docker run -d --restart always --name message-pusher -p 3000:3000 -e TZ=Asia/Shanghai -v /home/ubuntu/data/message-pusher:/data justsong/message-pusher

 

更新:

docker run --rm -v /var/run/docker.sock:/var/run/docker.sock containrrr/watchtower -cR

 

开放的端口号为 3000,之后用 Nginx 配置域名,反代以及 SSL 证书即可,具体参考详细部署教程。

数据将会保存在宿主机的 /home/ubuntu/data/message-pusher 目录(只有一个 SQLite 数据库文件),请确保该目录存在且具有写入权限,或者更改为合适的目录。

Nginx 的参考配置:

server{
   server_name msgpusher.com;  # 请根据实际情况修改你的域名
   
   location / {
          client_max_body_size  64m;
          proxy_http_version 1.1;
          proxy_pass http://localhost:3000;  # 请根据实际情况修改你的端口
          proxy_set_header Host $host;
          proxy_set_header X-Forwarded-For $remote_addr;
          proxy_cache_bypass $http_upgrade;
          proxy_set_header Accept-Encoding gzip;
   }
}

 

之后使用 Let’s Encrypt 的 certbot 配置 HTTPS:

# Ubuntu 安装 certbot:
sudo snap install --classic certbot
sudo ln -s /snap/bin/certbot /usr/bin/certbot
# 生成证书 & 修改 Nginx 配置
sudo certbot --nginx
# 根据指示进行操作
# 重启 Nginx
sudo service nginx restart

手动部署
1.从 GitHub Releases 下载可执行文件或者从源码编译:

git clone https://github.com/songquanpeng/message-pusher.git
cd message-pusher/web
npm install
npm run build
cd ..
go mod download
go build -ldflags "-s -w" -o message-pusher

运行:

chmod u+x message-pusher
./message-pusher --port 3000 --log-dir ./logs

访问 http://localhost:3000/ 并登录。初始账号用户名为 root,密码为 123456。
如果服务需要长久运行,只是单纯地启动是不够的,详细部署教程。

注意
如果需要使用 WebSocket 客户端推送功能,则 Nginx 的配置文件中 proxy_read_timeout 和 proxy_send_timeout 务必设置超过 1 分钟。

推荐设置:

proxy_read_timeout 300s;
proxy_send_timeout 300s;

配置
系统本身仅需要下载一个可执行文件即可开始使用,无其他依赖。

你可以通过设置环境变量或者命令行参数进行配置。

等到系统启动后,使用 root 用户登录系统并做进一步的配置,默认密码为 123456。

环境变量
REDIS_CONN_STRING:设置之后将使用 Redis 作为请求频率限制的存储,而非使用内存存储。
例子:REDIS_CONN_STRING=redis://default:redispw@localhost:49153
SESSION_SECRET:设置之后将使用固定的会话密钥,这样系统重新启动后已登录用户的 cookie 将依旧有效。
例子:SESSION_SECRET=random_string
SQL_DSN:设置之后将使用指定数据库而非 SQLite。
例子:SQL_DSN=root:123456@tcp(localhost:3306)/message-pusher
注意:使用 Docker 部署时,请使用 -e key=value 设置环境变量。

例子:docker run -e SESSION_SECRET=random_string …

命令行参数
–port <port_number>: 指定服务器监听的端口号,默认为 3000。
例子:–port 3000
–log-dir <log_dir>: 指定日志文件夹,如果没有设置,日志将不会被保存。
例子:–log-dir ./logs
–version: 打印系统版本号并退出。
进一步的配置
系统设置:
填写服务器地址。
配置登录注册选项,如果系统不对外开放,请取消选择允许新用户注册。
配置 SMTP 服务,可以使用 QQ 邮箱的 SMTP 服务。
其他配置可选,请按照页面上的指示完成配置。
个人设置:
点击更新用户信息更改默认用户名和密码。
点击绑定邮箱地址绑定邮箱以启用邮件消息推送方式。
推送设置:
设置默认推送方式,默认为通过邮件进行推送。
设置推送 token,用以推送 API 调用鉴权,如果不需要留空即可。
设置其他推送方式,按照页面上的指示即可,完成配置后点击对应的测试按钮即可测试配置是否成功。
其他设置:如果系统对外提供服务,本系统也提供了一定的个性化设置功能,你可以设置关于界面和页脚,以及发布公告。
用法
消息推送 API URL:https://<domain>/push/<username>
将上面的 <domain> 以及 <username> 替换为真实值,例如:https://push.mydomain.cn/push/admin
GET 请求方式:https://<domain>/push/<username>?title=<标题>&description=<描述>&content=<Markdown 文本>&channel=<推送方式>&token=<推送 token>
title:选填,受限于具体的消息推送方式,其可能被忽略。
description:必填,可以替换为 desp。
content:选填,受限于具体的消息推送方式,Markdown 语法的支持有所区别。
channel:选填,如果不填则系统使用你在后台设置的默认推送通道。注意,此处填的是消息通道的名称,而非类型。可选的推送通道类型有:
email:通过发送邮件的方式进行推送(使用 title 或 description 字段设置邮件主题,使用 content 字段设置正文,支持完整的 Markdown 语法)。
test:通过微信测试号进行推送(使用 description 字段设置模板消息内容,不支持 Markdown)。
corp_app:通过企业微信应用号进行推送(仅当使用企业微信 APP 时,如果设置了 content 字段,title 和 description 字段会被忽略;使用微信中的企业微信插件时正常)。
lark_app:通过飞书自建应用进行推送。
corp:通过企业微信群机器人推送(设置 content 字段则将渲染 Markdown 消息,支持 Markdown 的子集;设置 description 字段则为普通文本消息)。
lark:通过飞书群机器人进行推送(注意事项同上)。
ding:通过钉钉群机器人进行推送(注意事项同上)。
bark:通过 Bark 进行推送(支持 title 和 description 字段)。
client:通过 WebSocket 客户端进行推送(支持 title 和 description 字段)。
telegram:通过 Telegram 机器人进行推送(description 或 content 字段二选一,支持 Markdown 的子集)。
discord:通过 Discord 群机器人进行推送(注意事项同上)。
one_api:通过 OneAPI 协议推送消息到 QQ。
group:通过预先配置的消息推送通道群组进行推送。
custom:通过预先配置好的自定义推送通道进行推送。
tencent_alarm:通过腾讯云监控告警进行推送,仅支持 description 字段。
none:仅保存到数据库,不做推送。
token:如果你在后台设置了推送 token,则此项必填。另外可以通过设置 HTTP Authorization 头部设置此项。
url:选填,如果不填则系统自动为消息生成 URL,其内容为消息详情。
to:选填,推送给指定用户,如果不填则默认推送给自己,受限于具体的消息推送方式,有些推送方式不支持此项。
@all:推送给所有用户。
user1|user2|user3:推送给多个用户,用户之间使用 | 分隔。
async:选填,如果设置为 true 则消息推送将在后台异步进行,返回结果包含 uuid 字段,可用于后续[获取消息发送状态](./docs/API.md#通过消息 UUID 获取消息发送状态)。
POST 请求方式:字段与上面 GET 请求方式保持一致。
如果发送的是 JSON,HTTP Header Content-Type 请务必设置为 application/json,否则一律按 Form 处理。
POST 请求方式下的 token 字段也可以通过 URL 查询参数进行设置。

 

项目地址:github点击进入地址

------本页内容已结束,喜欢请分享------
© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享