本地开发
欢迎贡献插件
建议nodejs版本 20.x
及以上
一、本地调试运行
克隆代码
shell
# 克隆代码
git clone https://github.com/certd/certd --depth=1
#进入项目目录
cd certd
# 切换到最新版本代码【如果v2分支无法编译,请尝试切换到最新版tag】
# git checkout v1.27.0 # 这里换成最新版本号
修改pnpm-workspace.yaml文件
重要:否则无法正确加载专业版的access和plugin
yaml
# pnpm-workspace.yaml
packages:
- 'packages/**' # <--------------注释掉这一行,PR时不要提交此修改
- 'packages/ui/**'
安装依赖和初始化:
shell
# 安装pnpm,如果提示npm命令不存在,就需要先安装nodejs
npm install -g pnpm@8.15.7 --registry=https://registry.npmmirror.com
# 使用国内镜像源,如果有代理,就不需要
pnpm config set registry https://registry.npmmirror.com
# 安装依赖
pnpm install
# 初始化构建
npm run init
启动 server:
shell
cd packages/ui/certd-server
npm run dev
启动 client:
shell
cd packages/ui/certd-client
npm run dev
# 会自动打开浏览器,确认正常运行
二、开发插件
进入 packages/ui/certd-server/src/plugins
1.复制plugin-demo
目录作为你的插件目录
比如你想做cloudflare
的插件,那么你可以复制plugin-demo
目录,将其命名成plugin-cloudflare
。
以下均以plugin-cloudflare
为例进行说明,你需要将其替换成你的插件名称
2. access授权
如果这是一个新的平台,它应该有授权方式,比如accessKey accessSecret之类的
参考plugin-cloudflare/access.ts
修改为你要做的平台的access
这样用户就可以在certd
后台中创建这种授权凭证了
3. dns-provider
如果域名是这个平台进行解析的,那么你需要实现dns-provider,(申请证书需要)
参考plugin-cloudflare/dns-provider.ts
修改为你要做的平台的dns-provider
4. plugin-deploy
如果这个平台有需要部署证书的地方
参考plugin-cloudflare/plugins/plugin-deploy-to-xx.ts
修改为你要做的平台的plugin-deploy-to-xx
5. 增加导入
在plugin-cloudflare/index.ts
中增加你的插件的import
ts
export * from './dns-provider'
export * from './access'
export * from './plugins/plugin-deploy-to-xx'
在./src/plugins/index.ts
中增加import
ts
export * from "./plugin-cloudflare.js"
6. 重启服务进行调试
刷新浏览器,检查你的插件是否工作正常, 确保能够正常进行证书申请和部署
三、提交PR
我们将尽快审核PR
四、 注意事项
1. 如何让任务报错停止
js
// 抛出异常即可使任务停止,否则会判定为成功
throw new Error("错误信息")
五、贡献插件送激活码
- PR要求,插件功能完整,代码规范
- PR通过后,联系我们,送您一个专业版激活码