diff --git a/packages/libs/lib-jdcloud/package.json b/packages/libs/lib-jdcloud/package.json index 05e68098..20cd2bf1 100644 --- a/packages/libs/lib-jdcloud/package.json +++ b/packages/libs/lib-jdcloud/package.json @@ -12,11 +12,17 @@ "preview": "vite preview" }, "dependencies": { + "babel-register": "^6.26.0", + "buffer": "^5.0.8", + "create-hash": "^1.1.3", + "create-hmac": "^1.1.6", + "debug": "^3.1.0", + "node-fetch": "^2.1.2", + "url": "^0.11.0", + "uuid": "^3.1.0", "@certd/pipeline": "1.21.0", "axios": "^1.7.2", - "node-fetch": "^3.3.2", - "rollup": "^3.7.4", - "uuid": "^3.4.0" + "rollup": "^3.7.4" }, "gitHead": "c49ccbde93dbad7062ac39d4f18eca7d561f573f" } diff --git a/packages/libs/lib-jdcloud/rollup.config.js b/packages/libs/lib-jdcloud/rollup.config.js index eeed5b1c..d822c2e6 100644 --- a/packages/libs/lib-jdcloud/rollup.config.js +++ b/packages/libs/lib-jdcloud/rollup.config.js @@ -12,7 +12,11 @@ module.exports = { }, plugins: [ // 解析第三方依赖 - resolve(), + resolve({ + jsnext: true, + main: true, + browser: true, + }), // 识别 commonjs 模式第三方依赖 commonjs({ // dynamicRequireRoot: "../../../../", @@ -32,5 +36,5 @@ module.exports = { json(), terser(), ], - external: ["vue", "lodash-es", "dayjs", "log4js", "@midwayjs/core", "@certd/pipeline", "axios", "node-fetch"], + external: ["vue", "lodash-es", "dayjs", "log4js", "@midwayjs/core", "@certd/pipeline", "axios", "querystring"], }; diff --git a/packages/libs/lib-jdcloud/src/lib/core.js b/packages/libs/lib-jdcloud/src/lib/core.js index 18a7c44c..40876554 100644 --- a/packages/libs/lib-jdcloud/src/lib/core.js +++ b/packages/libs/lib-jdcloud/src/lib/core.js @@ -1,13 +1,12 @@ -require('node-fetch') - var JDCloud = { - util: require('./util'), + util: require("./util"), // todo swaggerVar - VERSION: '' -} + VERSION: "", + fetch: require("node-fetch"), +}; -module.exports = JDCloud +module.exports = JDCloud; -require('./service') -require('./config') -require('./request') +require("./service"); +require("./config"); +require("./request"); diff --git a/packages/libs/lib-jdcloud/src/lib/request.js b/packages/libs/lib-jdcloud/src/lib/request.js index c83f139b..9c5a1749 100644 --- a/packages/libs/lib-jdcloud/src/lib/request.js +++ b/packages/libs/lib-jdcloud/src/lib/request.js @@ -1,126 +1,106 @@ -var JDCloud = require('./core') +var JDCloud = require("./core"); -let util = JDCloud.util +let util = JDCloud.util; JDCloud.JCRequest = class JCRequest { - constructor ( - service, - path, - httpMethod, - pathParams, - queryParams, - headerParams, - formParams, - postBody, - contentTypes, - accepts, - returnType - ) { - this.service = service + constructor(service, path, httpMethod, pathParams, queryParams, headerParams, formParams, postBody, contentTypes, accepts, returnType) { + this.service = service; - var endpoint = service.config.endpoint - pathParams.regionId = pathParams.regionId || service.config.regionId - this.regionId = pathParams.regionId + var endpoint = service.config.endpoint; + pathParams.regionId = pathParams.regionId || service.config.regionId; + this.regionId = pathParams.regionId; - this.path = this.buildPath(path, pathParams) - this.path = util.uriEscapePath(this.path) + this.path = this.buildPath(path, pathParams); + this.path = util.uriEscapePath(this.path); - var queryString = this.buildQuery(queryParams) + var queryString = this.buildQuery(queryParams); - var url = this.path + var url = this.path; if (queryString) { - url = this.path + '?' + queryString + url = this.path + "?" + queryString; } - var contentType = this.jsonPreferredMime(contentTypes) || 'application/json' - headerParams['content-type'] = contentType - var requestHeaders = this.buildHeaders(headerParams) + var contentType = this.jsonPreferredMime(contentTypes) || "application/json"; + headerParams["content-type"] = contentType; + var requestHeaders = this.buildHeaders(headerParams); var requestInit = { - method: httpMethod || 'GET', - headers: requestHeaders - } + method: httpMethod || "GET", + headers: requestHeaders, + }; - if (contentType === 'application/x-www-form-urlencoded') { - } else if (contentType === 'multipart/form-data') { + if (contentType === "application/x-www-form-urlencoded") { + } else if (contentType === "multipart/form-data") { } else if (postBody) { - requestInit.body = JSON.stringify(postBody) + requestInit.body = JSON.stringify(postBody); } - var fetchUrl = endpoint.protocol + '://' + endpoint.host + url - JDCloud.config.logger( - `make request where url is :${fetchUrl} \nwith fetch config:${JSON.stringify( - requestInit - )}` - ) - this.request = new JDCloud.fetch.Request(fetchUrl, requestInit) + var fetchUrl = endpoint.protocol + "://" + endpoint.host + url; + JDCloud.config.logger(`make request where url is :${fetchUrl} \nwith fetch config:${JSON.stringify(requestInit)}`); + this.request = new JDCloud.fetch.Request(fetchUrl, requestInit); + this.request.bodyCache = requestInit.body; } - buildPath (path, pathParams) { - var uri = (this.service.config.basePath || '') + path + buildPath(path, pathParams) { + var uri = (this.service.config.basePath || "") + path; uri = uri.replace(/\{([\w-]+)\}/g, (fullMatch, key) => { - var value + var value; if (pathParams.hasOwnProperty(key)) { - value = pathParams[key] + value = pathParams[key]; } else { - value = fullMatch + value = fullMatch; } - return value - }) - return uri + return value; + }); + return uri; } - buildQuery (queryParams) { - var queryParamsWithoutEmptyItem = {} - var keys = Object.keys(queryParams) + buildQuery(queryParams) { + var queryParamsWithoutEmptyItem = {}; + var keys = Object.keys(queryParams); for (let key of keys) { if (queryParams[key] !== undefined) { - queryParamsWithoutEmptyItem[key] = queryParams[key] + queryParamsWithoutEmptyItem[key] = queryParams[key]; } } - return JDCloud.util.querystring.stringify(queryParamsWithoutEmptyItem) + return JDCloud.util.querystring.stringify(queryParamsWithoutEmptyItem); } - search () { - var query = this.request.url.split('?', 2)[1] + search() { + var query = this.request.url.split("?", 2)[1]; if (query) { - query = JDCloud.util.querystring.parse(query) - return JDCloud.util.queryParamsToString(query) + query = JDCloud.util.querystring.parse(query); + return JDCloud.util.queryParamsToString(query); } - return '' + return ""; } - digitizationArray (key, obj) { - var result = key + digitizationArray(key, obj) { + var result = key; if (Array.isArray(obj)) { JDCloud.util.arrayEach(obj, (arrayValue, index) => { - result += this.digitizationArray(`.${index + 1}`, arrayValue) - }) - } else if (typeof obj === 'object' && obj != null) { + result += this.digitizationArray(`.${index + 1}`, arrayValue); + }); + } else if (typeof obj === "object" && obj != null) { JDCloud.util.each(obj, (key, ObjValue) => { - result += `.name=${key}&${result}.values` + this.digitizationArray() - result += - key + - '.name=' + - ObjValue + - '&' + - this.digitizationArray(key + '.values', ObjValue) - }) + result += `.name=${key}&${result}.values` + this.digitizationArray(); + result += key + ".name=" + ObjValue + "&" + this.digitizationArray(key + ".values", ObjValue); + }); } else { - result += key + '=' + encodeURI(obj) + result += key + "=" + encodeURI(obj); } - return result + return result; } - buildHeaders (headerParams) { + buildHeaders(headerParams) { var headers = new JDCloud.fetch.Headers({ - accept: 'application/json' - }) + accept: "application/json", + }); util.each.call(this, headerParams, function (key) { if (headerParams[key] !== undefined && headerParams[key] != null) { - headers.append(key, headerParams[key]) + headers.append(key, headerParams[key]); } - }) - return headers + }); + return headers; } /** @@ -134,10 +114,8 @@ JDCloud.JCRequest = class JCRequest { * @param {String} contentType The MIME content type to check. * @returns {Boolean} true if contentType represents JSON, otherwise false. */ - isJsonMime (contentType) { - return Boolean( - contentType != null && contentType.match(/^application\/json(;.*)?$/i) - ) + isJsonMime(contentType) { + return Boolean(contentType != null && contentType.match(/^application\/json(;.*)?$/i)); } /** @@ -145,15 +123,15 @@ JDCloud.JCRequest = class JCRequest { * @param {Array.} contentTypes * @returns {String} The chosen content type, preferring JSON. */ - jsonPreferredMime (contentTypes) { + jsonPreferredMime(contentTypes) { for (var i = 0; i < contentTypes.length; i++) { if (this.isJsonMime(contentTypes[i])) { - return contentTypes[i] + return contentTypes[i]; } } - return contentTypes[0] + return contentTypes[0]; } -} +}; -module.exports = JDCloud.JCRequest +module.exports = JDCloud.JCRequest; diff --git a/packages/libs/lib-jdcloud/src/lib/signers/v2.js b/packages/libs/lib-jdcloud/src/lib/signers/v2.js index 52861eb0..a13495b9 100644 --- a/packages/libs/lib-jdcloud/src/lib/signers/v2.js +++ b/packages/libs/lib-jdcloud/src/lib/signers/v2.js @@ -138,7 +138,11 @@ module.exports = class SignerV2 extends RequestSigner { } hexEncodedBodyHash() { - return this.hexEncodedHash(this.request.request.body || ""); + let body = this.request.request?.body; + if (body && body instanceof ReadableStream) { + body = this.request.request?.bodyCache; + } + return this.hexEncodedHash(body || ""); /* var request = this.request; if (this.isPresigned() && this.serviceName === 's3' && !request.body) { return 'UNSIGNED-PAYLOAD'; diff --git a/packages/libs/lib-jdcloud/src/lib/util.js b/packages/libs/lib-jdcloud/src/lib/util.js index adb3e7ba..cf0d4de7 100644 --- a/packages/libs/lib-jdcloud/src/lib/util.js +++ b/packages/libs/lib-jdcloud/src/lib/util.js @@ -1,477 +1,219 @@ var util = { - isBrowser: function isBrowser () { - return process && process.browser + isBrowser: function isBrowser() { + return process && process.browser; }, - isNode: function isNode () { - return !util.isBrowser() + isNode: function isNode() { + return !util.isBrowser(); }, - uriEscape: function uriEscape (string) { - var output = encodeURIComponent(string) - output = output.replace(/[^A-Za-z0-9_.~\-%]+/g, escape) + uriEscape: function uriEscape(string) { + var output = encodeURIComponent(string); + output = output.replace(/[^A-Za-z0-9_.~\-%]+/g, escape); // AWS percent-encodes some extra non-standard characters in a URI output = output.replace(/[*]/g, function (ch) { - return ( - '%' + - ch - .charCodeAt(0) - .toString(16) - .toUpperCase() - ) - }) + return "%" + ch.charCodeAt(0).toString(16).toUpperCase(); + }); - return output + return output; }, - uriEscapePath: function uriEscapePath (string) { - var parts = [] - util.arrayEach(string.split('/'), function (part) { - parts.push(util.uriEscape(part)) - }) - return parts.join('/') + uriEscapePath: function uriEscapePath(string) { + var parts = []; + util.arrayEach(string.split("/"), function (part) { + parts.push(util.uriEscape(part)); + }); + return parts.join("/"); }, abort: {}, - each: function each (object, iterFunction) { + each: function each(object, iterFunction) { for (var key in object) { if (Object.prototype.hasOwnProperty.call(object, key)) { - var ret = iterFunction.call(this, key, object[key]) - if (ret === util.abort) break + var ret = iterFunction.call(this, key, object[key]); + if (ret === util.abort) break; } } }, - arrayEach: function arrayEach (array, iterFunction) { + arrayEach: function arrayEach(array, iterFunction) { for (var idx in array) { if (Object.prototype.hasOwnProperty.call(array, idx)) { - var ret = iterFunction.call(this, array[idx], parseInt(idx, 10)) - if (ret === util.abort) break + var ret = iterFunction.call(this, array[idx], parseInt(idx, 10)); + if (ret === util.abort) break; } } }, - arraySliceFn: function arraySliceFn (obj) { - var fn = obj.slice || obj.webkitSlice || obj.mozSlice - return typeof fn === 'function' ? fn : null + arraySliceFn: function arraySliceFn(obj) { + var fn = obj.slice || obj.webkitSlice || obj.mozSlice; + return typeof fn === "function" ? fn : null; }, - queryParamsToString: function queryParamsToString (params) { - var items = [] - var escape = util.uriEscape - var sortedKeys = Object.keys(params).sort() + queryParamsToString: function queryParamsToString(params) { + var items = []; + var escape = util.uriEscape; + var sortedKeys = Object.keys(params).sort(); util.arrayEach(sortedKeys, function (name) { - var value = params[name] - var ename = escape(name) - var result = ename + '=' + var value = params[name]; + var ename = escape(name); + var result = ename + "="; if (Array.isArray(value)) { - var vals = [] + var vals = []; util.arrayEach(value, function (item) { - vals.push(escape(item)) - }) - result = ename + '=' + vals.sort().join('&' + ename + '=') + vals.push(escape(item)); + }); + result = ename + "=" + vals.sort().join("&" + ename + "="); } else if (value !== undefined && value !== null) { - result = ename + '=' + escape(value) + result = ename + "=" + escape(value); } - items.push(result) - }) + items.push(result); + }); - return items.join('&') + return items.join("&"); }, date: { - getDate () { - return new Date() + getDate() { + return new Date(); }, - iso8601: function iso8601 (date) { + iso8601: function iso8601(date) { if (date === undefined) { - date = util.date.getDate() + date = util.date.getDate(); } - return date.toISOString().replace(/\.\d{3}Z$/, 'Z') - } + return date.toISOString().replace(/\.\d{3}Z$/, "Z"); + }, }, crypto: { /* eslint-disable no-use-before-define */ crc32Table: [ - 0x00000000, - 0x77073096, - 0xee0e612c, - 0x990951ba, - 0x076dc419, - 0x706af48f, - 0xe963a535, - 0x9e6495a3, - 0x0edb8832, - 0x79dcb8a4, - 0xe0d5e91e, - 0x97d2d988, - 0x09b64c2b, - 0x7eb17cbd, - 0xe7b82d07, - 0x90bf1d91, - 0x1db71064, - 0x6ab020f2, - 0xf3b97148, - 0x84be41de, - 0x1adad47d, - 0x6ddde4eb, - 0xf4d4b551, - 0x83d385c7, - 0x136c9856, - 0x646ba8c0, - 0xfd62f97a, - 0x8a65c9ec, - 0x14015c4f, - 0x63066cd9, - 0xfa0f3d63, - 0x8d080df5, - 0x3b6e20c8, - 0x4c69105e, - 0xd56041e4, - 0xa2677172, - 0x3c03e4d1, - 0x4b04d447, - 0xd20d85fd, - 0xa50ab56b, - 0x35b5a8fa, - 0x42b2986c, - 0xdbbbc9d6, - 0xacbcf940, - 0x32d86ce3, - 0x45df5c75, - 0xdcd60dcf, - 0xabd13d59, - 0x26d930ac, - 0x51de003a, - 0xc8d75180, - 0xbfd06116, - 0x21b4f4b5, - 0x56b3c423, - 0xcfba9599, - 0xb8bda50f, - 0x2802b89e, - 0x5f058808, - 0xc60cd9b2, - 0xb10be924, - 0x2f6f7c87, - 0x58684c11, - 0xc1611dab, - 0xb6662d3d, - 0x76dc4190, - 0x01db7106, - 0x98d220bc, - 0xefd5102a, - 0x71b18589, - 0x06b6b51f, - 0x9fbfe4a5, - 0xe8b8d433, - 0x7807c9a2, - 0x0f00f934, - 0x9609a88e, - 0xe10e9818, - 0x7f6a0dbb, - 0x086d3d2d, - 0x91646c97, - 0xe6635c01, - 0x6b6b51f4, - 0x1c6c6162, - 0x856530d8, - 0xf262004e, - 0x6c0695ed, - 0x1b01a57b, - 0x8208f4c1, - 0xf50fc457, - 0x65b0d9c6, - 0x12b7e950, - 0x8bbeb8ea, - 0xfcb9887c, - 0x62dd1ddf, - 0x15da2d49, - 0x8cd37cf3, - 0xfbd44c65, - 0x4db26158, - 0x3ab551ce, - 0xa3bc0074, - 0xd4bb30e2, - 0x4adfa541, - 0x3dd895d7, - 0xa4d1c46d, - 0xd3d6f4fb, - 0x4369e96a, - 0x346ed9fc, - 0xad678846, - 0xda60b8d0, - 0x44042d73, - 0x33031de5, - 0xaa0a4c5f, - 0xdd0d7cc9, - 0x5005713c, - 0x270241aa, - 0xbe0b1010, - 0xc90c2086, - 0x5768b525, - 0x206f85b3, - 0xb966d409, - 0xce61e49f, - 0x5edef90e, - 0x29d9c998, - 0xb0d09822, - 0xc7d7a8b4, - 0x59b33d17, - 0x2eb40d81, - 0xb7bd5c3b, - 0xc0ba6cad, - 0xedb88320, - 0x9abfb3b6, - 0x03b6e20c, - 0x74b1d29a, - 0xead54739, - 0x9dd277af, - 0x04db2615, - 0x73dc1683, - 0xe3630b12, - 0x94643b84, - 0x0d6d6a3e, - 0x7a6a5aa8, - 0xe40ecf0b, - 0x9309ff9d, - 0x0a00ae27, - 0x7d079eb1, - 0xf00f9344, - 0x8708a3d2, - 0x1e01f268, - 0x6906c2fe, - 0xf762575d, - 0x806567cb, - 0x196c3671, - 0x6e6b06e7, - 0xfed41b76, - 0x89d32be0, - 0x10da7a5a, - 0x67dd4acc, - 0xf9b9df6f, - 0x8ebeeff9, - 0x17b7be43, - 0x60b08ed5, - 0xd6d6a3e8, - 0xa1d1937e, - 0x38d8c2c4, - 0x4fdff252, - 0xd1bb67f1, - 0xa6bc5767, - 0x3fb506dd, - 0x48b2364b, - 0xd80d2bda, - 0xaf0a1b4c, - 0x36034af6, - 0x41047a60, - 0xdf60efc3, - 0xa867df55, - 0x316e8eef, - 0x4669be79, - 0xcb61b38c, - 0xbc66831a, - 0x256fd2a0, - 0x5268e236, - 0xcc0c7795, - 0xbb0b4703, - 0x220216b9, - 0x5505262f, - 0xc5ba3bbe, - 0xb2bd0b28, - 0x2bb45a92, - 0x5cb36a04, - 0xc2d7ffa7, - 0xb5d0cf31, - 0x2cd99e8b, - 0x5bdeae1d, - 0x9b64c2b0, - 0xec63f226, - 0x756aa39c, - 0x026d930a, - 0x9c0906a9, - 0xeb0e363f, - 0x72076785, - 0x05005713, - 0x95bf4a82, - 0xe2b87a14, - 0x7bb12bae, - 0x0cb61b38, - 0x92d28e9b, - 0xe5d5be0d, - 0x7cdcefb7, - 0x0bdbdf21, - 0x86d3d2d4, - 0xf1d4e242, - 0x68ddb3f8, - 0x1fda836e, - 0x81be16cd, - 0xf6b9265b, - 0x6fb077e1, - 0x18b74777, - 0x88085ae6, - 0xff0f6a70, - 0x66063bca, - 0x11010b5c, - 0x8f659eff, - 0xf862ae69, - 0x616bffd3, - 0x166ccf45, - 0xa00ae278, - 0xd70dd2ee, - 0x4e048354, - 0x3903b3c2, - 0xa7672661, - 0xd06016f7, - 0x4969474d, - 0x3e6e77db, - 0xaed16a4a, - 0xd9d65adc, - 0x40df0b66, - 0x37d83bf0, - 0xa9bcae53, - 0xdebb9ec5, - 0x47b2cf7f, - 0x30b5ffe9, - 0xbdbdf21c, - 0xcabac28a, - 0x53b39330, - 0x24b4a3a6, - 0xbad03605, - 0xcdd70693, - 0x54de5729, - 0x23d967bf, - 0xb3667a2e, - 0xc4614ab8, - 0x5d681b02, - 0x2a6f2b94, - 0xb40bbe37, - 0xc30c8ea1, - 0x5a05df1b, - 0x2d02ef8d + 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, + 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, + 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, + 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, + 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, + 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, + 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, + 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, + 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, + 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, + 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, + 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, + 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, + 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, + 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, + 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, + 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, + 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, + 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, + 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, + 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, + 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d, ], /* eslint-disable no-use-before-define */ - crc32: function crc32 (data) { - var tbl = util.crypto.crc32Table - var crc = 0 ^ -1 + crc32: function crc32(data) { + var tbl = util.crypto.crc32Table; + var crc = 0 ^ -1; - if (typeof data === 'string') { - data = new util.Buffer(data) + if (typeof data === "string") { + data = new util.Buffer(data); } for (var i = 0; i < data.length; i++) { - var code = data.readUInt8(i) - crc = (crc >>> 8) ^ tbl[(crc ^ code) & 0xff] + var code = data.readUInt8(i); + crc = (crc >>> 8) ^ tbl[(crc ^ code) & 0xff]; } - return (crc ^ -1) >>> 0 + return (crc ^ -1) >>> 0; }, - hmac: function hmac (key, string, digest, fn) { - if (!digest) digest = 'binary' - if (digest === 'buffer') { - digest = undefined + hmac: function hmac(key, string, digest, fn) { + if (!digest) digest = "binary"; + if (digest === "buffer") { + digest = undefined; } - if (!fn) fn = 'sha256' - if (typeof string === 'string') string = new util.Buffer(string) - return util.crypto.lib - .createHmac(fn, key) - .update(string) - .digest(digest) + if (!fn) fn = "sha256"; + if (typeof string === "string") string = new util.Buffer(string); + return util.crypto.lib.createHmac(fn, key).update(string).digest(digest); }, - md5: function md5 (data, digest, callback) { - return util.crypto.hash('md5', data, digest, callback) + md5: function md5(data, digest, callback) { + return util.crypto.hash("md5", data, digest, callback); }, - sha256: function sha256 (data, digest, callback) { - return util.crypto.hash('sha256', data, digest, callback) + sha256: function sha256(data, digest, callback) { + return util.crypto.hash("sha256", data, digest, callback); }, hash: function (algorithm, data, digest, callback) { - var hash = util.crypto.createHash(algorithm) + var hash = util.crypto.createHash(algorithm); if (!digest) { - digest = 'binary' + digest = "binary"; } - if (digest === 'buffer') { - digest = undefined + if (digest === "buffer") { + digest = undefined; } - if (typeof data === 'string') data = new util.Buffer(data) - var sliceFn = util.arraySliceFn(data) - var isBuffer = util.Buffer.isBuffer(data) + if (typeof data === "string") data = new util.Buffer(data); + var sliceFn = util.arraySliceFn(data); + var isBuffer = util.Buffer.isBuffer(data); // Identifying objects with an ArrayBuffer as buffers - if ( - util.isBrowser() && - typeof ArrayBuffer !== 'undefined' && - data && - data.buffer instanceof ArrayBuffer - ) { - isBuffer = true + if (util.isBrowser() && typeof ArrayBuffer !== "undefined" && data && data.buffer instanceof ArrayBuffer) { + isBuffer = true; } - if ( - callback && - typeof data === 'object' && - typeof data.on === 'function' && - !isBuffer - ) { - data.on('data', function (chunk) { - hash.update(chunk) - }) - data.on('error', function (err) { - callback(err) - }) - data.on('end', function () { - callback(null, hash.digest(digest)) - }) - } else if ( - callback && - sliceFn && - !isBuffer && - typeof FileReader !== 'undefined' - ) { + if (callback && typeof data === "object" && typeof data.on === "function" && !isBuffer) { + data.on("data", function (chunk) { + hash.update(chunk); + }); + data.on("error", function (err) { + callback(err); + }); + data.on("end", function () { + callback(null, hash.digest(digest)); + }); + } else if (callback && sliceFn && !isBuffer && typeof FileReader !== "undefined") { // this might be a File/Blob - var index = 0 - var size = 1024 * 512 - var reader = new FileReader() + var index = 0; + var size = 1024 * 512; + var reader = new FileReader(); reader.onerror = function () { - callback(new Error('Failed to read data.')) - } + callback(new Error("Failed to read data.")); + }; reader.onload = function () { - var buf = new util.Buffer(new Uint8Array(reader.result)) - hash.update(buf) - index += buf.length - reader._continueReading() - } + var buf = new util.Buffer(new Uint8Array(reader.result)); + hash.update(buf); + index += buf.length; + reader._continueReading(); + }; reader._continueReading = function () { if (index >= data.size) { - callback(null, hash.digest(digest)) - return + callback(null, hash.digest(digest)); + return; } - var back = index + size - if (back > data.size) back = data.size - reader.readAsArrayBuffer(sliceFn.call(data, index, back)) - } + var back = index + size; + if (back > data.size) back = data.size; + reader.readAsArrayBuffer(sliceFn.call(data, index, back)); + }; - reader._continueReading() + reader._continueReading(); } else { - if (util.isBrowser() && typeof data === 'object' && !isBuffer) { - data = new util.Buffer(new Uint8Array(data)) + if (util.isBrowser() && typeof data === "object" && !isBuffer) { + data = new util.Buffer(new Uint8Array(data)); } - var out = hash.update(data).digest(digest) - if (callback) callback(null, out) - return out + var out = hash.update(data).digest(digest); + if (callback) callback(null, out); + return out; } }, - toHex: function toHex (data) { - var out = [] + toHex: function toHex(data) { + var out = []; for (var i = 0; i < data.length; i++) { - out.push(('0' + data.charCodeAt(i).toString(16)).substr(-2, 2)) + out.push(("0" + data.charCodeAt(i).toString(16)).substr(-2, 2)); } - return out.join('') + return out.join(""); }, - createHash: function createHash (algorithm) { - return util.crypto.lib.createHash(algorithm) - } - } -} + createHash: function createHash(algorithm) { + return util.crypto.lib.createHash(algorithm); + }, + }, +}; -module.exports = util +module.exports = util; diff --git a/packages/plugins/plugin-cert/src/plugin/cert-plugin/index.ts b/packages/plugins/plugin-cert/src/plugin/cert-plugin/index.ts index 34e64a75..162ce957 100644 --- a/packages/plugins/plugin-cert/src/plugin/cert-plugin/index.ts +++ b/packages/plugins/plugin-cert/src/plugin/cert-plugin/index.ts @@ -196,8 +196,8 @@ export class CertApplyPlugin extends CertApplyBasePlugin { const certInfo = this.formatCerts(cert); return new CertReader(certInfo); } catch (e: any) { - const message: string = e.message; - if (message.indexOf("redundant with a wildcard domain in the same request") >= 0) { + const message: string = e?.message; + if (message != null && message.indexOf("redundant with a wildcard domain in the same request") >= 0) { this.logger.error(e); throw new Error(`通配符域名已经包含了普通域名,请删除其中一个(${message})`); } diff --git a/packages/ui/certd-client/src/views/certd/access/common.tsx b/packages/ui/certd-client/src/views/certd/access/common.tsx index dd986f76..29a8f27a 100644 --- a/packages/ui/certd-client/src/views/certd/access/common.tsx +++ b/packages/ui/certd-client/src/views/certd/access/common.tsx @@ -3,7 +3,7 @@ import { ColumnCompositionProps, dict, compute } from "@fast-crud/fast-crud"; import * as api from "./api"; // @ts-ignore import _ from "lodash-es"; -import { toRef } from "vue"; +import { computed, ref, toRef } from "vue"; import { useReference } from "/@/use/use-refrence"; export function getCommonColumnDefine(crudExpose: any, typeRef: any) { @@ -48,6 +48,8 @@ export function getCommonColumnDefine(crudExpose: any, typeRef: any) { }); } + const currentDefine = ref(); + return { type: { title: "类型", @@ -76,13 +78,21 @@ export function getCommonColumnDefine(crudExpose: any, typeRef: any) { return; } const define = await api.GetProviderDefine(value); + currentDefine.value = define; console.log("define", define); if (!immediate) { form.access = {}; } buildDefineFields(define, form); } - } + }, + helper: computed(() => { + const define = currentDefine.value; + if (define == null) { + return ""; + } + return define.desc; + }) }, addForm: { value: typeRef diff --git a/packages/ui/certd-server/.env.development.yaml b/packages/ui/certd-server/.env.development.yaml index 742b011c..80433258 100644 --- a/packages/ui/certd-server/.env.development.yaml +++ b/packages/ui/certd-server/.env.development.yaml @@ -1,15 +1,19 @@ # key: ./data/ssl/cert.key # cert: ./data/ssl/cert.crt -plus: - server: - baseUrl: 'http://127.0.0.1:11007' #plus: # server: -# baseUrl: 'https://api.ai.handsfree.work' +# baseUrl: 'http://127.0.0.1:11007' +plus: + server: + baseUrl: 'https://api.ai.handsfree.work' #typeorm: # dataSource: # default: # database: './data/db1.sqlite' +#account: +# server: +# baseUrl: 'http://127.0.0.1:1017/subject' + account: server: - baseUrl: 'http://127.0.0.1:1017/subject' + baseUrl: 'https://ai.handsfree.work/subject' diff --git a/packages/ui/certd-server/package.json b/packages/ui/certd-server/package.json index 9fc01f5e..99655710 100644 --- a/packages/ui/certd-server/package.json +++ b/packages/ui/certd-server/package.json @@ -63,7 +63,6 @@ "md5": "^2.3.0", "mwtsc": "^1.4.0", "nanoid": "^4.0.0", - "node-fetch": "^3.3.2", "nodemailer": "^6.9.3", "pg": "^8.12.0", "qiniu": "^7.12.0", diff --git a/packages/ui/certd-server/src/plugins/plugin-dynadot/access.ts b/packages/ui/certd-server/src/plugins/plugin-dynadot/access.ts index 68d11e23..bdee2d4b 100644 --- a/packages/ui/certd-server/src/plugins/plugin-dynadot/access.ts +++ b/packages/ui/certd-server/src/plugins/plugin-dynadot/access.ts @@ -7,7 +7,7 @@ import { AccessInput, IsAccess } from '@certd/pipeline'; @IsAccess({ name: 'dynadot', title: 'dynadot授权', - desc: '目前设置dns解析会覆盖已有的解析配置,慎用', + desc: '************\n注意:申请证书时会覆盖已有的域名解析配置,慎用\n************\n待优化,主要是dynadot的接口一言难尽', }) export class DynadotAccess { /** diff --git a/packages/ui/certd-server/src/plugins/plugin-dynadot/dns-provider.ts b/packages/ui/certd-server/src/plugins/plugin-dynadot/dns-provider.ts index b314ba58..b778258d 100644 --- a/packages/ui/certd-server/src/plugins/plugin-dynadot/dns-provider.ts +++ b/packages/ui/certd-server/src/plugins/plugin-dynadot/dns-provider.ts @@ -59,13 +59,21 @@ export class DynadotDnsProvider extends AbstractDnsProvider { const { fullRecord, value, type, domain } = options; this.logger.info('添加域名解析:', fullRecord, value, type, domain); + //先获取域名原始解析记录 + //https://api.dynadot.com/api3.xml?key=[API Key]&command=domain_info&domain=domain1.com + const res1 = await this.doRequest('domain_info', { + domain: domain, + }); + // this.logger.info(`域名信息:${JSON.stringify(res1)}`); + // "DomainInfoResponse.NameServerSettings":{"Type":"Dynadot DNS","SubDomains":[{"Subhost":"_acme-challenge","RecordType":"TXT","Value":"43XrhFA6pJpE7a-20y7BmC6CsN20TMt5l-Zl-CL_-4I"}],"TTL":"300"} + this.logger.info('原始域名解析记录:', JSON.stringify(res1.DomainInfoResponse?.DomainInfo?.NameServerSettings)); const prefix = fullRecord.replace(`.${domain}`, ''); // 给domain下创建txt类型的dns解析记录,fullRecord const res = await this.doRequest('set_dns2', { domain: domain, subdomain0: prefix, sub_record_type0: 'TXT', - sub_record0 : value, + sub_record0: value, }); this.logger.info(`添加域名解析成功:fullRecord=${fullRecord},value=${value}`); this.logger.info(`请求结果:${JSON.stringify(res)}`); diff --git a/packages/ui/certd-server/src/plugins/plugin-jdcloud/dns-provider.ts b/packages/ui/certd-server/src/plugins/plugin-jdcloud/dns-provider.ts index 51b15beb..e7865bae 100644 --- a/packages/ui/certd-server/src/plugins/plugin-jdcloud/dns-provider.ts +++ b/packages/ui/certd-server/src/plugins/plugin-jdcloud/dns-provider.ts @@ -4,13 +4,17 @@ import { JDCloudAccess } from './access.js'; function promisfy(func: any) { return (params: any, regionId: string) => { return new Promise((resolve, reject) => { - func(params, regionId, (err, result) => { - if (err) { - reject(err); - return; - } - resolve(result); - }); + try { + func(params, regionId, (err, result) => { + if (err) { + reject(err.error || err); + return; + } + resolve(result); + }); + } catch (e) { + reject(e); + } }); }; } @@ -57,17 +61,23 @@ export class JDCloudDnsProvider extends AbstractDnsProvider { const { fullRecord, value, type, domain } = options; this.logger.info('添加域名解析:', fullRecord, value, type, domain); - const describeDomains = promisfy(this.service.describeDomains); + const describeDomains = promisfy((a, b, c) => { + this.service.describeDomains(a, b, c); + }); const res: any = await describeDomains({ domainName: domain, pageNumber: 1, pageSize: 10 }, this.regionId); - - if (res.dataList.length === 0) { + this.logger.info('请求成功:', JSON.stringify(res.result)); + const dataList = res.result.dataList; + if (dataList.length === 0) { throw new Error('账号下找不到域名:' + domain); } - const domainId = res.dataList[0].id; + const domainId = dataList[0].id; + this.logger.info('domainId:', domainId); //开始创建解析记录 - const createResourceRecord = promisfy(this.service.createResourceRecord); + const createResourceRecord = promisfy((a, b, c) => { + this.service.createResourceRecord(a, b, c); + }); const res2: any = await createResourceRecord( { domainId, @@ -79,8 +89,9 @@ export class JDCloudDnsProvider extends AbstractDnsProvider { }, this.regionId ); - - const recordId = res2.dataList[0].id; + this.logger.info('请求成功:', JSON.stringify(res.result)); + const recordList = res2.result.dataList; + const recordId = recordList[0].id; this.logger.info(`添加域名解析成功:fullRecord=${fullRecord},value=${value}`); this.logger.info(`请求结果:recordId:${recordId}`); @@ -96,7 +107,7 @@ export class JDCloudDnsProvider extends AbstractDnsProvider { async removeRecord(opts: RemoveRecordOptions): Promise { const { record } = opts; const deleteResourceRecord = promisfy(this.service.deleteResourceRecord); - const res = await deleteResourceRecord( + const res: any = await deleteResourceRecord( { domainId: record.domainId, resourceRecordId: record.id,