Socket
Socket
Sign inDemoInstall

@cloudbase/utilities

Package Overview
Dependencies
Maintainers
10
Versions
109
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.1.2-alpha.1 to 1.1.2-alpha.2

6

dist/helpers/decorators.js

@@ -47,4 +47,4 @@ "use strict";

var REG_STACK_DECORATE = isFirefox ?
/\.js\/__decorate<@.*\d$/ :
/\/\w+\.js\.__decorate\s*\(.*\)$/;
/(\.js\/)?__decorate(\$\d+)?<@.*\d$/ :
/(\/\w+\.js\.)?__decorate(\$\d+)?\s*\(.*\)$/;
var REG_STACK_LINK = /https?\:\/\/.+\:\d*\/.*\.js\:\d+\:\d+/;

@@ -197,2 +197,2 @@ function catchErrorsDecorator(options) {

}
//# 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$/ : \n  /\\/\\w+\\.js\\.__decorate\\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 = 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              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 = 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              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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qCAA6C;AAC7C,0CAA6C;AAY7C,IAAI,SAAS,GAAG,KAAK,CAAC;AACtB,IAAG,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC,SAAS,EAAC;IACzD,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;CAC3D;AAID,IAAM,kBAAkB,GAAG,SAAS,CAAC,CAAC;IACpC,oCAAoC,CAAC,CAAC;IACtC,4CAA4C,CAAC;AAC/C,IAAM,cAAc,GAAG,uCAAuC,CAAC;AAK/D,SAAgB,oBAAoB,CAAC,OAAoC;IAE/D,IAAA,KAAoD,OAAO,KAA/C,EAAZ,IAAI,mBAAC,OAAO,KAAA,EAAE,KAAsC,OAAO,WAAhC,EAAb,UAAU,mBAAC,EAAE,KAAA,EAAE,KAAK,GAAkB,OAAO,MAAzB,EAAE,KAAgB,OAAO,SAAZ,EAAX,QAAQ,mBAAC,EAAE,KAAA,CAAa;IAEpE,OAAO,UACL,MAAW,EACX,UAAkB,EAClB,UAA6C;QAG7C,IAAG,CAAC,yBAAa,EAAC;YAChB,OAAO;SACR;QACD,IAAM,SAAS,GAAG,UAAU,CAAC,SAAS,IAAI,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC;QAClE,IAAM,MAAM,GAAG,UAAU,CAAC,UAAU,IAAI,UAAU,CAAC;QACnD,IAAM,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC;QAK5B,IAAM,UAAU,GAAG,aAAa,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC;QAE9C,IAAG,IAAI,KAAK,MAAM,EAAC;YACjB,UAAU,CAAC,KAAK,GAAG;gBAAS,cAAa;qBAAb,UAAa,EAAb,qBAAa,EAAb,IAAa;oBAAb,yBAAa;;gBAEvC,IAAM,QAAQ,GAAG,gBAAgB,CAAC;oBAChC,GAAG,EAAE,IAAI,KAAK,EAAE;oBAChB,SAAS,WAAA;oBACT,UAAU,EAAE,MAAM;oBAClB,UAAU,YAAA;iBACX,CAAC,CAAA;gBACF,IAAI;oBACF,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;iBAC7B;gBAAC,OAAO,GAAG,EAAE;oBACZ,IAAI,OAAO,GAAG,GAAG,CAAC;oBACV,IAAS,MAAM,GAAK,GAAG,QAAR,CAAS;oBAChC,IAAM,IAAI,GAAO;wBACf,KAAK,EAAE,KAAK,IAAK,SAAS,SAAI,MAAM,YAAS;wBAC7C,OAAO,EAAE,CAAC;gCACR,IAAI,EAAE,OAAO;gCACb,IAAI,EAAE,GAAG;6BACV,CAAC;qBACH,CAAA;oBAED,IAAG,MAAM,IAAE,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC;wBACjC,IAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;wBAC/B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;wBACvB,IAAG,GAAG,CAAC,IAAI,EAAC;4BACV,OAAO,GAAG,QAAQ,IAAI,GAAG,CAAC;4BAC1B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,GAAG;gCAC7B,OAAO;oCACL,IAAI,EAAE,MAAM;oCACZ,IAAI,EAAE,GAAG;iCACV,CAAA;4BACH,CAAC,CAAC,CAAC;yBACJ;qBACF;oBACD,oBAAa,CAAC,IAAI,CAAC,CAAC;oBACpB,MAAM,OAAO,CAAC;iBACf;YACH,CAAC,CAAA;SACF;aAAI;YACH,UAAU,CAAC,KAAK,GAAG;gBAAe,cAAa;qBAAb,UAAa,EAAb,qBAAa,EAAb,IAAa;oBAAb,yBAAa;;;;;;;gCACvC,QAAQ,GAAG,gBAAgB,CAAC;oCAChC,GAAG,EAAE,IAAI,KAAK,EAAE;oCAChB,SAAS,WAAA;oCACT,UAAU,EAAE,MAAM;oCAClB,UAAU,YAAA;iCACX,CAAC,CAAA;;;;gCAEO,WAAM,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,EAAA;oCAAjC,WAAO,SAA0B,EAAC;;;gCAE9B,OAAO,GAAG,KAAG,CAAC;gCACD,MAAM,GAAK,KAAG,QAAR,CAAS;gCAC1B,IAAI,GAAO;oCACf,KAAK,EAAE,KAAK,IAAK,SAAS,SAAI,MAAM,YAAS;oCAC7C,OAAO,EAAE,CAAC;4CACR,IAAI,EAAE,OAAO;4CACb,IAAI,EAAE,KAAG;yCACV,CAAC;iCACH,CAAA;gCAED,IAAG,MAAM,IAAE,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC;oCAC3B,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;oCAC/B,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;oCACpB,IAAG,GAAG,CAAC,IAAI,EAAC;wCACV,OAAO,GAAG,QAAQ,IAAI,KAAG,CAAC;wCAC1B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,GAAG;4CAC7B,OAAO;gDACL,IAAI,EAAE,MAAM;gDACZ,IAAI,EAAE,GAAG;6CACV,CAAA;wCACH,CAAC,CAAC,CAAC;qCACJ;iCACF;gCACD,oBAAa,CAAC,IAAI,CAAC,CAAC;gCACpB,MAAM,OAAO,CAAC;;;;;aAEjB,CAAA;SACF;IAEH,CAAC,CAAC;AACJ,CAAC;AAtGD,oDAsGC;AAMD,SAAS,aAAa,CAAC,GAAS;IAC9B,IAAI,UAAU,GAAG,EAAE,CAAC;IACpB,IAAM,eAAe,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC9C,IAAM,gBAAgB,GAAG,eAAe,CAAC,SAAS,CAAC,UAAA,GAAG,IAAE,OAAA,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,EAA5B,CAA4B,CAAC,CAAC;IACtF,IAAG,gBAAgB,KAAG,CAAC,CAAC,EAAC;QACvB,IAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,GAAC,CAAC,CAAC,IAAE,EAAE,CAAC,CAAC;QAC3E,UAAU,GAAG,KAAK,CAAA,CAAC,CAAA,KAAK,CAAC,CAAC,CAAC,CAAA,CAAC,CAAA,EAAE,CAAC;KAChC;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;AAMD,SAAS,gBAAgB,CAAC,OAKzB;IACS,IAAA,GAAG,GAAuC,OAAO,IAA9C,EAAE,SAAS,GAA4B,OAAO,UAAnC,EAAE,UAAU,GAAgB,OAAO,WAAvB,EAAE,UAAU,GAAI,OAAO,WAAX,CAAY;IAE1D,IAAG,CAAC,UAAU,EAAC;QACb,OAAO,IAAI,CAAC;KACb;IAED,IAAM,aAAa,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC5C,IAAM,sBAAsB,GAAG,SAAS,CAAC,CAAC;QACxC,kDAAkD,CAAC,CAAC;QACpD,IAAI,MAAM,CAAI,SAAS,uCAAkC,UAAU,qBAAkB,CAAC,CAAC;IACzF,IAAM,mCAAmC,GAAG,SAAS,CAAC,CAAC;QACrD,4CAA4C,CAAC,CAAC;QAC9C,IAAI,MAAM,CAAI,SAAS,uCAAkC,UAAU,QAAK,CAAC,CAAC;IAC5E,IAAM,aAAa,GAAG,aAAa,CAAC,SAAS,CAAC,UAAA,GAAG,IAAE,OAAA,sBAAsB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAhC,CAAgC,CAAC,CAAC;IACrF,IAAI,QAAc,CAAC;IACnB,IAAG,aAAa,KAAK,CAAC,CAAC,EAAC;QAEtB,IAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CAAC,UAAC,CAAC,EAAC,CAAC;YAC5C,OAAO,CAAC,GAAC,aAAa,CAAA;QACxB,CAAC,CAAC,CAAC;QACH,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC;aAC9C,OAAO,CAAC,mCAAmC,EAAI,SAAS,SAAI,UAAY,CAAC;aACzE,OAAO,CAAC,cAAc,EAAC,UAAU,CAAC,CAAC,CAAC;QACvC,QAAQ,GAAG,IAAI,KAAK,EAAE,CAAC;QACvB,QAAQ,CAAC,KAAK,GAAG,CAAI,SAAS,CAAC,CAAC,CAAC,WAAW,CAAA,CAAC,CAAC,OAAO,WAAK,YAAY,CAAC,IAAI,CAAC,IAAI,CAAG,CAAC;KACrF;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC","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 = 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              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 = 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              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.1.2-alpha.1",
"version": "1.1.2-alpha.2",
"description": "cloudbase javascript sdk utilities",

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

},
"gitHead": "edb3bfc51f3d214cb292d6e00b294f4e6c1ec232"
"gitHead": "ceb7175c19241332e0af1c33da308b6e27c925ae"
}
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