写了一个自建 Kindle 推送服务 KPush
可以定制个人专属的 Kindle 电子书推送服务,放在服务器高端口自用
项目地址:KPush
KPush
定制个人专属的Kindle电子书推送服务
安装
首先需要安装Node.js环境,且版本大于8,相关信息请戳这里
npm源
# 全局安装
$ npm i -g kpush
使用
帮助:
Usage: kpush [options]
Options:
-V, --version output the version number
-c, --config <string> set kpush custom config
-p, --port <number> set kpush server listening port
-s, --smtp <string> set stmp server of pushing mail
-u, --user <string> set user of pushing mail
-s, --pass <string> set password of pushing mail
-k, --kindle <string> set user of kindle received mail
-h, --help output usage information
所有设置都会自动保存,再次使用时无需再进行设置
运行:
$ kpush
配置设置并运行:
# 可以只设置其中几项
$ kpush -p 7001 -s smtp.163.com -u test@163.com -s test -k test@kindle.cn
以自定义配置运行:
# 请提供配置的绝对路径,以自定义配置运行时将忽略其他设置选项
$ kpush -c /usr/local/kpush/config.json
配置格式如下,字段含义见帮助:
{
"port": "7001",
"smtp": "smtp.163.com",
"user": "test@163.com",
"pass": "test",
"kindle": "test@kindle.cn"
}
运行后,浏览器访问KPush服务器监听端口即可使用,推荐移动端进行访问
mobi源更换
这里默认用了走读派作为mobi电子书源,感谢一下。若更换其他mobi源,请自行开发,仅需要实现model.js中getList和getUrl方法即可,约定如下:
// KPush自带依赖,用于发送请求以及解析页面
const request = require('superagent')
const cheerio = require('cheerio')
// 导出model对象
module.exports = {
/**
* 获取mobi电子书搜索列表
*
* @param {string} q - 查询关键词
* @return {array} - 返回list数组
*
* list数组元素为mobi对象,包含3个字段,均为string
* mobi.id - mobi电子书唯一索引,用于查询源下载链接
* mobi.img - mobi电子书封面图链接
* mobi.ctx - mobi电子书简介
*/
async getList (q) {
let list = []
list.push({
id: '123',
img: 'http://test.com/test1.jpg',
ctx: '简介'
})
return list
},
/**
* 获取mobi电子书下载链接
*
* @param {string} i - mobi电子书索引
* @return {string} - 返回源中mobi电子书下载链接
*/
async getUrl (i) {
let url = 'http://test.com/download/123'
return url
}
}
项目地址:KPush
其实我是来求Star(逃