refactor: move

This commit is contained in:
xiaojunnuo
2021-02-08 00:21:36 +08:00
parent cfb1034450
commit 82f86d9556
150 changed files with 14691 additions and 2059 deletions
+3 -3
View File
@@ -8,9 +8,9 @@ node_modules/
/*.log /*.log
/ui/*/.idea /packages/ui/*/.idea
/ui/*/node_modules /packages/ui/*/node_modules
/packages/*/node_modules /packages/*/node_modules
/ui/certd-server/tmp/ /packages/ui/certd-server/tmp/
+1 -2
View File
@@ -1,7 +1,6 @@
{ {
"packages": [ "packages": [
"packages/*", "packages/*/*"
"ui/*"
], ],
"version": "0.1.14" "version": "0.1.14"
} }
File diff suppressed because it is too large Load Diff
-24
View File
@@ -1,24 +0,0 @@
{
"name": "@certd/access-providers",
"version": "0.1.13",
"description": "",
"main": "./src/index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"type": "module",
"author": "Greper",
"license": "MIT",
"dependencies": {
"@certd/api": "^0.1.13",
"lodash-es": "^4.17.20"
},
"devDependencies": {
"eslint": "^7.15.0",
"eslint-config-standard": "^16.0.2",
"eslint-plugin-import": "^2.22.1",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^4.2.1"
},
"gitHead": "4a421d5b142d453203c68ce6d1036e168ea2455b"
}
-21
View File
@@ -1,21 +0,0 @@
import _ from 'lodash-es'
import { accessProviderRegistry } from '@certd/api'
import { AliyunAccessProvider } from './providers/aliyun.js'
import { DnspodAccessProvider } from './providers/dnspod.js'
import { TencentAccessProvider } from './providers/tencent.js'
import { SSHAccessProvider } from './providers/ssh.js'
export const DefaultAccessProviders = {
AliyunAccessProvider,
DnspodAccessProvider,
TencentAccessProvider,
SSHAccessProvider
}
export default {
install () {
_.forEach(DefaultAccessProviders, item => {
accessProviderRegistry.install(item)
})
}
}
-5
View File
@@ -1,5 +0,0 @@
export * from './dns-provider/index.js'
export * from './plugin/index.js'
export * from './access-provider/index.js'
export { Store } from './store/store.js'
export { util } from './utils/index.js'
@@ -2,7 +2,7 @@
"name": "@certd/api", "name": "@certd/api",
"version": "0.1.13", "version": "0.1.13",
"description": "", "description": "",
"main": "./src/index.js", "main": "src/index.js",
"type": "module", "type": "module",
"author": "Greper", "author": "Greper",
"license": "MIT", "license": "MIT",
+5
View File
@@ -0,0 +1,5 @@
export * from './dns-provider'
export * from './plugin'
export * from './access-provider'
export { Store } from './store/store.js'
export { util } from './utils'
@@ -2,9 +2,9 @@
"name": "@certd/certd", "name": "@certd/certd",
"version": "0.1.13", "version": "0.1.13",
"description": "", "description": "",
"main": "./src/index.js", "main": "src/index.js",
"scripts": { "scripts": {
"test": "echo \"Error: no test specified\" && exit 1" "test": "echo \\\"Error: no test specified\\\" && exit 1"
}, },
"type": "module", "type": "module",
"author": "Greper", "author": "Greper",
@@ -12,7 +12,6 @@
"dependencies": { "dependencies": {
"@certd/acme-client": "^0.1.6", "@certd/acme-client": "^0.1.6",
"@certd/api": "^0.1.13", "@certd/api": "^0.1.13",
"@certd/dns-providers": "^0.1.13",
"dayjs": "^1.9.7", "dayjs": "^1.9.7",
"lodash-es": "^4.17.20", "lodash-es": "^4.17.20",
"node-forge": "^0.10.0" "node-forge": "^0.10.0"
@@ -1,6 +1,6 @@
import pkg from 'chai' import pkg from 'chai'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
import { Certd } from '../../src/index.js' import { Certd } from '../../src'
const { expect } = pkg const { expect } = pkg
describe('AliyunDnsProvider', function () { describe('AliyunDnsProvider', function () {
it('#申请证书-aliyun', async function () { it('#申请证书-aliyun', async function () {
@@ -1,6 +1,6 @@
import pkg from 'chai' import pkg from 'chai'
import { Certd } from '../../src/index.js' import { Certd } from '../../src'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('DnspodDnsProvider', function () { describe('DnspodDnsProvider', function () {
it('#申请证书', async function () { it('#申请证书', async function () {
@@ -1,6 +1,6 @@
import chai from 'chai' import chai from 'chai'
import { Certd } from '../src/index.js' import { Certd } from '../src'
import { createOptions } from '../../../test/options.js' import { createOptions } from '../../../../test/options.js'
const { expect } = chai const { expect } = chai
const fakeCrt = `-----BEGIN CERTIFICATE----- const fakeCrt = `-----BEGIN CERTIFICATE-----
MIIFSTCCBDGgAwIBAgITAPoZZk/LhVIyXoic2NnJyxubezANBgkqhkiG9w0BAQsF MIIFSTCCBDGgAwIBAgITAPoZZk/LhVIyXoic2NnJyxubezANBgkqhkiG9w0BAQsF
@@ -4,7 +4,7 @@
"description": "", "description": "",
"main": "src/index.js", "main": "src/index.js",
"scripts": { "scripts": {
"test": "echo \"Error: no test specified\" && exit 1", "test": "echo \\\"Error: no test specified\\\" && exit 1",
"build": "webpack --config webpack.config.cjs ", "build": "webpack --config webpack.config.cjs ",
"rollup": "rollup --config rollup.config.js" "rollup": "rollup --config rollup.config.js"
}, },
@@ -3,12 +3,16 @@ import { pluginRegistry, util } from '@certd/api'
import _ from 'lodash-es' import _ from 'lodash-es'
import dayjs from 'dayjs' import dayjs from 'dayjs'
import { Trace } from './trace.js' import { Trace } from './trace.js'
import DefaultPlugins from '@certd/plugins' import PluginAliyun from '@certd/plugin-aliyun'
import PluginTencent from '@certd/plugin-tencent'
const logger = util.logger import PluginHost from '@certd/plugin-host'
// 安装默认插件和授权提供者 // 安装默认插件和授权提供者
DefaultPlugins.install() PluginAliyun.install()
PluginTencent.install()
PluginHost.install()
const logger = util.logger
function createDefaultOptions () { function createDefaultOptions () {
return { return {
@@ -1,6 +1,6 @@
import pkg from 'chai' import pkg from 'chai'
import { Executor } from '../src/index.js' import { Executor } from '../src'
import { createOptions } from '../../../test/options.js' import { createOptions } from '../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('AutoDeploy', function () { describe('AutoDeploy', function () {
-29
View File
@@ -1,29 +0,0 @@
{
"name": "@certd/dns-providers",
"version": "0.1.13",
"description": "",
"main": "./src/index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"private": false,
"type": "module",
"author": "Greper",
"license": "MIT",
"dependencies": {
"@alicloud/pop-core": "^1.7.10",
"@certd/api": "^0.1.13",
"lodash-es": "^4.17.20",
"tencentcloud-sdk-nodejs": "^4.0.44"
},
"devDependencies": {
"chai": "^4.2.0",
"eslint": "^7.15.0",
"eslint-config-standard": "^16.0.2",
"eslint-plugin-import": "^2.22.1",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^4.2.1",
"mocha": "^8.2.1"
},
"gitHead": "4a421d5b142d453203c68ce6d1036e168ea2455b"
}
-16
View File
@@ -1,16 +0,0 @@
import _ from 'lodash-es'
import { AliyunDnsProvider } from './providers/aliyun.js'
import { DnspodDnsProvider } from './providers/dnspod.js'
import { dnsProviderRegistry } from '@certd/api'
export const DefaultDnsProviders = {
AliyunDnsProvider,
DnspodDnsProvider
}
export default {
install () {
_.forEach(DefaultDnsProviders, item => {
dnsProviderRegistry.install(item)
})
}
}
@@ -131,6 +131,18 @@
"to-fast-properties": "^2.0.0" "to-fast-properties": "^2.0.0"
} }
}, },
"@certd/api": {
"version": "0.1.13",
"resolved": "https://registry.npm.taobao.org/@certd/api/download/@certd/api-0.1.13.tgz",
"integrity": "sha1-ProCS1OfZAWzr3bIKHHfZA5hrOw=",
"requires": {
"axios": "^0.21.1",
"dayjs": "^1.9.7",
"lodash-es": "^4.17.20",
"log4js": "^6.3.0",
"qs": "^6.9.4"
}
},
"@eslint/eslintrc": { "@eslint/eslintrc": {
"version": "0.2.2", "version": "0.2.2",
"resolved": "https://registry.npm.taobao.org/@eslint/eslintrc/download/@eslint/eslintrc-0.2.2.tgz?cache=0&sync_timestamp=1607145629875&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40eslint%2Feslintrc%2Fdownload%2F%40eslint%2Feslintrc-0.2.2.tgz", "resolved": "https://registry.npm.taobao.org/@eslint/eslintrc/download/@eslint/eslintrc-0.2.2.tgz?cache=0&sync_timestamp=1607145629875&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2F%40eslint%2Feslintrc%2Fdownload%2F%40eslint%2Feslintrc-0.2.2.tgz",
@@ -476,6 +488,14 @@
"resolved": "https://registry.npm.taobao.org/aws4/download/aws4-1.11.0.tgz?cache=0&sync_timestamp=1604101166484&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faws4%2Fdownload%2Faws4-1.11.0.tgz", "resolved": "https://registry.npm.taobao.org/aws4/download/aws4-1.11.0.tgz?cache=0&sync_timestamp=1604101166484&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faws4%2Fdownload%2Faws4-1.11.0.tgz",
"integrity": "sha1-1h9G2DslGSUOJ4Ta9bCUeai0HFk=" "integrity": "sha1-1h9G2DslGSUOJ4Ta9bCUeai0HFk="
}, },
"axios": {
"version": "0.21.1",
"resolved": "https://registry.npm.taobao.org/axios/download/axios-0.21.1.tgz?cache=0&sync_timestamp=1608609215811&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faxios%2Fdownload%2Faxios-0.21.1.tgz",
"integrity": "sha1-IlY0gZYvTWvemnbVFu8OXTwJsrg=",
"requires": {
"follow-redirects": "^1.10.0"
}
},
"babel-eslint": { "babel-eslint": {
"version": "10.1.0", "version": "10.1.0",
"resolved": "https://registry.npm.taobao.org/babel-eslint/download/babel-eslint-10.1.0.tgz?cache=0&sync_timestamp=1599054223324&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbabel-eslint%2Fdownload%2Fbabel-eslint-10.1.0.tgz", "resolved": "https://registry.npm.taobao.org/babel-eslint/download/babel-eslint-10.1.0.tgz?cache=0&sync_timestamp=1599054223324&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbabel-eslint%2Fdownload%2Fbabel-eslint-10.1.0.tgz",
@@ -762,6 +782,11 @@
"assert-plus": "^1.0.0" "assert-plus": "^1.0.0"
} }
}, },
"date-format": {
"version": "3.0.0",
"resolved": "https://registry.npm.taobao.org/date-format/download/date-format-3.0.0.tgz",
"integrity": "sha1-64eANlx9KxURB4+0keZHl4DzrZU="
},
"dayjs": { "dayjs": {
"version": "1.10.2", "version": "1.10.2",
"resolved": "https://registry.npm.taobao.org/dayjs/download/dayjs-1.10.2.tgz?cache=0&sync_timestamp=1609889274763&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdayjs%2Fdownload%2Fdayjs-1.10.2.tgz", "resolved": "https://registry.npm.taobao.org/dayjs/download/dayjs-1.10.2.tgz?cache=0&sync_timestamp=1609889274763&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdayjs%2Fdownload%2Fdayjs-1.10.2.tgz",
@@ -1406,6 +1431,16 @@
} }
} }
}, },
"flatted": {
"version": "2.0.2",
"resolved": "https://registry.npm.taobao.org/flatted/download/flatted-2.0.2.tgz?cache=0&sync_timestamp=1611061309017&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fflatted%2Fdownload%2Fflatted-2.0.2.tgz",
"integrity": "sha1-RXWyHivO50NKqb5mL0t7X5wrUTg="
},
"follow-redirects": {
"version": "1.13.2",
"resolved": "https://registry.npm.taobao.org/follow-redirects/download/follow-redirects-1.13.2.tgz?cache=0&sync_timestamp=1611606737937&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ffollow-redirects%2Fdownload%2Ffollow-redirects-1.13.2.tgz",
"integrity": "sha1-3XPI7/wScoulz0JZ12DqX7g+MUc="
},
"forever-agent": { "forever-agent": {
"version": "0.6.1", "version": "0.6.1",
"resolved": "https://registry.npm.taobao.org/forever-agent/download/forever-agent-0.6.1.tgz", "resolved": "https://registry.npm.taobao.org/forever-agent/download/forever-agent-0.6.1.tgz",
@@ -1421,6 +1456,16 @@
"mime-types": "^2.1.12" "mime-types": "^2.1.12"
} }
}, },
"fs-extra": {
"version": "8.1.0",
"resolved": "https://registry.npm.taobao.org/fs-extra/download/fs-extra-8.1.0.tgz?cache=0&sync_timestamp=1611075469998&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ffs-extra%2Fdownload%2Ffs-extra-8.1.0.tgz",
"integrity": "sha1-SdQ8RaiM2Wd2aMt74bRu/bjS4cA=",
"requires": {
"graceful-fs": "^4.2.0",
"jsonfile": "^4.0.0",
"universalify": "^0.1.0"
}
},
"fs.realpath": { "fs.realpath": {
"version": "1.0.0", "version": "1.0.0",
"resolved": "https://registry.npm.taobao.org/fs.realpath/download/fs.realpath-1.0.0.tgz", "resolved": "https://registry.npm.taobao.org/fs.realpath/download/fs.realpath-1.0.0.tgz",
@@ -1537,8 +1582,7 @@
"graceful-fs": { "graceful-fs": {
"version": "4.2.4", "version": "4.2.4",
"resolved": "https://registry.npm.taobao.org/graceful-fs/download/graceful-fs-4.2.4.tgz", "resolved": "https://registry.npm.taobao.org/graceful-fs/download/graceful-fs-4.2.4.tgz",
"integrity": "sha1-Ila94U02MpWMRl68ltxGfKB6Kfs=", "integrity": "sha1-Ila94U02MpWMRl68ltxGfKB6Kfs="
"dev": true
}, },
"growl": { "growl": {
"version": "1.10.5", "version": "1.10.5",
@@ -1923,6 +1967,14 @@
"minimist": "^1.2.0" "minimist": "^1.2.0"
} }
}, },
"jsonfile": {
"version": "4.0.0",
"resolved": "https://registry.npm.taobao.org/jsonfile/download/jsonfile-4.0.0.tgz?cache=0&sync_timestamp=1604161797011&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fjsonfile%2Fdownload%2Fjsonfile-4.0.0.tgz",
"integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=",
"requires": {
"graceful-fs": "^4.1.6"
}
},
"jsonpath-plus": { "jsonpath-plus": {
"version": "0.19.0", "version": "0.19.0",
"resolved": "https://registry.npm.taobao.org/jsonpath-plus/download/jsonpath-plus-0.19.0.tgz", "resolved": "https://registry.npm.taobao.org/jsonpath-plus/download/jsonpath-plus-0.19.0.tgz",
@@ -2083,6 +2135,33 @@
} }
} }
}, },
"log4js": {
"version": "6.3.0",
"resolved": "https://registry.npm.taobao.org/log4js/download/log4js-6.3.0.tgz",
"integrity": "sha1-EN+vu0NDUaPjAnegC5h5RG9xW8s=",
"requires": {
"date-format": "^3.0.0",
"debug": "^4.1.1",
"flatted": "^2.0.1",
"rfdc": "^1.1.4",
"streamroller": "^2.2.4"
},
"dependencies": {
"debug": {
"version": "4.3.1",
"resolved": "https://registry.npm.taobao.org/debug/download/debug-4.3.1.tgz?cache=0&sync_timestamp=1607566533140&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdebug%2Fdownload%2Fdebug-4.3.1.tgz",
"integrity": "sha1-8NIpxQXgxtjEmsVT0bE9wYP2su4=",
"requires": {
"ms": "2.1.2"
}
},
"ms": {
"version": "2.1.2",
"resolved": "https://registry.npm.taobao.org/ms/download/ms-2.1.2.tgz?cache=0&sync_timestamp=1607433842694&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.2.tgz",
"integrity": "sha1-0J0fNXtEP0kzgqjrPM0YOHKuYAk="
}
}
},
"loose-envify": { "loose-envify": {
"version": "1.4.0", "version": "1.4.0",
"resolved": "https://registry.npm.taobao.org/loose-envify/download/loose-envify-1.4.0.tgz", "resolved": "https://registry.npm.taobao.org/loose-envify/download/loose-envify-1.4.0.tgz",
@@ -2795,6 +2874,11 @@
"lowercase-keys": "^1.0.0" "lowercase-keys": "^1.0.0"
} }
}, },
"rfdc": {
"version": "1.2.0",
"resolved": "https://registry.npm.taobao.org/rfdc/download/rfdc-1.2.0.tgz?cache=0&sync_timestamp=1610744108114&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Frfdc%2Fdownload%2Frfdc-1.2.0.tgz",
"integrity": "sha1-npiUJY9I8oS0PDFDxoBwpPNzuUk="
},
"rimraf": { "rimraf": {
"version": "3.0.2", "version": "3.0.2",
"resolved": "https://registry.npm.taobao.org/rimraf/download/rimraf-3.0.2.tgz?cache=0&sync_timestamp=1599054104695&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Frimraf%2Fdownload%2Frimraf-3.0.2.tgz", "resolved": "https://registry.npm.taobao.org/rimraf/download/rimraf-3.0.2.tgz?cache=0&sync_timestamp=1599054104695&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Frimraf%2Fdownload%2Frimraf-3.0.2.tgz",
@@ -2991,6 +3075,36 @@
"tweetnacl": "~0.14.0" "tweetnacl": "~0.14.0"
} }
}, },
"streamroller": {
"version": "2.2.4",
"resolved": "https://registry.npm.taobao.org/streamroller/download/streamroller-2.2.4.tgz",
"integrity": "sha1-wZjO1C25QIamGTYIGHzoCl8rDlM=",
"requires": {
"date-format": "^2.1.0",
"debug": "^4.1.1",
"fs-extra": "^8.1.0"
},
"dependencies": {
"date-format": {
"version": "2.1.0",
"resolved": "https://registry.npm.taobao.org/date-format/download/date-format-2.1.0.tgz",
"integrity": "sha1-MdW16iEc9f12TNOLr50DPffhJc8="
},
"debug": {
"version": "4.3.1",
"resolved": "https://registry.npm.taobao.org/debug/download/debug-4.3.1.tgz?cache=0&sync_timestamp=1607566533140&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fdebug%2Fdownload%2Fdebug-4.3.1.tgz",
"integrity": "sha1-8NIpxQXgxtjEmsVT0bE9wYP2su4=",
"requires": {
"ms": "2.1.2"
}
},
"ms": {
"version": "2.1.2",
"resolved": "https://registry.npm.taobao.org/ms/download/ms-2.1.2.tgz?cache=0&sync_timestamp=1607433842694&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fms%2Fdownload%2Fms-2.1.2.tgz",
"integrity": "sha1-0J0fNXtEP0kzgqjrPM0YOHKuYAk="
}
}
},
"streamsearch": { "streamsearch": {
"version": "0.1.2", "version": "0.1.2",
"resolved": "https://registry.npm.taobao.org/streamsearch/download/streamsearch-0.1.2.tgz", "resolved": "https://registry.npm.taobao.org/streamsearch/download/streamsearch-0.1.2.tgz",
@@ -3215,6 +3329,11 @@
"resolved": "https://registry.npm.taobao.org/underscore/download/underscore-1.12.0.tgz?cache=0&sync_timestamp=1606179462980&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funderscore%2Fdownload%2Funderscore-1.12.0.tgz", "resolved": "https://registry.npm.taobao.org/underscore/download/underscore-1.12.0.tgz?cache=0&sync_timestamp=1606179462980&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funderscore%2Fdownload%2Funderscore-1.12.0.tgz",
"integrity": "sha1-SBSUBVH8gFh873hA0euw8WRTvpc=" "integrity": "sha1-SBSUBVH8gFh873hA0euw8WRTvpc="
}, },
"universalify": {
"version": "0.1.2",
"resolved": "https://registry.npm.taobao.org/universalify/download/universalify-0.1.2.tgz?cache=0&sync_timestamp=1603179967633&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Funiversalify%2Fdownload%2Funiversalify-0.1.2.tgz",
"integrity": "sha1-tkb2m+OULavOzJ1mOcgNwQXvqmY="
},
"uri-js": { "uri-js": {
"version": "4.4.0", "version": "4.4.0",
"resolved": "https://registry.npm.taobao.org/uri-js/download/uri-js-4.4.0.tgz", "resolved": "https://registry.npm.taobao.org/uri-js/download/uri-js-4.4.0.tgz",
@@ -0,0 +1,25 @@
{
"name": "@certd/plugin-aliyun",
"version": "0.1.13",
"description": "",
"main": "src/index.js",
"type": "module",
"dependencies": {
"@alicloud/pop-core": "^1.7.10",
"@certd/api": "^0.1.13",
"dayjs": "^1.9.7",
"lodash-es": "^4.17.20"
},
"devDependencies": {
"chai": "^4.2.0",
"eslint": "^7.15.0",
"eslint-config-standard": "^16.0.2",
"eslint-plugin-import": "^2.22.1",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^4.2.1",
"mocha": "^8.2.1"
},
"author": "Greper",
"license": "MIT",
"gitHead": "4a421d5b142d453203c68ce6d1036e168ea2455b"
}
@@ -1,6 +1,10 @@
import _ from 'lodash-es' import _ from 'lodash-es'
import { UploadCertToAliyun } from './aliyun/upload-to-aliyun/index.js'
import { DeployCertToAliyunCDN } from './aliyun/deploy-to-cdn/index.js' import { AliyunDnsProvider, AliyunAccessProvider } from './access-providers/aliyun'
import { UploadCertToAliyun } from './plugins/upload-to-aliyun'
import { DeployCertToAliyunCDN } from './plugins/deploy-to-cdn'
import { UploadCertToTencent } from './tencent/upload-to-tencent/index.js' import { UploadCertToTencent } from './tencent/upload-to-tencent/index.js'
@@ -13,9 +17,9 @@ import { DeployCertToTencentTKEIngress } from './tencent/deploy-to-tke-ingress/i
import { UploadCertToHost } from './host/upload-to-host/index.js' import { UploadCertToHost } from './host/upload-to-host/index.js'
import { HostShellExecute } from './host/host-shell-execute/index.js' import { HostShellExecute } from './host/host-shell-execute/index.js'
import { pluginRegistry } from '@certd/api' import { pluginRegistry, accessProviderRegister, dnsProviderRegistry } from '@certd/api'
export const DefaultPlugins = { export const Plugins = {
UploadCertToAliyun, UploadCertToAliyun,
DeployCertToAliyunCDN, DeployCertToAliyunCDN,
UploadCertToTencent, UploadCertToTencent,
@@ -27,8 +31,12 @@ export const DefaultPlugins = {
} }
export default { export default {
install () { install () {
_.forEach(DefaultPlugins, item => { _.forEach(Plugins, item => {
pluginRegistry.install(item) pluginRegistry.install(item)
}) })
accessProviderRegister.install(AliyunAccessProvider)
dnsProviderRegistry.install(AliyunDnsProvider)
} }
} }
@@ -1,4 +1,4 @@
import { AbstractAliyunPlugin } from '../../aliyun/abstract-aliyun.js' import { AbstractAliyunPlugin } from '../abstract-aliyun.js'
import Core from '@alicloud/pop-core' import Core from '@alicloud/pop-core'
import dayjs from 'dayjs' import dayjs from 'dayjs'
@@ -1,6 +1,6 @@
import pkg from 'chai' import pkg from 'chai'
import AliyunDnsProvider from '../../src/providers/aliyun.js' import AliyunDnsProvider from '../../src/dns-providers/aliyun.js'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('AliyunDnsProvider', function () { describe('AliyunDnsProvider', function () {
it('#getDomainList', async function () { it('#getDomainList', async function () {
@@ -1,8 +1,9 @@
import pkg from 'chai' import pkg from 'chai'
import { DeployCertToAliyunCDN } from '../../src/aliyun/deploy-to-cdn/index.js' import { DeployCertToAliyunCDN } from '../../src/plugins/deploy-to-cdn/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import createOptions from '../../../../test/options.js' import createOptions from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('DeployToAliyunCDN', function () { describe('DeployToAliyunCDN', function () {
it('#execute', async function () { it('#execute', async function () {
this.timeout(5000) this.timeout(5000)
@@ -1,7 +1,7 @@
import pkg from 'chai' import pkg from 'chai'
import { UploadCertToAliyun } from '../../src/aliyun/upload-to-aliyun/index.js' import { UploadCertToAliyun } from '../../src/plugins/upload-to-aliyun/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('PluginUploadToAliyun', function () { describe('PluginUploadToAliyun', function () {
it('#execute', async function () { it('#execute', async function () {
@@ -3,10 +3,6 @@
"env": { "env": {
"mocha": true "mocha": true
}, },
"parserOptions": {
"sourceType": "module",
"ecmaVersion": 2020
},
"overrides": [ "overrides": [
{ {
"files": ["*.test.js", "*.spec.js"], "files": ["*.test.js", "*.spec.js"],
File diff suppressed because it is too large Load Diff
+25
View File
@@ -0,0 +1,25 @@
{
"name": "@certd/plugins",
"version": "0.1.13",
"description": "",
"main": "src/index.js",
"type": "module",
"dependencies": {
"@certd/api": "^0.1.13",
"dayjs": "^1.9.7",
"lodash-es": "^4.17.20",
"ssh2": "^0.8.9"
},
"devDependencies": {
"chai": "^4.2.0",
"eslint": "^7.15.0",
"eslint-config-standard": "^16.0.2",
"eslint-plugin-import": "^2.22.1",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-promise": "^4.2.1",
"mocha": "^8.2.1"
},
"author": "Greper",
"license": "MIT",
"gitHead": "4a421d5b142d453203c68ce6d1036e168ea2455b"
}
+22
View File
@@ -0,0 +1,22 @@
import _ from 'lodash-es'
import { SSHAccessProvider } from './access-providers/ssh'
import { UploadCertToHost } from './host/upload-to-host/index.js'
import { HostShellExecute } from './host/host-shell-execute/index.js'
import { pluginRegistry, accessProviderRegistry } from '@certd/api'
export const DefaultPlugins = {
UploadCertToHost,
HostShellExecute
}
export default {
install () {
_.forEach(DefaultPlugins, item => {
pluginRegistry.install(item)
})
accessProviderRegistry.install(SSHAccessProvider)
}
}
@@ -0,0 +1,42 @@
import _ from 'lodash-es'
import optionsPrivate from '../../../test/options.private.mjs'
const defaultOptions = {
version: '1.0.0',
args: {
directory: 'test',
dry: false
},
accessProviders: {
aliyun: {
providerType: 'aliyun',
accessKeyId: '',
accessKeySecret: ''
},
myLinux: {
providerType: 'SSH',
username: 'xxx',
password: 'xxx',
host: '1111.com',
port: 22,
publicKey: ''
}
},
cert: {
domains: ['*.docmirror.club', 'docmirror.club'],
email: 'xiaojunnuo@qq.com',
dnsProvider: 'aliyun',
certProvider: 'letsencrypt',
csrInfo: {
country: 'CN',
state: 'GuangDong',
locality: 'ShengZhen',
organization: 'CertD Org.',
organizationUnit: 'IT Department',
emailAddress: 'xiaojunnuo@qq.com'
}
}
}
_.merge(defaultOptions, optionsPrivate)
export default defaultOptions
@@ -1,7 +1,7 @@
import pkg from 'chai' import pkg from 'chai'
import { HostShellExecute } from '../../src/host/host-shell-execute/index.js' import { HostShellExecute } from '../../src/plugins/host-shell-execute/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('HostShellExecute', function () { describe('HostShellExecute', function () {
it('#execute', async function () { it('#execute', async function () {
@@ -1,7 +1,7 @@
import pkg from 'chai' import pkg from 'chai'
import { UploadCertToHost } from '../../src/host/upload-to-host/index.js' import { UploadCertToHost } from '../../src/plugins/upload-to-host/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('PluginUploadToHost', function () { describe('PluginUploadToHost', function () {
it('#execute', async function () { it('#execute', async function () {
File diff suppressed because it is too large Load Diff
File diff suppressed because it is too large Load Diff
@@ -3,10 +3,6 @@
"env": { "env": {
"mocha": true "mocha": true
}, },
"parserOptions": {
"sourceType": "module",
"ecmaVersion": 2020
},
"overrides": [ "overrides": [
{ {
"files": ["*.test.js", "*.spec.js"], "files": ["*.test.js", "*.spec.js"],
File diff suppressed because it is too large Load Diff
@@ -2,15 +2,13 @@
"name": "@certd/plugins", "name": "@certd/plugins",
"version": "0.1.13", "version": "0.1.13",
"description": "", "description": "",
"main": "./src/index.js", "main": "src/index.js",
"type": "module", "type": "module",
"dependencies": { "dependencies": {
"@alicloud/pop-core": "^1.7.10",
"@certd/api": "^0.1.13", "@certd/api": "^0.1.13",
"dayjs": "^1.9.7", "dayjs": "^1.9.7",
"kubernetes-client": "^9.0.0", "kubernetes-client": "^9.0.0",
"lodash-es": "^4.17.20", "lodash-es": "^4.17.20",
"ssh2": "^0.8.9",
"tencentcloud-sdk-nodejs": "^4.0.44" "tencentcloud-sdk-nodejs": "^4.0.44"
}, },
"devDependencies": { "devDependencies": {
@@ -0,0 +1,34 @@
import _ from 'lodash-es'
import { TencentAccessProvider } from './access-providers/tencent'
import { DnspodAccessProvider } from './access-providers/dnspod'
import { DnspodDnsProvider } from './dns-providers/dnspod.js'
import { UploadCertToTencent } from './plugins/upload-to-tencent'
import { DeployCertToTencentCDN } from './plugins/deploy-to-cdn'
import { DeployCertToTencentCLB } from './plugins/deploy-to-clb'
import { DeployCertToTencentTKEIngress } from './plugins/deploy-to-tke-ingress'
import { pluginRegistry, accessProviderRegistry, dnsProviderRegistry } from '@certd/api'
export const DefaultPlugins = {
UploadCertToTencent,
DeployCertToTencentTKEIngress,
DeployCertToTencentCDN,
DeployCertToTencentCLB
}
export default {
install () {
_.forEach(DefaultPlugins, item => {
pluginRegistry.install(item)
})
accessProviderRegistry.install(TencentAccessProvider)
accessProviderRegistry.install(DnspodDnsProvider)
dnsProviderRegistry.install(DnspodDnsProvider)
}
}
@@ -1,4 +1,4 @@
import { AbstractTencentPlugin } from '../../tencent/abstract-tencent.js' import { AbstractTencentPlugin } from '../abstract-tencent.js'
import dayjs from 'dayjs' import dayjs from 'dayjs'
import tencentcloud from 'tencentcloud-sdk-nodejs' import tencentcloud from 'tencentcloud-sdk-nodejs'
@@ -1,4 +1,4 @@
import { AbstractTencentPlugin } from '../../tencent/abstract-tencent.js' import { AbstractTencentPlugin } from '../abstract-tencent.js'
import tencentcloud from 'tencentcloud-sdk-nodejs' import tencentcloud from 'tencentcloud-sdk-nodejs'
export class DeployCertToTencentCLB extends AbstractTencentPlugin { export class DeployCertToTencentCLB extends AbstractTencentPlugin {
/** /**
@@ -1,4 +1,4 @@
import { AbstractTencentPlugin } from '../../tencent/abstract-tencent.js' import { AbstractTencentPlugin } from '../abstract-tencent.js'
import tencentcloud from 'tencentcloud-sdk-nodejs' import tencentcloud from 'tencentcloud-sdk-nodejs'
import { K8sClient } from '../../utils/util.k8s.client.js' import { K8sClient } from '../../utils/util.k8s.client.js'
export class DeployCertToTencentTKEIngress extends AbstractTencentPlugin { export class DeployCertToTencentTKEIngress extends AbstractTencentPlugin {
@@ -1,7 +1,6 @@
import pkg from 'chai' import pkg from 'chai'
import DnspodDnsProvider from '../../src/providers/dnspod.js' import DnspodDnsProvider from '../../src/dns-providers/dnspod.js'
import { Certd } from '../../src/index.js' import { createOptions } from '../../../../../test/options.js'
import { createOptions } from '../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('DnspodDnsProvider', function () { describe('DnspodDnsProvider', function () {
it('#getDomainList', async function () { it('#getDomainList', async function () {
@@ -0,0 +1,42 @@
import _ from 'lodash-es'
import optionsPrivate from '../../../../test/options.private.js'
const defaultOptions = {
version: '1.0.0',
args: {
directory: 'test',
dry: false
},
accessProviders: {
aliyun: {
providerType: 'aliyun',
accessKeyId: '',
accessKeySecret: ''
},
myLinux: {
providerType: 'SSH',
username: 'xxx',
password: 'xxx',
host: '1111.com',
port: 22,
publicKey: ''
}
},
cert: {
domains: ['*.docmirror.club', 'docmirror.club'],
email: 'xiaojunnuo@qq.com',
dnsProvider: 'aliyun',
certProvider: 'letsencrypt',
csrInfo: {
country: 'CN',
state: 'GuangDong',
locality: 'ShengZhen',
organization: 'CertD Org.',
organizationUnit: 'IT Department',
emailAddress: 'xiaojunnuo@qq.com'
}
}
}
_.merge(defaultOptions, optionsPrivate)
export default defaultOptions
@@ -1,8 +1,8 @@
import pkg from 'chai' import pkg from 'chai'
import { DeployCertToTencentCDN } from '../../src/tencent/deploy-to-cdn/index.js' import { DeployCertToTencentCDN } from '../../src/plugins/deploy-to-cdn'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { UploadCertToTencent } from '../../src/tencent/upload-to-tencent/index.js' import { UploadCertToTencent } from '../../src/plugins/upload-to-tencent'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('DeployToTencentCDN', function () { describe('DeployToTencentCDN', function () {
it('#execute-from-store', async function () { it('#execute-from-store', async function () {
@@ -1,9 +1,9 @@
import pkg from 'chai' import pkg from 'chai'
import { DeployCertToTencentCLB } from '../../src/tencent/deploy-to-clb/index.js' import { DeployCertToTencentCLB } from '../../src/plugins/deploy-to-clb/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
// eslint-disable-next-line no-unused-vars // eslint-disable-next-line no-unused-vars
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
import { UploadCertToTencent } from '../../src/tencent/upload-to-tencent/index.js' import { UploadCertToTencent } from '../../src/plugins/upload-to-tencent'
const { expect } = pkg const { expect } = pkg
describe('DeployToTencentCLB', function () { describe('DeployToTencentCLB', function () {
it('#execute-getClbList', async function () { it('#execute-getClbList', async function () {
@@ -1,7 +1,7 @@
import pkg from 'chai' import pkg from 'chai'
import { DeployCertToTencentTKEIngress } from '../../src/tencent/deploy-to-tke-ingress/index.js' import { DeployCertToTencentTKEIngress } from '../../src/plugins/deploy-to-tke-ingress/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
import { K8sClient } from '../../src/utils/util.k8s.client.js' import { K8sClient } from '../../src/utils/util.k8s.client.js'
const { expect } = pkg const { expect } = pkg
@@ -1,7 +1,7 @@
import pkg from 'chai' import pkg from 'chai'
import { UploadCertToTencent } from '../../src/tencent/upload-to-tencent/index.js' import { UploadCertToTencent } from '../../src/plugins/upload-to-tencent/index.js'
import { Certd } from '@certd/certd' import { Certd } from '@certd/certd'
import { createOptions } from '../../../../test/options.js' import { createOptions } from '../../../../../test/options.js'
const { expect } = pkg const { expect } = pkg
describe('PluginUploadToTencent', function () { describe('PluginUploadToTencent', function () {
it('#execute', async function () { it('#execute', async function () {
File diff suppressed because it is too large Load Diff
File diff suppressed because it is too large Load Diff

Some files were not shown because too many files have changed in this diff Show More