Socket
Socket
Sign inDemoInstall

@cloudbase/utilities

Package Overview
Dependencies
Maintainers
12
Versions
115
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@cloudbase/utilities - npm Package Compare versions

Comparing version 1.3.3-alpha.0 to 1.3.4-alpha.0

22

dist/helpers/decorators.js

@@ -89,4 +89,10 @@ "use strict";

if (msg.code) {
innerErr.code = msg.code;
innerErr.message = msg.msg;
if (innerErr) {
innerErr.code = msg.code;
innerErr.msg = msg.msg;
}
else {
err.code = msg.code;
err.message = msg.msg;
}
failErr = innerErr || err;

@@ -143,4 +149,10 @@ logs.content = messages.map(function (msg) {

if (msg.code) {
innerErr.code = msg.code;
innerErr.message = msg.msg;
if (innerErr) {
innerErr.code = msg.code;
innerErr.message = msg.msg;
}
else {
err_1.code = msg.code;
err_1.message = msg.msg;
}
failErr = innerErr || err_1;

@@ -202,2 +214,2 @@ logs.content = messages.map(function (msg) {

}
//# 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              innerErr.code = msg.code;\n              innerErr.message = msg.msg;\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              innerErr.code = msg.code;\n              innerErr.message = msg.msg;\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\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.3.3-alpha.0",
"version": "1.3.4-alpha.0",
"description": "cloudbase javascript sdk utilities",

@@ -51,3 +51,3 @@ "main": "dist/index.js",

},
"gitHead": "c3223d96a60b5b8f87f159d503defa4b2b7a31a5"
"gitHead": "564033e5caf8a6b3be21a4ccfb63c5b799ee781d"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc