mirror of
https://github.com/certd/certd.git
synced 2026-04-26 22:07:29 +08:00
Compare commits
7 Commits
ad4e1c1b5b
...
v1.37.8
| Author | SHA1 | Date | |
|---|---|---|---|
| ac70821fea | |||
| 38b273a1c9 | |||
| eb5c88fbb2 | |||
| 1102952b47 | |||
| 5ad6cadcee | |||
| 5d236808d6 | |||
| ada9243e84 |
@@ -3,6 +3,17 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* **plugins/woai-cdn:** 修正默认接口域名与帮助链接中的路径 ([#576](https://github.com/certd/certd/issues/576)) @LjyLab ([d20046c](https://github.com/certd/certd/commit/d20046c86681ea177ece434423b7c81a76b437fb))
|
||||||
|
|
||||||
|
### Performance Improvements
|
||||||
|
|
||||||
|
* 修复西数解析记录添加失败的bug,支持部署证书到西数虚拟主机 ([1102952](https://github.com/certd/certd/commit/1102952b4703e8c0bbc17b0700c0ed3ef6f866d3))
|
||||||
|
* 支持回车键触发登录 ([eb5c88f](https://github.com/certd/certd/commit/eb5c88fbb2901f1a9669429a7cd8dc76f6806d01))
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Bug Fixes
|
### Bug Fixes
|
||||||
|
|||||||
@@ -161,14 +161,13 @@ https://certd.handfree.work/
|
|||||||
************************
|
************************
|
||||||
开源为什么要做专业版收费?
|
开源为什么要做专业版收费?
|
||||||
1. 纯靠为爱发电不可持续(比如:我的dev-sidecar项目即便是拥有20K+star,也差点凉凉,幸亏有另外大佬接手用爱发电)
|
1. 纯靠为爱发电不可持续(比如:我的dev-sidecar项目即便是拥有20K+star,也差点凉凉,幸亏有另外大佬接手用爱发电)
|
||||||
2. 没有赞助的项目,作者不会用心倾听用户的心声,不顾用户体验(比如:下意识拒绝需求、频繁破坏性变更升级、全盘推倒重来之类的)
|
2. 没有赞助的项目,作者会比较任性,不会用心倾听用户的心声,不顾用户体验(比如:下意识拒绝需求、频繁破坏性变更升级、全盘推倒重来之类的)
|
||||||
3. 没有赞助的项目,交流群的戾气有时候比较重,容易起冲突
|
3. 没有赞助的项目,交流群的戾气有时候比较重,容易起冲突
|
||||||
|
|
||||||
|
|
||||||
发电权益:
|
发电权益:
|
||||||
1. 可加入发电专属群,可以获得作者一对一技术支持
|
1. 可加入发电专属VIP群,可以获得作者一对一技术支持,必要时可以远程协助
|
||||||
2. 您的需求我们将优先实现,并且将作为专业版功能提供
|
2. 您的需求我们将优先实现,并且可能将作为专业版功能提供
|
||||||
3. 一年期专业版激活码
|
3. 获得专业版功能
|
||||||
|
|
||||||
专业版特权对比
|
专业版特权对比
|
||||||
|
|
||||||
@@ -180,7 +179,7 @@ https://certd.handfree.work/
|
|||||||
| 站点证书监控 | 限制1条 | 无限制 |
|
| 站点证书监控 | 限制1条 | 无限制 |
|
||||||
| 自动部署插件 | 阿里云CDN、腾讯云、七牛CDN、主机部署、宝塔、1Panel等大部分插件 | 群晖 |
|
| 自动部署插件 | 阿里云CDN、腾讯云、七牛CDN、主机部署、宝塔、1Panel等大部分插件 | 群晖 |
|
||||||
| 通知 | 邮件通知、自定义webhook | 邮件免配置、企微、钉钉、飞书、anpush、server酱等 |
|
| 通知 | 邮件通知、自定义webhook | 邮件免配置、企微、钉钉、飞书、anpush、server酱等 |
|
||||||
|
| VIP群 | 无 | 可加,一对一技术支持,必要时远程协助 |
|
||||||
************************
|
************************
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
+1
-1
@@ -9,5 +9,5 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"npmClient": "pnpm",
|
"npmClient": "pnpm",
|
||||||
"version": "1.37.7"
|
"version": "1.37.8"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/publishlab/node-acme-client/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/acme-client
|
||||||
|
|
||||||
## [1.37.7](https://github.com/publishlab/node-acme-client/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/publishlab/node-acme-client/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Performance Improvements
|
### Performance Improvements
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
"description": "Simple and unopinionated ACME client",
|
"description": "Simple and unopinionated ACME client",
|
||||||
"private": false,
|
"private": false,
|
||||||
"author": "nmorsman",
|
"author": "nmorsman",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"module": "scr/index.js",
|
"module": "scr/index.js",
|
||||||
"main": "src/index.js",
|
"main": "src/index.js",
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
"types"
|
"types"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@peculiar/x509": "^1.11.0",
|
"@peculiar/x509": "^1.11.0",
|
||||||
"asn1js": "^3.0.5",
|
"asn1js": "^3.0.5",
|
||||||
"axios": "^1.7.2",
|
"axios": "^1.7.2",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/basic
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Performance Improvements
|
### Performance Improvements
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
01:12
|
01:14
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/basic",
|
"name": "@certd/basic",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"module": "./dist/index.js",
|
"module": "./dist/index.js",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/pipeline
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/pipeline
|
**Note:** Version bump only for package @certd/pipeline
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/pipeline",
|
"name": "@certd/pipeline",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"module": "./dist/index.js",
|
"module": "./dist/index.js",
|
||||||
@@ -18,8 +18,8 @@
|
|||||||
"compile": "tsc --skipLibCheck --watch"
|
"compile": "tsc --skipLibCheck --watch"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@certd/plus-core": "^1.37.7",
|
"@certd/plus-core": "^1.37.8",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
"lodash-es": "^4.17.21",
|
"lodash-es": "^4.17.21",
|
||||||
"reflect-metadata": "^0.1.13"
|
"reflect-metadata": "^0.1.13"
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/lib-huawei
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/lib-huawei
|
**Note:** Version bump only for package @certd/lib-huawei
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/lib-huawei",
|
"name": "@certd/lib-huawei",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"main": "./dist/bundle.js",
|
"main": "./dist/bundle.js",
|
||||||
"module": "./dist/bundle.js",
|
"module": "./dist/bundle.js",
|
||||||
"types": "./dist/d/index.d.ts",
|
"types": "./dist/d/index.d.ts",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/lib-iframe
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/lib-iframe
|
**Note:** Version bump only for package @certd/lib-iframe
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/lib-iframe",
|
"name": "@certd/lib-iframe",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"module": "./dist/index.js",
|
"module": "./dist/index.js",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/jdcloud
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/jdcloud
|
**Note:** Version bump only for package @certd/jdcloud
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/jdcloud",
|
"name": "@certd/jdcloud",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"description": "jdcloud openApi sdk",
|
"description": "jdcloud openApi sdk",
|
||||||
"main": "./dist/bundle.js",
|
"main": "./dist/bundle.js",
|
||||||
"module": "./dist/bundle.js",
|
"module": "./dist/bundle.js",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/lib-k8s
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/lib-k8s
|
**Note:** Version bump only for package @certd/lib-k8s
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/lib-k8s",
|
"name": "@certd/lib-k8s",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"module": "./dist/index.js",
|
"module": "./dist/index.js",
|
||||||
@@ -17,7 +17,7 @@
|
|||||||
"pub": "npm publish"
|
"pub": "npm publish"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@kubernetes/client-node": "0.21.0"
|
"@kubernetes/client-node": "0.21.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/lib-server
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/lib-server
|
**Note:** Version bump only for package @certd/lib-server
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/lib-server",
|
"name": "@certd/lib-server",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"description": "midway with flyway, sql upgrade way ",
|
"description": "midway with flyway, sql upgrade way ",
|
||||||
"private": false,
|
"private": false,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
@@ -28,11 +28,11 @@
|
|||||||
],
|
],
|
||||||
"license": "AGPL",
|
"license": "AGPL",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certd/acme-client": "^1.37.7",
|
"@certd/acme-client": "^1.37.8",
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@certd/pipeline": "^1.37.7",
|
"@certd/pipeline": "^1.37.8",
|
||||||
"@certd/plugin-lib": "^1.37.7",
|
"@certd/plugin-lib": "^1.37.8",
|
||||||
"@certd/plus-core": "^1.37.7",
|
"@certd/plus-core": "^1.37.8",
|
||||||
"@midwayjs/cache": "3.14.0",
|
"@midwayjs/cache": "3.14.0",
|
||||||
"@midwayjs/core": "3.20.11",
|
"@midwayjs/core": "3.20.11",
|
||||||
"@midwayjs/i18n": "3.20.13",
|
"@midwayjs/i18n": "3.20.13",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/midway-flyway-js
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
**Note:** Version bump only for package @certd/midway-flyway-js
|
**Note:** Version bump only for package @certd/midway-flyway-js
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/midway-flyway-js",
|
"name": "@certd/midway-flyway-js",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"description": "midway with flyway, sql upgrade way ",
|
"description": "midway with flyway, sql upgrade way ",
|
||||||
"private": false,
|
"private": false,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/plugin-cert
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Performance Improvements
|
### Performance Improvements
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/plugin-cert",
|
"name": "@certd/plugin-cert",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"types": "./dist/index.d.ts",
|
"types": "./dist/index.d.ts",
|
||||||
@@ -17,10 +17,10 @@
|
|||||||
"compile": "tsc --skipLibCheck --watch"
|
"compile": "tsc --skipLibCheck --watch"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@certd/acme-client": "^1.37.7",
|
"@certd/acme-client": "^1.37.8",
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@certd/pipeline": "^1.37.7",
|
"@certd/pipeline": "^1.37.8",
|
||||||
"@certd/plugin-lib": "^1.37.7",
|
"@certd/plugin-lib": "^1.37.8",
|
||||||
"@google-cloud/publicca": "^1.3.0",
|
"@google-cloud/publicca": "^1.3.0",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
"jszip": "^3.10.1",
|
"jszip": "^3.10.1",
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
**Note:** Version bump only for package @certd/plugin-lib
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Performance Improvements
|
### Performance Improvements
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/plugin-lib",
|
"name": "@certd/plugin-lib",
|
||||||
"private": false,
|
"private": false,
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "./dist/index.js",
|
"main": "./dist/index.js",
|
||||||
"types": "./dist/index.d.ts",
|
"types": "./dist/index.d.ts",
|
||||||
@@ -22,8 +22,8 @@
|
|||||||
"@alicloud/pop-core": "^1.7.10",
|
"@alicloud/pop-core": "^1.7.10",
|
||||||
"@alicloud/tea-util": "^1.4.10",
|
"@alicloud/tea-util": "^1.4.10",
|
||||||
"@aws-sdk/client-s3": "^3.787.0",
|
"@aws-sdk/client-s3": "^3.787.0",
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@certd/pipeline": "^1.37.7",
|
"@certd/pipeline": "^1.37.8",
|
||||||
"@kubernetes/client-node": "0.21.0",
|
"@kubernetes/client-node": "0.21.0",
|
||||||
"ali-oss": "^6.22.0",
|
"ali-oss": "^6.22.0",
|
||||||
"basic-ftp": "^5.0.5",
|
"basic-ftp": "^5.0.5",
|
||||||
|
|||||||
@@ -3,6 +3,12 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
### Performance Improvements
|
||||||
|
|
||||||
|
* 支持回车键触发登录 ([eb5c88f](https://github.com/certd/certd/commit/eb5c88fbb2901f1a9669429a7cd8dc76f6806d01))
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Bug Fixes
|
### Bug Fixes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/ui-client",
|
"name": "@certd/ui-client",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "vite --open",
|
"dev": "vite --open",
|
||||||
@@ -106,8 +106,8 @@
|
|||||||
"zod-defaults": "^0.1.3"
|
"zod-defaults": "^0.1.3"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@certd/lib-iframe": "^1.37.7",
|
"@certd/lib-iframe": "^1.37.8",
|
||||||
"@certd/pipeline": "^1.37.7",
|
"@certd/pipeline": "^1.37.8",
|
||||||
"@rollup/plugin-commonjs": "^25.0.7",
|
"@rollup/plugin-commonjs": "^25.0.7",
|
||||||
"@rollup/plugin-node-resolve": "^15.2.3",
|
"@rollup/plugin-node-resolve": "^15.2.3",
|
||||||
"@types/chai": "^4.3.12",
|
"@types/chai": "^4.3.12",
|
||||||
|
|||||||
@@ -117,7 +117,6 @@ onUnmounted(() => {
|
|||||||
:confirm-text="$t('common.refresh')"
|
:confirm-text="$t('common.refresh')"
|
||||||
:fullscreen-button="false"
|
:fullscreen-button="false"
|
||||||
:title="$t('ui.widgets.checkUpdatesTitle')"
|
:title="$t('ui.widgets.checkUpdatesTitle')"
|
||||||
centered
|
|
||||||
content-class="px-8 min-h-10"
|
content-class="px-8 min-h-10"
|
||||||
footer-class="border-none mb-3 mr-3"
|
footer-class="border-none mb-3 mr-3"
|
||||||
header-class="border-none"
|
header-class="border-none"
|
||||||
|
|||||||
@@ -156,7 +156,6 @@ if (enableShortcutKey.value) {
|
|||||||
:confirm-text="$t('common.confirm')"
|
:confirm-text="$t('common.confirm')"
|
||||||
:fullscreen-button="false"
|
:fullscreen-button="false"
|
||||||
:title="$t('common.prompt')"
|
:title="$t('common.prompt')"
|
||||||
centered
|
|
||||||
content-class="px-8 min-h-10"
|
content-class="px-8 min-h-10"
|
||||||
footer-class="border-none mb-3 mr-3"
|
footer-class="border-none mb-3 mr-3"
|
||||||
header-class="border-none"
|
header-class="border-none"
|
||||||
|
|||||||
@@ -7,14 +7,14 @@
|
|||||||
<template v-if="formState.loginType === 'password'">
|
<template v-if="formState.loginType === 'password'">
|
||||||
<!-- <div class="login-title">登录</div>-->
|
<!-- <div class="login-title">登录</div>-->
|
||||||
<a-form-item required has-feedback name="username" :rules="rules.username">
|
<a-form-item required has-feedback name="username" :rules="rules.username">
|
||||||
<a-input v-model:value="formState.username" :placeholder="t('authentication.usernamePlaceholder')" autocomplete="off">
|
<a-input v-model:value="formState.username" :placeholder="t('authentication.usernamePlaceholder')" autocomplete="off" @keydown.enter="handleFinish">
|
||||||
<template #prefix>
|
<template #prefix>
|
||||||
<fs-icon icon="ion:phone-portrait-outline"></fs-icon>
|
<fs-icon icon="ion:phone-portrait-outline"></fs-icon>
|
||||||
</template>
|
</template>
|
||||||
</a-input>
|
</a-input>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-form-item has-feedback name="password" :rules="rules.password">
|
<a-form-item has-feedback name="password" :rules="rules.password">
|
||||||
<a-input-password v-model:value="formState.password" :placeholder="t('authentication.passwordPlaceholder')" autocomplete="off">
|
<a-input-password v-model:value="formState.password" :placeholder="t('authentication.passwordPlaceholder')" autocomplete="off" @keyup.enter="handleFinish">
|
||||||
<template #prefix>
|
<template #prefix>
|
||||||
<fs-icon icon="ion:lock-closed-outline"></fs-icon>
|
<fs-icon icon="ion:lock-closed-outline"></fs-icon>
|
||||||
</template>
|
</template>
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
</a-form-item>
|
</a-form-item>
|
||||||
|
|
||||||
<a-form-item v-if="settingStore.sysPublic.captchaEnabled" has-feedback required name="captcha" :rules="rules.captcha">
|
<a-form-item v-if="settingStore.sysPublic.captchaEnabled" has-feedback required name="captcha" :rules="rules.captcha">
|
||||||
<CaptchaInput v-model:model-value="formState.captcha"></CaptchaInput>
|
<CaptchaInput v-model:model-value="formState.captcha" @keydown.enter="handleFinish"></CaptchaInput>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
</template>
|
</template>
|
||||||
</a-tab-pane>
|
</a-tab-pane>
|
||||||
@@ -37,7 +37,7 @@
|
|||||||
</a-form-item>
|
</a-form-item>
|
||||||
|
|
||||||
<a-form-item has-feedback name="smsCaptcha">
|
<a-form-item has-feedback name="smsCaptcha">
|
||||||
<CaptchaInput v-model:model-value="formState.smsCaptcha"></CaptchaInput>
|
<CaptchaInput v-model:model-value="formState.smsCaptcha" @keydown.enter="handleFinish"></CaptchaInput>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
|
|
||||||
<a-form-item name="smsCode" :rules="rules.smsCode">
|
<a-form-item name="smsCode" :rules="rules.smsCode">
|
||||||
@@ -169,7 +169,7 @@ export default defineComponent({
|
|||||||
await userStore.loginByTwoFactor(twoFactor);
|
await userStore.loginByTwoFactor(twoFactor);
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleFinish = async (values: any) => {
|
const handleFinish = async () => {
|
||||||
loading.value = true;
|
loading.value = true;
|
||||||
try {
|
try {
|
||||||
// formState.captcha = await doCaptchaValidate();
|
// formState.captcha = await doCaptchaValidate();
|
||||||
|
|||||||
@@ -3,6 +3,16 @@
|
|||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
||||||
|
|
||||||
|
## [1.37.8](https://github.com/certd/certd/compare/v1.37.7...v1.37.8) (2025-11-17)
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* **plugins/woai-cdn:** 修正默认接口域名与帮助链接中的路径 ([#576](https://github.com/certd/certd/issues/576)) @LjyLab ([d20046c](https://github.com/certd/certd/commit/d20046c86681ea177ece434423b7c81a76b437fb))
|
||||||
|
|
||||||
|
### Performance Improvements
|
||||||
|
|
||||||
|
* 修复西数解析记录添加失败的bug,支持部署证书到西数虚拟主机 ([1102952](https://github.com/certd/certd/commit/1102952b4703e8c0bbc17b0700c0ed3ef6f866d3))
|
||||||
|
|
||||||
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
## [1.37.7](https://github.com/certd/certd/compare/v1.37.6...v1.37.7) (2025-11-12)
|
||||||
|
|
||||||
### Performance Improvements
|
### Performance Improvements
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@certd/ui-server",
|
"name": "@certd/ui-server",
|
||||||
"version": "1.37.7",
|
"version": "1.37.8",
|
||||||
"description": "fast-server base midway",
|
"description": "fast-server base midway",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
@@ -45,20 +45,20 @@
|
|||||||
"@aws-sdk/client-cloudfront": "^3.699.0",
|
"@aws-sdk/client-cloudfront": "^3.699.0",
|
||||||
"@aws-sdk/client-iam": "^3.699.0",
|
"@aws-sdk/client-iam": "^3.699.0",
|
||||||
"@aws-sdk/client-s3": "^3.705.0",
|
"@aws-sdk/client-s3": "^3.705.0",
|
||||||
"@certd/acme-client": "^1.37.7",
|
"@certd/acme-client": "^1.37.8",
|
||||||
"@certd/basic": "^1.37.7",
|
"@certd/basic": "^1.37.8",
|
||||||
"@certd/commercial-core": "^1.37.7",
|
"@certd/commercial-core": "^1.37.8",
|
||||||
"@certd/cv4pve-api-javascript": "^8.4.2",
|
"@certd/cv4pve-api-javascript": "^8.4.2",
|
||||||
"@certd/jdcloud": "^1.37.7",
|
"@certd/jdcloud": "^1.37.8",
|
||||||
"@certd/lib-huawei": "^1.37.7",
|
"@certd/lib-huawei": "^1.37.8",
|
||||||
"@certd/lib-k8s": "^1.37.7",
|
"@certd/lib-k8s": "^1.37.8",
|
||||||
"@certd/lib-server": "^1.37.7",
|
"@certd/lib-server": "^1.37.8",
|
||||||
"@certd/midway-flyway-js": "^1.37.7",
|
"@certd/midway-flyway-js": "^1.37.8",
|
||||||
"@certd/pipeline": "^1.37.7",
|
"@certd/pipeline": "^1.37.8",
|
||||||
"@certd/plugin-cert": "^1.37.7",
|
"@certd/plugin-cert": "^1.37.8",
|
||||||
"@certd/plugin-lib": "^1.37.7",
|
"@certd/plugin-lib": "^1.37.8",
|
||||||
"@certd/plugin-plus": "^1.37.7",
|
"@certd/plugin-plus": "^1.37.8",
|
||||||
"@certd/plus-core": "^1.37.7",
|
"@certd/plus-core": "^1.37.8",
|
||||||
"@huaweicloud/huaweicloud-sdk-cdn": "^3.1.120",
|
"@huaweicloud/huaweicloud-sdk-cdn": "^3.1.120",
|
||||||
"@huaweicloud/huaweicloud-sdk-core": "^3.1.120",
|
"@huaweicloud/huaweicloud-sdk-core": "^3.1.120",
|
||||||
"@koa/cors": "^5.0.0",
|
"@koa/cors": "^5.0.0",
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
|
import { HttpRequestConfig } from '@certd/basic';
|
||||||
import { IsAccess, AccessInput, BaseAccess } from '@certd/pipeline';
|
import { IsAccess, AccessInput, BaseAccess } from '@certd/pipeline';
|
||||||
|
import qs from 'qs';
|
||||||
/**
|
/**
|
||||||
* 这个注解将注册一个授权配置
|
* 这个注解将注册一个授权配置
|
||||||
* 在certd的后台管理系统中,用户可以选择添加此类型的授权
|
* 在certd的后台管理系统中,用户可以选择添加此类型的授权
|
||||||
@@ -55,7 +56,7 @@ export class WestAccess extends BaseAccess {
|
|||||||
component: {
|
component: {
|
||||||
placeholder: '账户级别的key,对整个账户都有管理权限',
|
placeholder: '账户级别的key,对整个账户都有管理权限',
|
||||||
},
|
},
|
||||||
helper: '账户级别的key,对整个账户都有管理权限\n前往https://www.west.cn/manager/API/APIconfig.asp,手动设置“api连接密码”',
|
helper: '账户级别的key,对整个账户都有管理权限\n前往[API接口配置](https://www.west.cn/manager/API/APIconfig.asp),手动设置“api连接密码”',
|
||||||
encrypt: true,
|
encrypt: true,
|
||||||
required: false,
|
required: false,
|
||||||
mergeScript: `
|
mergeScript: `
|
||||||
@@ -88,6 +89,100 @@ export class WestAccess extends BaseAccess {
|
|||||||
`,
|
`,
|
||||||
})
|
})
|
||||||
apidomainkey = '';
|
apidomainkey = '';
|
||||||
|
|
||||||
|
|
||||||
|
@AccessInput({
|
||||||
|
title: "测试",
|
||||||
|
component: {
|
||||||
|
name: "api-test",
|
||||||
|
action: "TestRequest"
|
||||||
|
},
|
||||||
|
helper: "点击测试接口是否正常"
|
||||||
|
})
|
||||||
|
testRequest = true;
|
||||||
|
|
||||||
|
async onTestRequest() {
|
||||||
|
await this.getDomainList();
|
||||||
|
return "ok";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
async getDomainList() {
|
||||||
|
const res = await this.doRequest({
|
||||||
|
url: '/v2/domain',
|
||||||
|
method: 'GET',
|
||||||
|
data:{
|
||||||
|
act:'getdomains',
|
||||||
|
limit:1,
|
||||||
|
page:1
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public async doRequest(req: HttpRequestConfig) {
|
||||||
|
let { url, method, data } = req;
|
||||||
|
if (data == null) {
|
||||||
|
data = {};
|
||||||
|
}
|
||||||
|
if (!method) {
|
||||||
|
method = 'POST';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.scope === 'account') {
|
||||||
|
/**
|
||||||
|
* token text 身份验证字符串,取值为:md5(username+api_password+timestamp),其中:
|
||||||
|
username:您在我司注册的用户名。
|
||||||
|
api_password:您设置的API密码。您可登录官网管理中心,在“代理商管理”-<API接口配置>""页面查看您的api密码。
|
||||||
|
timestamp:当前时间的毫秒时间戳。
|
||||||
|
将字符串username与字符串api_password连接,再与timestamp连接,然后将生成的字符串进行md5求值,md5算法要求为:
|
||||||
|
32位16进制字符串,小写格式。
|
||||||
|
身份验证串有效期10分钟。
|
||||||
|
|
||||||
|
比如,您的用户名为:zhangsan,您的API密码为:5dh232kfg!* ,当前毫秒时间戳为:1554691950854,则:
|
||||||
|
token=md5(zhangsan + 5dh232kfg!* + 1554691950854)=cfcd208495d565ef66e7dff9f98764da
|
||||||
|
*/
|
||||||
|
// data.apikey = this.ctx.utils.hash.md5(this.apikey);
|
||||||
|
data.username = this.username;
|
||||||
|
const timestamp = new Date().getTime();
|
||||||
|
const token = this.ctx.utils.hash.md5(`${this.username}${this.apikey}${timestamp}`).toLowerCase();
|
||||||
|
data.token = token;
|
||||||
|
data.time = timestamp;
|
||||||
|
} else {
|
||||||
|
data.apidomainkey = this.apidomainkey;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const headers = {}
|
||||||
|
const body: any = {}
|
||||||
|
if (method.toUpperCase() === 'POST') {
|
||||||
|
headers['Content-Type'] = 'application/x-www-form-urlencoded';
|
||||||
|
body.data = data
|
||||||
|
} else if (method.toUpperCase() === 'GET') {
|
||||||
|
let queryString = '';
|
||||||
|
if (method.toUpperCase() === 'GET') {
|
||||||
|
queryString = qs.stringify(data);
|
||||||
|
}
|
||||||
|
url = `${url}?${queryString}`
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const res = await this.ctx.http.request<any, any>({
|
||||||
|
baseURL: 'https://api.west.cn/api',
|
||||||
|
url,
|
||||||
|
method,
|
||||||
|
...body,
|
||||||
|
headers,
|
||||||
|
});
|
||||||
|
this.ctx.logger.info(`request ${url} ${method} res:${JSON.stringify(res)}`);
|
||||||
|
if (res.msg !== 'success' && res.result!= 200) {
|
||||||
|
throw new Error(`${JSON.stringify(res.msg)}`);
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
new WestAccess();
|
new WestAccess();
|
||||||
|
|||||||
@@ -4,10 +4,10 @@ import { WestAccess } from './access.js';
|
|||||||
|
|
||||||
type westRecord = {
|
type westRecord = {
|
||||||
// 这里定义Record记录的数据结构,跟对应云平台接口返回值一样即可,一般是拿到id就行,用于删除txt解析记录,清理申请痕迹
|
// 这里定义Record记录的数据结构,跟对应云平台接口返回值一样即可,一般是拿到id就行,用于删除txt解析记录,清理申请痕迹
|
||||||
code: number;
|
result: number;
|
||||||
msg: string;
|
msg: string;
|
||||||
body: {
|
data: {
|
||||||
record_id: number;
|
id: number;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -31,27 +31,6 @@ export class WestDnsProvider extends AbstractDnsProvider<westRecord> {
|
|||||||
//...
|
//...
|
||||||
}
|
}
|
||||||
|
|
||||||
private async doRequestApi(url: string, data: any = null, method = 'post') {
|
|
||||||
if (this.access.scope === 'account') {
|
|
||||||
data.apikey = this.ctx.utils.hash.md5(this.access.apikey);
|
|
||||||
data.username = this.access.username;
|
|
||||||
} else {
|
|
||||||
data.apidomainkey = this.access.apidomainkey;
|
|
||||||
}
|
|
||||||
const res = await this.ctx.http.request<any, any>({
|
|
||||||
url,
|
|
||||||
method,
|
|
||||||
data,
|
|
||||||
headers: {
|
|
||||||
'Content-Type': 'application/x-www-form-urlencoded',
|
|
||||||
},
|
|
||||||
});
|
|
||||||
if (res.msg !== 'success') {
|
|
||||||
throw new Error(`${JSON.stringify(res.msg)}`);
|
|
||||||
}
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 创建dns解析记录,用于验证域名所有权
|
* 创建dns解析记录,用于验证域名所有权
|
||||||
*/
|
*/
|
||||||
@@ -63,22 +42,26 @@ export class WestDnsProvider extends AbstractDnsProvider<westRecord> {
|
|||||||
* type: 'TXT',
|
* type: 'TXT',
|
||||||
* domain: 'example.com'
|
* domain: 'example.com'
|
||||||
*/
|
*/
|
||||||
const { fullRecord, value, type, domain } = options;
|
const { fullRecord, value, type, domain,hostRecord } = options;
|
||||||
this.logger.info('添加域名解析:', fullRecord, value, type, domain);
|
this.logger.info('添加域名解析:', fullRecord, value, type, domain);
|
||||||
|
|
||||||
// 准备要发送到API的请求体
|
// 准备要发送到API的请求体
|
||||||
const requestBody = {
|
const requestBody = {
|
||||||
act: 'dnsrec.add', // API动作类型
|
act: 'adddnsrecord', // API动作类型
|
||||||
domain: domain, // 域名
|
domain: domain, // 域名
|
||||||
record_type: 'TXT', // DNS记录类型
|
type: 'TXT', // DNS记录类型
|
||||||
hostname: fullRecord, // 完整的记录名
|
host: hostRecord, // 完整的记录名
|
||||||
record_value: value, // 记录的值
|
value: value, // 记录的值
|
||||||
record_line: '', // 记录线路
|
line: '', // 记录线路
|
||||||
record_ttl: 60, // TTL (生存时间),设置为60秒
|
ttl: 60, // TTL (生存时间),设置为60秒
|
||||||
};
|
};
|
||||||
|
|
||||||
const url = 'https://api.west.cn/API/v2/domain/dns/';
|
const url = '/v2/domain/';
|
||||||
const res = await this.doRequestApi(url, requestBody);
|
const res = await this.access.doRequest({
|
||||||
|
url,
|
||||||
|
method:'POST',
|
||||||
|
data: requestBody,
|
||||||
|
});
|
||||||
const record = res as westRecord;
|
const record = res as westRecord;
|
||||||
this.logger.info(`添加域名解析成功:fullRecord=${fullRecord},value=${value}`);
|
this.logger.info(`添加域名解析成功:fullRecord=${fullRecord},value=${value}`);
|
||||||
this.logger.info(`dns解析记录:${JSON.stringify(record)}`);
|
this.logger.info(`dns解析记录:${JSON.stringify(record)}`);
|
||||||
@@ -90,6 +73,7 @@ export class WestDnsProvider extends AbstractDnsProvider<westRecord> {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除dns解析记录,清理申请痕迹
|
* 删除dns解析记录,清理申请痕迹
|
||||||
|
* https://console-docs.apipost.cn/preview/ab2c3103b22855ba/fac91d1e43fafb69?target_id=c4564349-6687-413d-a3d4-b0e8db5b34b2
|
||||||
* @param options
|
* @param options
|
||||||
*/
|
*/
|
||||||
async removeRecord(options: RemoveRecordOptions<westRecord>): Promise<void> {
|
async removeRecord(options: RemoveRecordOptions<westRecord>): Promise<void> {
|
||||||
@@ -104,16 +88,17 @@ export class WestDnsProvider extends AbstractDnsProvider<westRecord> {
|
|||||||
|
|
||||||
// 准备要发送到API的请求体
|
// 准备要发送到API的请求体
|
||||||
const requestBody = {
|
const requestBody = {
|
||||||
act: 'dnsrec.remove', // API动作类型
|
act: 'deldnsrecord', // API动作类型
|
||||||
domain: domain, // 域名
|
domain: domain, // 域名
|
||||||
record_id: record.body.record_id,
|
id: record.data?.id,
|
||||||
hostname: fullRecord, // 完整的记录名
|
|
||||||
record_type: 'TXT', // DNS记录类型
|
|
||||||
record_line: '', // 记录线路
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const url = 'https://api.west.cn/API/v2/domain/dns/';
|
const url = '/v2/domain/';
|
||||||
const res = await this.doRequestApi(url, requestBody);
|
const res = await this.access.doRequest({
|
||||||
|
url,
|
||||||
|
method:'POST',
|
||||||
|
data: requestBody,
|
||||||
|
});
|
||||||
const result = res.result;
|
const result = res.result;
|
||||||
this.logger.info('删除域名解析成功:', fullRecord, value, JSON.stringify(result));
|
this.logger.info('删除域名解析成功:', fullRecord, value, JSON.stringify(result));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,2 +1,3 @@
|
|||||||
export * from './dns-provider.js';
|
export * from './dns-provider.js';
|
||||||
export * from './access.js';
|
export * from './access.js';
|
||||||
|
export * from './plugins/deploy-to-vhost.js';
|
||||||
@@ -0,0 +1,227 @@
|
|||||||
|
import {
|
||||||
|
AbstractTaskPlugin,
|
||||||
|
IsTaskPlugin,
|
||||||
|
PageSearch,
|
||||||
|
pluginGroups,
|
||||||
|
RunStrategy,
|
||||||
|
TaskInput
|
||||||
|
} from "@certd/pipeline";
|
||||||
|
import { CertApplyPluginNames, CertInfo } from "@certd/plugin-cert";
|
||||||
|
import { createCertDomainGetterInputDefine, createRemoteSelectInputDefine } from "@certd/plugin-lib";
|
||||||
|
import { WestAccess } from "../access.js";
|
||||||
|
|
||||||
|
@IsTaskPlugin({
|
||||||
|
//命名规范,插件类型+功能(就是目录plugin-demo中的demo),大写字母开头,驼峰命名
|
||||||
|
name: "WestDeployToVhost",
|
||||||
|
title: "西数-部署到虚拟主机",
|
||||||
|
desc: "西部数码部署证书到虚拟主机",
|
||||||
|
icon: "svg:icon-lucky",
|
||||||
|
//插件分组
|
||||||
|
group: pluginGroups.cdn.key,
|
||||||
|
needPlus: false,
|
||||||
|
default: {
|
||||||
|
//默认值配置照抄即可
|
||||||
|
strategy: {
|
||||||
|
runStrategy: RunStrategy.SkipWhenSucceed
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
//类名规范,跟上面插件名称(name)一致
|
||||||
|
export class WestDeployToVhost extends AbstractTaskPlugin {
|
||||||
|
//证书选择,此项必须要有
|
||||||
|
@TaskInput({
|
||||||
|
title: "域名证书",
|
||||||
|
helper: "请选择前置任务输出的域名证书",
|
||||||
|
component: {
|
||||||
|
name: "output-selector",
|
||||||
|
from: [...CertApplyPluginNames]
|
||||||
|
}
|
||||||
|
// required: true, // 必填
|
||||||
|
})
|
||||||
|
cert!: CertInfo;
|
||||||
|
|
||||||
|
@TaskInput(createCertDomainGetterInputDefine({ props: { required: false } }))
|
||||||
|
certDomains!: string[];
|
||||||
|
|
||||||
|
|
||||||
|
//授权选择框
|
||||||
|
@TaskInput({
|
||||||
|
title: "西数授权",
|
||||||
|
component: {
|
||||||
|
name: "access-selector",
|
||||||
|
type: "west" //固定授权类型
|
||||||
|
},
|
||||||
|
required: true //必填
|
||||||
|
})
|
||||||
|
accessId!: string;
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
@TaskInput(
|
||||||
|
createRemoteSelectInputDefine({
|
||||||
|
title: "虚拟主机列表",
|
||||||
|
helper: "虚拟主机列表",
|
||||||
|
action: WestDeployToVhost.prototype.onGetVhostList.name,
|
||||||
|
pager: false,
|
||||||
|
search: false
|
||||||
|
})
|
||||||
|
)
|
||||||
|
vhostList!: string[];
|
||||||
|
|
||||||
|
// @TaskInput(
|
||||||
|
// createRemoteSelectInputDefine({
|
||||||
|
// title: "证书Id",
|
||||||
|
// helper: "要部署的西数证书id",
|
||||||
|
// action: WestDeployToVhost.prototype.onGetCertList.name,
|
||||||
|
// pager: false,
|
||||||
|
// search: false
|
||||||
|
// })
|
||||||
|
// )
|
||||||
|
// certList!: string[];
|
||||||
|
|
||||||
|
//插件实例化时执行的方法
|
||||||
|
async onInstance() {
|
||||||
|
}
|
||||||
|
|
||||||
|
//插件执行方法
|
||||||
|
async execute(): Promise<void> {
|
||||||
|
const access = await this.getAccess<WestAccess>(this.accessId);
|
||||||
|
|
||||||
|
for (const item of this.vhostList) {
|
||||||
|
this.logger.info(`----------- 开始更新证书到虚拟主机:${item}`);
|
||||||
|
const arr = item.split("_");
|
||||||
|
const sitename = arr[1];
|
||||||
|
await this.uploadCert({access,sitename});
|
||||||
|
await this.ctx.utils.sleep(2000);
|
||||||
|
const res = await this.getVhostSslInfo({access,sitename});
|
||||||
|
this.logger.info(`----------- 虚拟主机${sitename}证书信息:${JSON.stringify(res)}`);
|
||||||
|
this.logger.info(`----------- 更新证书${item}成功`);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.logger.info("部署完成");
|
||||||
|
}
|
||||||
|
|
||||||
|
// async onGetCertList(data: PageSearch = {}) {
|
||||||
|
// const access = await this.getAccess<WestAccess>(this.accessId);
|
||||||
|
|
||||||
|
// const list = await access.getCertList({});
|
||||||
|
// if (!list || list.length === 0) {
|
||||||
|
// throw new Error("没有找到证书,请先在控制台上传一次证书且关联域名");
|
||||||
|
// }
|
||||||
|
|
||||||
|
// /**
|
||||||
|
// * certificate-id
|
||||||
|
// * name
|
||||||
|
// * dns-names
|
||||||
|
// */
|
||||||
|
// const options = list.map((item: any) => {
|
||||||
|
// const domains = item["dns-names"]
|
||||||
|
// const certId = item["certificate-id"];
|
||||||
|
// return {
|
||||||
|
// label: `${item.name}<${certId}-${domains[0]}>`,
|
||||||
|
// value: certId,
|
||||||
|
// domain: item["dns-names"]
|
||||||
|
// };
|
||||||
|
// });
|
||||||
|
// return {
|
||||||
|
// list: this.ctx.utils.options.buildGroupOptions(options, this.certDomains),
|
||||||
|
// total: list.length,
|
||||||
|
// pageNo: 1,
|
||||||
|
// pageSize: list.length
|
||||||
|
// };
|
||||||
|
// }
|
||||||
|
|
||||||
|
async uploadCert(req:{access:any,sitename:string}){
|
||||||
|
const {access,sitename} = req;
|
||||||
|
const data = {
|
||||||
|
/**
|
||||||
|
* act
|
||||||
|
vhostssl
|
||||||
|
是
|
||||||
|
String
|
||||||
|
sitename
|
||||||
|
westly
|
||||||
|
是
|
||||||
|
String
|
||||||
|
cmd
|
||||||
|
import
|
||||||
|
是
|
||||||
|
String
|
||||||
|
openssl/closessl 部署/关闭
|
||||||
|
keycontent
|
||||||
|
是
|
||||||
|
String
|
||||||
|
私匙
|
||||||
|
certcontent
|
||||||
|
*/
|
||||||
|
act:"vhostssl",
|
||||||
|
sitename:sitename,
|
||||||
|
westly:"1",
|
||||||
|
cmd:"import",
|
||||||
|
opensslclosessl:"openssl",
|
||||||
|
keycontent:this.cert.key,
|
||||||
|
certcontent:this.cert.crt,
|
||||||
|
}
|
||||||
|
|
||||||
|
const res = await access.doRequest({
|
||||||
|
url: `/v2/vhost/`,
|
||||||
|
method:"POST",
|
||||||
|
data:data
|
||||||
|
});
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
async getVhostSslInfo(req:{access:any,sitename:string}){
|
||||||
|
const {access,sitename} = req;
|
||||||
|
const data = {
|
||||||
|
act:"vhostssl",
|
||||||
|
sitename:sitename,
|
||||||
|
cmd:"info",
|
||||||
|
}
|
||||||
|
const res = await access.doRequest({
|
||||||
|
url: `/v2/vhost/`,
|
||||||
|
method:"POST",
|
||||||
|
data:data
|
||||||
|
});
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
async onGetVhostList(data: PageSearch = {}) {
|
||||||
|
const access = await this.getAccess<WestAccess>(this.accessId);
|
||||||
|
|
||||||
|
const res = await access.doRequest({
|
||||||
|
url: `/v2/vhost/`,
|
||||||
|
method:"POST",
|
||||||
|
data:{
|
||||||
|
act:"sync",
|
||||||
|
westid: 1,
|
||||||
|
}
|
||||||
|
});
|
||||||
|
const list = res.data
|
||||||
|
if (!list || list.length === 0) {
|
||||||
|
throw new Error("没有找到虚拟主机");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* certificate-id
|
||||||
|
* name
|
||||||
|
* dns-names
|
||||||
|
*/
|
||||||
|
const options = list.map((item: any) => {
|
||||||
|
return {
|
||||||
|
label: `${item.sitename}<${item.westid}-${item.bindings}>`,
|
||||||
|
value: `${item.westid}_${item.sitename}`,
|
||||||
|
domain: item.bindings.split(",")
|
||||||
|
};
|
||||||
|
});
|
||||||
|
return {
|
||||||
|
list: this.ctx.utils.options.buildGroupOptions(options, this.certDomains),
|
||||||
|
total: list.length,
|
||||||
|
pageNo: 1,
|
||||||
|
pageSize: list.length
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//实例化一下,注册插件
|
||||||
|
new WestDeployToVhost();
|
||||||
Reference in New Issue
Block a user