@cloudbase/utilities
Advanced tools
Comparing version 1.4.2-alpha.0 to 1.4.3-alpha.0
@@ -11,2 +11,4 @@ interface ICatchErrorsDecoratorOptions { | ||
export declare function catchErrorsDecorator(options: ICatchErrorsDecoratorOptions): (target: any, methodName: string, descriptor: TypedPropertyDescriptor<Function>) => void; | ||
export declare function stopOAuthLoginWithAuth(): (_target: any, _methodName: string, descriptor: TypedPropertyDescriptor<Function>) => void; | ||
export declare function stopAuthLoginWithOAuth(): (_target: any, _methodName: string, descriptor: TypedPropertyDescriptor<Function>) => void; | ||
export {}; |
@@ -39,3 +39,3 @@ "use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.catchErrorsDecorator = void 0; | ||
exports.stopAuthLoginWithOAuth = exports.stopOAuthLoginWithAuth = exports.catchErrorsDecorator = void 0; | ||
var util_1 = require("../libs/util"); | ||
@@ -177,2 +177,70 @@ var constants_1 = require("../constants"); | ||
exports.catchErrorsDecorator = catchErrorsDecorator; | ||
function stopOAuthLoginWithAuth() { | ||
return function (_target, _methodName, descriptor) { | ||
var fn = descriptor.value; | ||
descriptor.value = function () { | ||
var args = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
args[_i] = arguments[_i]; | ||
} | ||
return __awaiter(this, void 0, void 0, function () { | ||
var _fromApp, authInstance, authLogin, _a; | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
_fromApp = this._fromApp; | ||
authInstance = _fromApp.authInstance; | ||
_a = authInstance; | ||
if (!_a) return [3, 2]; | ||
return [4, authInstance.getLoginState()]; | ||
case 1: | ||
_a = (_b.sent()); | ||
_b.label = 2; | ||
case 2: | ||
authLogin = _a; | ||
if (authLogin) { | ||
throw Error('当前已使用 auth 登录,请手动退出 auth 登录后再进行 oauth 登录'); | ||
} | ||
return [2, fn.apply(this, args)]; | ||
} | ||
}); | ||
}); | ||
}; | ||
}; | ||
} | ||
exports.stopOAuthLoginWithAuth = stopOAuthLoginWithAuth; | ||
function stopAuthLoginWithOAuth() { | ||
return function (_target, _methodName, descriptor) { | ||
var fn = descriptor.value; | ||
descriptor.value = function () { | ||
var args = []; | ||
for (var _i = 0; _i < arguments.length; _i++) { | ||
args[_i] = arguments[_i]; | ||
} | ||
return __awaiter(this, void 0, void 0, function () { | ||
var _fromApp, oauthInstance, oauthLogin, _a; | ||
return __generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
_fromApp = this._fromApp; | ||
oauthInstance = _fromApp.oauthInstance || _fromApp.oauth(); | ||
_a = oauthInstance; | ||
if (!_a) return [3, 2]; | ||
return [4, oauthInstance.hasLoginState()]; | ||
case 1: | ||
_a = (_b.sent()); | ||
_b.label = 2; | ||
case 2: | ||
oauthLogin = _a; | ||
if (oauthLogin) { | ||
throw Error('当前已使用 oauth 登录,请手动退出 oauth 登录后再进行 auth 登录'); | ||
} | ||
return [2, fn.apply(this, args)]; | ||
} | ||
}); | ||
}); | ||
}; | ||
}; | ||
} | ||
exports.stopAuthLoginWithOAuth = stopAuthLoginWithOAuth; | ||
function getSourceLink(err) { | ||
@@ -214,2 +282,2 @@ var sourceLink = ''; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/helpers/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { printGroupLog } from \"../libs/util\";\nimport { IS_DEBUG_MODE } from \"../constants\";\n\ninterface ICatchErrorsDecoratorOptions {\n  mode?: 'sync' | 'async';\n  customInfo?: {\n    className?: string;\n    methodName?: string;\n  };\n  title?: string;\n  messages?: string[];\n}\n// firefox的stack格式与chrome不同\nlet isFirefox = false;\nif (typeof navigator !== 'undefined' && navigator.userAgent) {\n  isFirefox = navigator.userAgent.indexOf(\"Firefox\") !== -1;\n}\n/**\n * decorate在stack中一般都特定的规范\n */\nconst REG_STACK_DECORATE = isFirefox ?\n  /(\\.js\\/)?__decorate(\\$\\d+)?<@.*\\d$/ :\n  /(\\/\\w+\\.js\\.)?__decorate(\\$\\d+)?\\s*\\(.*\\)$/;\nconst REG_STACK_LINK = /https?\\:\\/\\/.+\\:\\d*\\/.*\\.js\\:\\d+\\:\\d+/;\n/**\n * debug模式强化日志信息\n * @param options\n */\nexport function catchErrorsDecorator(options: ICatchErrorsDecoratorOptions) {\n\n  const { mode = 'async', customInfo = {}, title, messages = [] } = options;\n\n  return function (\n    target: any,\n    methodName: string,\n    descriptor: TypedPropertyDescriptor<Function>\n  ) {\n    // 生产环境禁用\n    if (!IS_DEBUG_MODE) {\n      return;\n    }\n    const className = customInfo.className || target.constructor.name;\n    const fnName = customInfo.methodName || methodName;\n    const fn = descriptor.value;\n\n    // 被decorator装饰的源码link\n    // 在descriptor.value外部此处创建的stack层次可触达源码\n    // 而descriptor.value内部有可能由于stack太深无法触达\n    const sourceLink = getSourceLink(new Error());\n\n    if (mode === 'sync') {\n      descriptor.value = function (...args: any[]) {\n        // 此处的stack作用主要是为了获取被decorator装饰的源码class和method名称\n        const innerErr: any = getRewritedError({\n          err: new Error(),\n          className,\n          methodName: fnName,\n          sourceLink\n        })\n        try {\n          return fn.apply(this, args);\n        } catch (err) {\n          let failErr = err;\n          const { message: errMsg } = err;\n          const logs: any = {\n            title: title || `${className}.${fnName} failed`,\n            content: [{\n              type: 'error',\n              body: err\n            }]\n          }\n          // 只特殊处理SDK业务逻辑抛出的错误-JSON string\n          if (errMsg && /^\\{.*\\}$/.test(errMsg)) {\n            const msg = JSON.parse(errMsg);\n            logs.subtitle = errMsg;\n            if (msg.code) {\n              if (innerErr) {\n                innerErr.code = msg.code;\n                innerErr.msg = msg.msg;\n              } else {\n                err.code = msg.code\n                err.message = msg.msg\n              }\n              failErr = innerErr || err;\n              logs.content = messages.map(msg => {\n                return {\n                  type: 'info',\n                  body: msg\n                }\n              });\n            }\n          }\n          printGroupLog(logs);\n          throw failErr;\n        }\n      }\n    } else {\n      descriptor.value = async function (...args: any[]) {\n        const innerErr: any = getRewritedError({\n          err: new Error(),\n          className,\n          methodName: fnName,\n          sourceLink\n        })\n        try {\n          return await fn.apply(this, args);\n        } catch (err) {\n          let failErr = err;\n          const { message: errMsg } = err;\n          const logs: any = {\n            title: title || `${className}.${fnName} failed`,\n            content: [{\n              type: 'error',\n              body: err\n            }]\n          }\n          // 只特殊处理SDK业务逻辑抛出的错误-JSON string\n          if (errMsg && /^\\{.*\\}$/.test(errMsg)) {\n            const msg = JSON.parse(errMsg);\n            logs.subtitle = msg;\n            if (msg.code) {\n              if (innerErr) {\n                innerErr.code = msg.code;\n                innerErr.message = msg.msg;\n              } else {\n                err.code = msg.code\n                err.message = msg.msg\n              }\n              failErr = innerErr || err;\n              logs.content = messages.map(msg => {\n                return {\n                  type: 'info',\n                  body: msg\n                }\n              });\n            }\n          }\n          printGroupLog(logs);\n          throw failErr;\n        }\n      }\n    }\n\n  };\n}\n\n/**\n * 在原始堆栈中查找装饰器条目并返回源码链接link\n * @param err\n */\nfunction getSourceLink(err: Error) {\n  let sourceLink = '';\n  const outterErrStacks = err.stack.split('\\n');\n  const indexOfDecorator = outterErrStacks.findIndex(str => REG_STACK_DECORATE.test(str));\n  if (indexOfDecorator !== -1) {\n    const match = REG_STACK_LINK.exec(outterErrStacks[indexOfDecorator + 1] || '');\n    sourceLink = match ? match[0] : '';\n  }\n  return sourceLink;\n}\n\n/**\n * 在原始堆栈中查找装饰器条目，剔除其后的无用堆栈，并将链接替换为源码link\n * @param options\n */\nfunction getRewritedError(options: {\n  err: Error;\n  className: string;\n  methodName: string;\n  sourceLink: string;\n}) {\n  const { err, className, methodName, sourceLink } = options;\n  // 找不到源码link返回null，后续逻辑将打印原堆栈信息\n  if (!sourceLink) {\n    return null;\n  }\n\n  const innerErrStack = err.stack.split('\\n');\n  const REG_STACK_INNER_METHOD = isFirefox ?\n    /^catchErrorsDecorator\\/<\\/descriptor.value@.*\\d$/ :\n    new RegExp(`${className}\\\\.descriptor.value\\\\s*\\\\[as\\\\s${methodName}\\\\]\\\\s*\\\\(.*\\\\)$`);\n  const REG_STACK_INNER_METHOD_WITHOUT_LINK = isFirefox ?\n    /^catchErrorsDecorator\\/<\\/descriptor.value/ :\n    new RegExp(`${className}\\\\.descriptor.value\\\\s*\\\\[as\\\\s${methodName}\\\\]`);\n  const indexOfSource = innerErrStack.findIndex(str => REG_STACK_INNER_METHOD.test(str));\n  let innerErr: Error;\n  if (indexOfSource !== -1) {\n    // @ts-ignore\n    const realErrStack = innerErrStack.filter((v, i) => {\n      return i > indexOfSource\n    });\n    realErrStack.unshift(innerErrStack[indexOfSource]\n      .replace(REG_STACK_INNER_METHOD_WITHOUT_LINK, `${className}.${methodName}`)\n      .replace(REG_STACK_LINK, sourceLink));\n    innerErr = new Error();\n    innerErr.stack = `${isFirefox ? '@debugger' : 'Error'}\\n${realErrStack.join('\\n')}`;\n  }\n  return innerErr;\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/helpers/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { printGroupLog } from \"../libs/util\";\nimport { IS_DEBUG_MODE } from \"../constants\";\n\ninterface ICatchErrorsDecoratorOptions {\n  mode?: 'sync' | 'async';\n  customInfo?: {\n    className?: string;\n    methodName?: string;\n  };\n  title?: string;\n  messages?: string[];\n}\n// firefox的stack格式与chrome不同\nlet isFirefox = false;\nif (typeof navigator !== 'undefined' && navigator.userAgent) {\n  isFirefox = navigator.userAgent.indexOf(\"Firefox\") !== -1;\n}\n/**\n * decorate在stack中一般都特定的规范\n */\nconst REG_STACK_DECORATE = isFirefox ?\n  /(\\.js\\/)?__decorate(\\$\\d+)?<@.*\\d$/ :\n  /(\\/\\w+\\.js\\.)?__decorate(\\$\\d+)?\\s*\\(.*\\)$/;\nconst REG_STACK_LINK = /https?\\:\\/\\/.+\\:\\d*\\/.*\\.js\\:\\d+\\:\\d+/;\n/**\n * debug模式强化日志信息\n * @param options\n */\nexport function catchErrorsDecorator(options: ICatchErrorsDecoratorOptions) {\n\n  const { mode = 'async', customInfo = {}, title, messages = [] } = options;\n\n  return function (\n    target: any,\n    methodName: string,\n    descriptor: TypedPropertyDescriptor<Function>\n  ) {\n    // 生产环境禁用\n    if (!IS_DEBUG_MODE) {\n      return;\n    }\n    const className = customInfo.className || target.constructor.name;\n    const fnName = customInfo.methodName || methodName;\n    const fn = descriptor.value;\n\n    // 被decorator装饰的源码link\n    // 在descriptor.value外部此处创建的stack层次可触达源码\n    // 而descriptor.value内部有可能由于stack太深无法触达\n    const sourceLink = getSourceLink(new Error());\n\n    if (mode === 'sync') {\n      descriptor.value = function (...args: any[]) {\n        // 此处的stack作用主要是为了获取被decorator装饰的源码class和method名称\n        const innerErr: any = getRewritedError({\n          err: new Error(),\n          className,\n          methodName: fnName,\n          sourceLink\n        })\n        try {\n          return fn.apply(this, args);\n        } catch (err) {\n          let failErr = err;\n          const { message: errMsg } = err;\n          const logs: any = {\n            title: title || `${className}.${fnName} failed`,\n            content: [{\n              type: 'error',\n              body: err\n            }]\n          }\n          // 只特殊处理SDK业务逻辑抛出的错误-JSON string\n          if (errMsg && /^\\{.*\\}$/.test(errMsg)) {\n            const msg = JSON.parse(errMsg);\n            logs.subtitle = errMsg;\n            if (msg.code) {\n              if (innerErr) {\n                innerErr.code = msg.code;\n                innerErr.msg = msg.msg;\n              } else {\n                err.code = msg.code\n                err.message = msg.msg\n              }\n              failErr = innerErr || err;\n              logs.content = messages.map(msg => {\n                return {\n                  type: 'info',\n                  body: msg\n                }\n              });\n            }\n          }\n          printGroupLog(logs);\n          throw failErr;\n        }\n      }\n    } else {\n      descriptor.value = async function (...args: any[]) {\n        const innerErr: any = getRewritedError({\n          err: new Error(),\n          className,\n          methodName: fnName,\n          sourceLink\n        })\n        try {\n          return await fn.apply(this, args);\n        } catch (err) {\n          let failErr = err;\n          const { message: errMsg } = err;\n          const logs: any = {\n            title: title || `${className}.${fnName} failed`,\n            content: [{\n              type: 'error',\n              body: err\n            }]\n          }\n          // 只特殊处理SDK业务逻辑抛出的错误-JSON string\n          if (errMsg && /^\\{.*\\}$/.test(errMsg)) {\n            const msg = JSON.parse(errMsg);\n            logs.subtitle = msg;\n            if (msg.code) {\n              if (innerErr) {\n                innerErr.code = msg.code;\n                innerErr.message = msg.msg;\n              } else {\n                err.code = msg.code\n                err.message = msg.msg\n              }\n              failErr = innerErr || err;\n              logs.content = messages.map(msg => {\n                return {\n                  type: 'info',\n                  body: msg\n                }\n              });\n            }\n          }\n          printGroupLog(logs);\n          throw failErr;\n        }\n      }\n    }\n\n  };\n}\n\nexport function stopOAuthLoginWithAuth() {\n  return function (\n    _target: any,\n    _methodName: string,\n    descriptor: TypedPropertyDescriptor<Function>\n  ) {\n    const fn = descriptor.value;\n    descriptor.value = async function (...args: any[]) {\n      const { _fromApp } = this\n      const authInstance = _fromApp.authInstance\n      // const oauthInstance = _fromApp.oauthInstance\n      const authLogin = authInstance && await authInstance.getLoginState()\n      if (authLogin) {\n        throw Error('当前已使用 auth 登录，请手动退出 auth 登录后再进行 oauth 登录')\n      }\n\n      return fn.apply(this, args);\n    }\n  }\n}\n\nexport function stopAuthLoginWithOAuth() {\n  return function (\n    _target: any,\n    _methodName: string,\n    descriptor: TypedPropertyDescriptor<Function>\n  ) {\n    const fn = descriptor.value;\n    descriptor.value = async function (...args: any[]) {\n      const { _fromApp } = this\n      // const authInstance = _fromApp.authInstance\n      const oauthInstance = _fromApp.oauthInstance || (_fromApp as any).oauth()\n      const oauthLogin = oauthInstance && await oauthInstance.hasLoginState()\n      if (oauthLogin) {\n        throw Error('当前已使用 oauth 登录，请手动退出 oauth 登录后再进行 auth 登录')\n      }\n\n      return fn.apply(this, args);\n    }\n  }\n}\n\n/**\n * 在原始堆栈中查找装饰器条目并返回源码链接link\n * @param err\n */\nfunction getSourceLink(err: Error) {\n  let sourceLink = '';\n  const outterErrStacks = err.stack.split('\\n');\n  const indexOfDecorator = outterErrStacks.findIndex(str => REG_STACK_DECORATE.test(str));\n  if (indexOfDecorator !== -1) {\n    const match = REG_STACK_LINK.exec(outterErrStacks[indexOfDecorator + 1] || '');\n    sourceLink = match ? match[0] : '';\n  }\n  return sourceLink;\n}\n\n/**\n * 在原始堆栈中查找装饰器条目，剔除其后的无用堆栈，并将链接替换为源码link\n * @param options\n */\nfunction getRewritedError(options: {\n  err: Error;\n  className: string;\n  methodName: string;\n  sourceLink: string;\n}) {\n  const { err, className, methodName, sourceLink } = options;\n  // 找不到源码link返回null，后续逻辑将打印原堆栈信息\n  if (!sourceLink) {\n    return null;\n  }\n\n  const innerErrStack = err.stack.split('\\n');\n  const REG_STACK_INNER_METHOD = isFirefox ?\n    /^catchErrorsDecorator\\/<\\/descriptor.value@.*\\d$/ :\n    new RegExp(`${className}\\\\.descriptor.value\\\\s*\\\\[as\\\\s${methodName}\\\\]\\\\s*\\\\(.*\\\\)$`);\n  const REG_STACK_INNER_METHOD_WITHOUT_LINK = isFirefox ?\n    /^catchErrorsDecorator\\/<\\/descriptor.value/ :\n    new RegExp(`${className}\\\\.descriptor.value\\\\s*\\\\[as\\\\s${methodName}\\\\]`);\n  const indexOfSource = innerErrStack.findIndex(str => REG_STACK_INNER_METHOD.test(str));\n  let innerErr: Error;\n  if (indexOfSource !== -1) {\n    // @ts-ignore\n    const realErrStack = innerErrStack.filter((v, i) => {\n      return i > indexOfSource\n    });\n    realErrStack.unshift(innerErrStack[indexOfSource]\n      .replace(REG_STACK_INNER_METHOD_WITHOUT_LINK, `${className}.${methodName}`)\n      .replace(REG_STACK_LINK, sourceLink));\n    innerErr = new Error();\n    innerErr.stack = `${isFirefox ? '@debugger' : 'Error'}\\n${realErrStack.join('\\n')}`;\n  }\n  return innerErr;\n}"]} |
{ | ||
"name": "@cloudbase/utilities", | ||
"version": "1.4.2-alpha.0", | ||
"version": "1.4.3-alpha.0", | ||
"description": "cloudbase javascript sdk utilities", | ||
@@ -38,3 +38,3 @@ "main": "dist/index.js", | ||
"@cloudbase/adapter-interface": "^0.4.0", | ||
"@cloudbase/types": "^1.2.2-alpha.0", | ||
"@cloudbase/types": "^1.2.3-alpha.0", | ||
"crypto-js": "3", | ||
@@ -53,3 +53,3 @@ "jwt-decode": "^3.1.2" | ||
}, | ||
"gitHead": "d158e30a395d8fcd6b7c7e78a66006b194a3eddb" | ||
"gitHead": "eb161dd3c79b90a95a877984bf7c07cdb4563077" | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
150069
1460
+ Added@cloudbase/types@1.2.3-alpha.0(transitive)
- Removed@cloudbase/types@1.2.2-alpha.0(transitive)