@willbooster/shared-lib 6.0.4 → 6.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/error.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var r=require("./sleep.cjs");exports.errorify=function(r){if(r instanceof Error)return r;if("string"==typeof r)return new Error(r);try{return new Error(JSON.stringify(r))}catch(t){return new Error(String(r))}},exports.ignoreEnoent=function(r){try{return r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}},exports.ignoreEnoentAsync=async function(r){try{return await r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}},exports.ignoreError=function(r){try{return r()}catch(r){}},exports.ignoreErrorAsync=async function(r){try{return await r()}catch(r){}},exports.withRetry=async function(t,{beforeRetry:e,handleError:n,retryCount:o=3,retryLogger:i,shouldRetry:c,sleepMilliseconds:a=0,updateSleepMilliseconds:s}={}){let u=0;for(;;)try{return await t(u)}catch(t){if(await(null==n?void 0:n(t)),u++,u>=o)throw t;if(c&&!c(t))throw t;a>0&&await r.sleep(a),s&&(a=s(a)),null==i||i(`Retry due to: ${t}\n${t instanceof Error?"---\n"+t.stack:""}`),await(null==e?void 0:e(t))}};
1
+ "use strict";var r=require("./sleep.cjs");exports.errorify=function(r){if(r instanceof Error)return r;if("string"==typeof r)return new Error(r);try{return new Error(JSON.stringify(r))}catch(t){return new Error(String(r))}},exports.ignoreEnoent=function(r){try{return r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}},exports.ignoreEnoentAsync=async function(r){try{return await r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}},exports.ignoreError=function(r){try{return r()}catch(r){}},exports.ignoreErrorAsync=async function(r){try{return await r()}catch(r){}},exports.withRetry=async function(t,{beforeRetry:e,handleError:n,retryCount:o=3,retryLogger:i,shouldRetry:c,sleepMilliseconds:a=0,updateSleepMilliseconds:s}={}){let u=0;for(;;)try{return await t(u)}catch(t){var y;if(await(null==n?void 0:n(t)),u++,u>=o)throw t;if(c&&!c(t))throw t;a>0&&await r.sleep(a),s&&(a=s(a)),null==i||i(`Retry due to: ${t}\n${t instanceof Error?"---\n"+(null!=(y=t.stack)?y:""):""}`),await(null==e?void 0:e(t))}};
2
2
  //# sourceMappingURL=error.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"error.cjs","sources":["../src/error.ts"],"sourcesContent":["import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n if (obj instanceof Error) return obj;\n if (typeof obj === 'string') return new Error(obj);\n try {\n return new Error(JSON.stringify(obj));\n } catch {\n return new Error(String(obj));\n }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch {\n // do nothing\n }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch {\n // do nothing\n }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport interface RetryOptions {\n beforeRetry?: (error: unknown) => Promise<void>;\n handleError?: (error: unknown) => Promise<void>;\n retryCount?: number;\n retryLogger?: (message: string) => void;\n shouldRetry?: (error: unknown) => boolean;\n sleepMilliseconds?: number;\n updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n func: (failedCount: number) => T | Promise<T>,\n {\n beforeRetry,\n handleError,\n retryCount = 3,\n retryLogger,\n shouldRetry,\n sleepMilliseconds = 0,\n updateSleepMilliseconds,\n }: RetryOptions = {}\n): Promise<T> {\n let failedCount = 0;\n for (;;) {\n try {\n return await func(failedCount);\n } catch (error) {\n await handleError?.(error);\n failedCount++;\n if (failedCount >= retryCount) {\n throw error;\n }\n if (shouldRetry && !shouldRetry(error)) {\n throw error;\n }\n if (sleepMilliseconds > 0) {\n await sleep(sleepMilliseconds);\n }\n if (updateSleepMilliseconds) {\n sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n }\n retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + error.stack : ''}`);\n await beforeRetry?.(error);\n }\n }\n}\n"],"names":["obj","Error","JSON","stringify","_unused","String","fn","error","code","async","_unused2","_unused3","func","beforeRetry","handleError","retryCount","retryLogger","shouldRetry","sleepMilliseconds","updateSleepMilliseconds","failedCount","sleep","stack"],"mappings":"2DAMO,SAAkBA,GACvB,GAAIA,aAAeC,MAAO,OAAOD,EACjC,GAAmB,iBAARA,EAAkB,OAAO,IAAIC,MAAMD,GAC9C,IACE,OAAO,IAAIC,MAAMC,KAAKC,UAAUH,GAClC,CAAE,MAAAI,GACA,OAAO,IAAIH,MAAMI,OAAOL,GAC1B,CACF,uBAUO,SAAyBM,GAC9B,IACE,OAAOA,GACT,CAAE,MAAOC,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,4BAUOE,eAAoCH,GACzC,IACE,aAAaA,GACf,CAAE,MAAOC,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,sBApCO,SAAwBD,GAC7B,IACE,OAAOA,GACT,CAAE,MAAAI,GACA,CAEJ,2BAaOD,eAAmCH,GACxC,IACE,aAAaA,GACf,CAAE,MAAAK,GACA,CAEJ,oBAiCOF,eACLG,GACAC,YACEA,EAAWC,YACXA,EAAWC,WACXA,EAAa,EAACC,YACdA,EAAWC,YACXA,EAAWC,kBACXA,EAAoB,EAACC,wBACrBA,GACgB,IAElB,IAAIC,EAAc,EAClB,OACE,IACE,aAAaR,EAAKQ,EACpB,CAAE,MAAOb,GAGP,SAFiB,MAAXO,OAAW,EAAXA,EAAcP,IACpBa,IACIA,GAAeL,EACjB,MAAMR,EAER,GAAIU,IAAgBA,EAAYV,GAC9B,MAAMA,EAEJW,EAAoB,SAChBG,EAAAA,MAAMH,GAEVC,IACFD,EAAoBC,EAAwBD,IAEnC,MAAXF,GAAAA,EAAc,iBAAiBT,MACnCA,aAAiBN,MAAQ,QAAUM,EAAMe,MAAQ,YAC5B,MAAXT,OAAW,EAAXA,EAAcN,GACtB,CAEJ"}
1
+ {"version":3,"file":"error.cjs","sources":["../src/error.ts"],"sourcesContent":["import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n if (obj instanceof Error) return obj;\n if (typeof obj === 'string') return new Error(obj);\n try {\n return new Error(JSON.stringify(obj));\n } catch {\n return new Error(String(obj));\n }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch {\n // do nothing\n }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch {\n // do nothing\n }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport type RetryOptions = {\n beforeRetry?: (error: unknown) => Promise<void>;\n handleError?: (error: unknown) => Promise<void>;\n retryCount?: number;\n retryLogger?: (message: string) => void;\n shouldRetry?: (error: unknown) => boolean;\n sleepMilliseconds?: number;\n updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n};\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n func: (failedCount: number) => T | Promise<T>,\n {\n beforeRetry,\n handleError,\n retryCount = 3,\n retryLogger,\n shouldRetry,\n sleepMilliseconds = 0,\n updateSleepMilliseconds,\n }: RetryOptions = {}\n): Promise<T> {\n let failedCount = 0;\n for (;;) {\n try {\n return await func(failedCount);\n } catch (error) {\n await handleError?.(error);\n failedCount++;\n if (failedCount >= retryCount) {\n throw error;\n }\n if (shouldRetry && !shouldRetry(error)) {\n throw error;\n }\n if (sleepMilliseconds > 0) {\n await sleep(sleepMilliseconds);\n }\n if (updateSleepMilliseconds) {\n sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n }\n retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n await beforeRetry?.(error);\n }\n }\n}\n"],"names":["obj","Error","JSON","stringify","_unused","String","fn","error","code","async","_unused2","_unused3","func","beforeRetry","handleError","retryCount","retryLogger","shouldRetry","sleepMilliseconds","updateSleepMilliseconds","failedCount","_error$stack","sleep","stack"],"mappings":"2DAMO,SAAkBA,GACvB,GAAIA,aAAeC,MAAO,OAAOD,EACjC,GAAmB,iBAARA,EAAkB,OAAO,IAAIC,MAAMD,GAC9C,IACE,OAAO,IAAIC,MAAMC,KAAKC,UAAUH,GAClC,CAAE,MAAAI,GACA,OAAO,IAAIH,MAAMI,OAAOL,GAC1B,CACF,uBAUO,SAAyBM,GAC9B,IACE,OAAOA,GACT,CAAE,MAAOC,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,4BAUOE,eAAoCH,GACzC,IACE,aAAaA,GACf,CAAE,MAAOC,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,sBApCO,SAAwBD,GAC7B,IACE,OAAOA,GACT,CAAE,MAAAI,GACA,CAEJ,2BAaOD,eAAmCH,GACxC,IACE,aAAaA,GACf,CAAE,MAAAK,GACA,CAEJ,oBAiCOF,eACLG,GACAC,YACEA,EAAWC,YACXA,EAAWC,WACXA,EAAa,EAACC,YACdA,EAAWC,YACXA,EAAWC,kBACXA,EAAoB,EAACC,wBACrBA,GACgB,IAElB,IAAIC,EAAc,EAClB,OACE,IACE,aAAaR,EAAKQ,EACpB,CAAE,MAAOb,GAAO,IAAAc,EAGd,SAFiB,MAAXP,OAAW,EAAXA,EAAcP,IACpBa,IACIA,GAAeL,EACjB,MAAMR,EAER,GAAIU,IAAgBA,EAAYV,GAC9B,MAAMA,EAEJW,EAAoB,SAChBI,EAAAA,MAAMJ,GAEVC,IACFD,EAAoBC,EAAwBD,IAEnC,MAAXF,GAAAA,EAAc,iBAAiBT,MACnCA,aAAiBN,MAAQ,SAAsB,OAAfoB,EAAId,EAAMgB,OAAKF,EAAI,IAAM,YACpC,MAAXR,OAAW,EAAXA,EAAcN,GACtB,CAEJ"}
package/dist/error.d.ts CHANGED
@@ -7,7 +7,7 @@ export declare function ignoreError<T>(fn: () => T): T | undefined;
7
7
  export declare function ignoreEnoent<T>(fn: () => T): T | undefined;
8
8
  export declare function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined>;
9
9
  export declare function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined>;
10
- export interface RetryOptions {
10
+ export type RetryOptions = {
11
11
  beforeRetry?: (error: unknown) => Promise<void>;
12
12
  handleError?: (error: unknown) => Promise<void>;
13
13
  retryCount?: number;
@@ -15,7 +15,7 @@ export interface RetryOptions {
15
15
  shouldRetry?: (error: unknown) => boolean;
16
16
  sleepMilliseconds?: number;
17
17
  updateSleepMilliseconds?: (sleepMilliseconds: number) => number;
18
- }
18
+ };
19
19
  /**
20
20
  * Retry the given function.
21
21
  * @param func The function to retry.
package/dist/error.js CHANGED
@@ -1,2 +1,2 @@
1
- import{sleep as r}from"./sleep.js";function t(r){if(r instanceof Error)return r;if("string"==typeof r)return new Error(r);try{return new Error(JSON.stringify(r))}catch(t){return new Error(String(r))}}function n(r){try{return r()}catch(r){}}function e(r){try{return r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}}async function o(r){try{return await r()}catch(r){}}async function i(r){try{return await r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}}async function c(t,{beforeRetry:n,handleError:e,retryCount:o=3,retryLogger:i,shouldRetry:c,sleepMilliseconds:a=0,updateSleepMilliseconds:u}={}){let f=0;for(;;)try{return await t(f)}catch(t){if(await(null==e?void 0:e(t)),f++,f>=o)throw t;if(c&&!c(t))throw t;a>0&&await r(a),u&&(a=u(a)),null==i||i(`Retry due to: ${t}\n${t instanceof Error?"---\n"+t.stack:""}`),await(null==n?void 0:n(t))}}export{t as errorify,e as ignoreEnoent,i as ignoreEnoentAsync,n as ignoreError,o as ignoreErrorAsync,c as withRetry};
1
+ import{sleep as r}from"./sleep.js";function t(r){if(r instanceof Error)return r;if("string"==typeof r)return new Error(r);try{return new Error(JSON.stringify(r))}catch(t){return new Error(String(r))}}function n(r){try{return r()}catch(r){}}function e(r){try{return r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}}async function o(r){try{return await r()}catch(r){}}async function i(r){try{return await r()}catch(r){if("object"==typeof r&&r&&"code"in r&&"ENOENT"===r.code)return;throw r}}async function c(t,{beforeRetry:n,handleError:e,retryCount:o=3,retryLogger:i,shouldRetry:c,sleepMilliseconds:a=0,updateSleepMilliseconds:u}={}){let f=0;for(;;)try{return await t(f)}catch(t){var l;if(await(null==e?void 0:e(t)),f++,f>=o)throw t;if(c&&!c(t))throw t;a>0&&await r(a),u&&(a=u(a)),null==i||i(`Retry due to: ${t}\n${t instanceof Error?"---\n"+(null!=(l=t.stack)?l:""):""}`),await(null==n?void 0:n(t))}}export{t as errorify,e as ignoreEnoent,i as ignoreEnoentAsync,n as ignoreError,o as ignoreErrorAsync,c as withRetry};
2
2
  //# sourceMappingURL=error.js.map
package/dist/error.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"error.js","sources":["../src/error.ts"],"sourcesContent":["import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n if (obj instanceof Error) return obj;\n if (typeof obj === 'string') return new Error(obj);\n try {\n return new Error(JSON.stringify(obj));\n } catch {\n return new Error(String(obj));\n }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch {\n // do nothing\n }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch {\n // do nothing\n }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport interface RetryOptions {\n beforeRetry?: (error: unknown) => Promise<void>;\n handleError?: (error: unknown) => Promise<void>;\n retryCount?: number;\n retryLogger?: (message: string) => void;\n shouldRetry?: (error: unknown) => boolean;\n sleepMilliseconds?: number;\n updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n func: (failedCount: number) => T | Promise<T>,\n {\n beforeRetry,\n handleError,\n retryCount = 3,\n retryLogger,\n shouldRetry,\n sleepMilliseconds = 0,\n updateSleepMilliseconds,\n }: RetryOptions = {}\n): Promise<T> {\n let failedCount = 0;\n for (;;) {\n try {\n return await func(failedCount);\n } catch (error) {\n await handleError?.(error);\n failedCount++;\n if (failedCount >= retryCount) {\n throw error;\n }\n if (shouldRetry && !shouldRetry(error)) {\n throw error;\n }\n if (sleepMilliseconds > 0) {\n await sleep(sleepMilliseconds);\n }\n if (updateSleepMilliseconds) {\n sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n }\n retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + error.stack : ''}`);\n await beforeRetry?.(error);\n }\n }\n}\n"],"names":["errorify","obj","Error","JSON","stringify","_unused","String","ignoreError","fn","_unused2","ignoreEnoent","error","code","async","ignoreErrorAsync","_unused3","ignoreEnoentAsync","withRetry","func","beforeRetry","handleError","retryCount","retryLogger","shouldRetry","sleepMilliseconds","updateSleepMilliseconds","failedCount","sleep","stack"],"mappings":"mCAMO,SAASA,EAASC,GACvB,GAAIA,aAAeC,MAAO,OAAOD,EACjC,GAAmB,iBAARA,EAAkB,OAAO,IAAIC,MAAMD,GAC9C,IACE,OAAO,IAAIC,MAAMC,KAAKC,UAAUH,GAClC,CAAE,MAAAI,GACA,OAAO,IAAIH,MAAMI,OAAOL,GAC1B,CACF,CAEO,SAASM,EAAeC,GAC7B,IACE,OAAOA,GACT,CAAE,MAAAC,GACA,CAEJ,CAEO,SAASC,EAAgBF,GAC9B,IACE,OAAOA,GACT,CAAE,MAAOG,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,CAEOE,eAAeC,EAAoBN,GACxC,IACE,aAAaA,GACf,CAAE,MAAAO,GACA,CAEJ,CAEOF,eAAeG,EAAqBR,GACzC,IACE,aAAaA,GACf,CAAE,MAAOG,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,CAsBOE,eAAeI,EACpBC,GACAC,YACEA,EAAWC,YACXA,EAAWC,WACXA,EAAa,EAACC,YACdA,EAAWC,YACXA,EAAWC,kBACXA,EAAoB,EAACC,wBACrBA,GACgB,IAElB,IAAIC,EAAc,EAClB,OACE,IACE,aAAaR,EAAKQ,EACpB,CAAE,MAAOf,GAGP,SAFiB,MAAXS,OAAW,EAAXA,EAAcT,IACpBe,IACIA,GAAeL,EACjB,MAAMV,EAER,GAAIY,IAAgBA,EAAYZ,GAC9B,MAAMA,EAEJa,EAAoB,SAChBG,EAAMH,GAEVC,IACFD,EAAoBC,EAAwBD,IAEnC,MAAXF,GAAAA,EAAc,iBAAiBX,MACnCA,aAAiBT,MAAQ,QAAUS,EAAMiB,MAAQ,YAC5B,MAAXT,OAAW,EAAXA,EAAcR,GACtB,CAEJ"}
1
+ {"version":3,"file":"error.js","sources":["../src/error.ts"],"sourcesContent":["import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n if (obj instanceof Error) return obj;\n if (typeof obj === 'string') return new Error(obj);\n try {\n return new Error(JSON.stringify(obj));\n } catch {\n return new Error(String(obj));\n }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch {\n // do nothing\n }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n try {\n return fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch {\n // do nothing\n }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n try {\n return await fn();\n } catch (error) {\n if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n return;\n }\n throw error;\n }\n}\n\nexport type RetryOptions = {\n beforeRetry?: (error: unknown) => Promise<void>;\n handleError?: (error: unknown) => Promise<void>;\n retryCount?: number;\n retryLogger?: (message: string) => void;\n shouldRetry?: (error: unknown) => boolean;\n sleepMilliseconds?: number;\n updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n};\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n func: (failedCount: number) => T | Promise<T>,\n {\n beforeRetry,\n handleError,\n retryCount = 3,\n retryLogger,\n shouldRetry,\n sleepMilliseconds = 0,\n updateSleepMilliseconds,\n }: RetryOptions = {}\n): Promise<T> {\n let failedCount = 0;\n for (;;) {\n try {\n return await func(failedCount);\n } catch (error) {\n await handleError?.(error);\n failedCount++;\n if (failedCount >= retryCount) {\n throw error;\n }\n if (shouldRetry && !shouldRetry(error)) {\n throw error;\n }\n if (sleepMilliseconds > 0) {\n await sleep(sleepMilliseconds);\n }\n if (updateSleepMilliseconds) {\n sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n }\n retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n await beforeRetry?.(error);\n }\n }\n}\n"],"names":["errorify","obj","Error","JSON","stringify","_unused","String","ignoreError","fn","_unused2","ignoreEnoent","error","code","async","ignoreErrorAsync","_unused3","ignoreEnoentAsync","withRetry","func","beforeRetry","handleError","retryCount","retryLogger","shouldRetry","sleepMilliseconds","updateSleepMilliseconds","failedCount","_error$stack","sleep","stack"],"mappings":"mCAMO,SAASA,EAASC,GACvB,GAAIA,aAAeC,MAAO,OAAOD,EACjC,GAAmB,iBAARA,EAAkB,OAAO,IAAIC,MAAMD,GAC9C,IACE,OAAO,IAAIC,MAAMC,KAAKC,UAAUH,GAClC,CAAE,MAAAI,GACA,OAAO,IAAIH,MAAMI,OAAOL,GAC1B,CACF,CAEO,SAASM,EAAeC,GAC7B,IACE,OAAOA,GACT,CAAE,MAAAC,GACA,CAEJ,CAEO,SAASC,EAAgBF,GAC9B,IACE,OAAOA,GACT,CAAE,MAAOG,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,CAEOE,eAAeC,EAAoBN,GACxC,IACE,aAAaA,GACf,CAAE,MAAAO,GACA,CAEJ,CAEOF,eAAeG,EAAqBR,GACzC,IACE,aAAaA,GACf,CAAE,MAAOG,GACP,GAAqB,iBAAVA,GAAsBA,GAAS,SAAUA,GAAwB,WAAfA,EAAMC,KACjE,OAEF,MAAMD,CACR,CACF,CAsBOE,eAAeI,EACpBC,GACAC,YACEA,EAAWC,YACXA,EAAWC,WACXA,EAAa,EAACC,YACdA,EAAWC,YACXA,EAAWC,kBACXA,EAAoB,EAACC,wBACrBA,GACgB,IAElB,IAAIC,EAAc,EAClB,OACE,IACE,aAAaR,EAAKQ,EACpB,CAAE,MAAOf,GAAO,IAAAgB,EAGd,SAFiB,MAAXP,OAAW,EAAXA,EAAcT,IACpBe,IACIA,GAAeL,EACjB,MAAMV,EAER,GAAIY,IAAgBA,EAAYZ,GAC9B,MAAMA,EAEJa,EAAoB,SAChBI,EAAMJ,GAEVC,IACFD,EAAoBC,EAAwBD,IAEnC,MAAXF,GAAAA,EAAc,iBAAiBX,MACnCA,aAAiBT,MAAQ,SAAsB,OAAfyB,EAAIhB,EAAMkB,OAAKF,EAAI,IAAM,YACpC,MAAXR,OAAW,EAAXA,EAAcR,GACtB,CAEJ"}
package/dist/humanize.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";exports.humanizeNumber=function(t,{base:e=1e3,units:r=["K","M","B","T","P"]}={}){if(t<e)return t.toString();let n=-1;for(;t>=e&&n<r.length-1;)t/=e,n++;return t.toFixed(2)+(n>=0?r[n]:"")};
1
+ "use strict";exports.humanizeNumber=function(t,{base:e=1e3,units:r=["K","M","B","T","P"]}={}){var n;if(t<e)return t.toString();let u=-1;for(;t>=e&&u<r.length-1;)t/=e,u++;return t.toFixed(2)+(null!=(n=r[u])?n:"")};
2
2
  //# sourceMappingURL=humanize.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"humanize.cjs","sources":["../src/humanize.ts"],"sourcesContent":["export function humanizeNumber(value: number, { base = 1000, units = ['K', 'M', 'B', 'T', 'P'] } = {}): string {\n if (value < base) {\n return value.toString();\n }\n\n let unitIndex = -1;\n while (value >= base && unitIndex < units.length - 1) {\n value /= base;\n unitIndex++;\n }\n\n return value.toFixed(2) + (unitIndex >= 0 ? units[unitIndex] : '');\n}\n"],"names":["value","base","units","toString","unitIndex","length","toFixed"],"mappings":"oCAAO,SAAwBA,GAAeC,KAAEA,EAAO,IAAIC,MAAEA,EAAQ,CAAC,IAAK,IAAK,IAAK,IAAK,MAAS,IACjG,GAAIF,EAAQC,EACV,OAAOD,EAAMG,WAGf,IAAIC,GAAY,EAChB,KAAOJ,GAASC,GAAQG,EAAYF,EAAMG,OAAS,GACjDL,GAASC,EACTG,IAGF,OAAOJ,EAAMM,QAAQ,IAAMF,GAAa,EAAIF,EAAME,GAAa,GACjE"}
1
+ {"version":3,"file":"humanize.cjs","sources":["../src/humanize.ts"],"sourcesContent":["export function humanizeNumber(value: number, { base = 1000, units = ['K', 'M', 'B', 'T', 'P'] } = {}): string {\n if (value < base) {\n return value.toString();\n }\n\n let unitIndex = -1;\n while (value >= base && unitIndex < units.length - 1) {\n value /= base;\n unitIndex++;\n }\n\n return value.toFixed(2) + (units[unitIndex] ?? '');\n}\n"],"names":["value","base","units","_units$unitIndex","toString","unitIndex","length","toFixed"],"mappings":"oCAAO,SAAwBA,GAAeC,KAAEA,EAAO,IAAIC,MAAEA,EAAQ,CAAC,IAAK,IAAK,IAAK,IAAK,MAAS,IAAY,IAAAC,EAC7G,GAAIH,EAAQC,EACV,OAAOD,EAAMI,WAGf,IAAIC,GAAY,EAChB,KAAOL,GAASC,GAAQI,EAAYH,EAAMI,OAAS,GACjDN,GAASC,EACTI,IAGF,OAAOL,EAAMO,QAAQ,WAAEJ,EAAID,EAAMG,IAAUF,EAAI,GACjD"}
package/dist/humanize.js CHANGED
@@ -1,2 +1,2 @@
1
- function t(t,{base:e=1e3,units:n=["K","M","B","T","P"]}={}){if(t<e)return t.toString();let r=-1;for(;t>=e&&r<n.length-1;)t/=e,r++;return t.toFixed(2)+(r>=0?n[r]:"")}export{t as humanizeNumber};
1
+ function t(t,{base:e=1e3,units:n=["K","M","B","T","P"]}={}){var r;if(t<e)return t.toString();let i=-1;for(;t>=e&&i<n.length-1;)t/=e,i++;return t.toFixed(2)+(null!=(r=n[i])?r:"")}export{t as humanizeNumber};
2
2
  //# sourceMappingURL=humanize.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"humanize.js","sources":["../src/humanize.ts"],"sourcesContent":["export function humanizeNumber(value: number, { base = 1000, units = ['K', 'M', 'B', 'T', 'P'] } = {}): string {\n if (value < base) {\n return value.toString();\n }\n\n let unitIndex = -1;\n while (value >= base && unitIndex < units.length - 1) {\n value /= base;\n unitIndex++;\n }\n\n return value.toFixed(2) + (unitIndex >= 0 ? units[unitIndex] : '');\n}\n"],"names":["humanizeNumber","value","base","units","toString","unitIndex","length","toFixed"],"mappings":"AAAO,SAASA,EAAeC,GAAeC,KAAEA,EAAO,IAAIC,MAAEA,EAAQ,CAAC,IAAK,IAAK,IAAK,IAAK,MAAS,IACjG,GAAIF,EAAQC,EACV,OAAOD,EAAMG,WAGf,IAAIC,GAAY,EAChB,KAAOJ,GAASC,GAAQG,EAAYF,EAAMG,OAAS,GACjDL,GAASC,EACTG,IAGF,OAAOJ,EAAMM,QAAQ,IAAMF,GAAa,EAAIF,EAAME,GAAa,GACjE"}
1
+ {"version":3,"file":"humanize.js","sources":["../src/humanize.ts"],"sourcesContent":["export function humanizeNumber(value: number, { base = 1000, units = ['K', 'M', 'B', 'T', 'P'] } = {}): string {\n if (value < base) {\n return value.toString();\n }\n\n let unitIndex = -1;\n while (value >= base && unitIndex < units.length - 1) {\n value /= base;\n unitIndex++;\n }\n\n return value.toFixed(2) + (units[unitIndex] ?? '');\n}\n"],"names":["humanizeNumber","value","base","units","_units$unitIndex","toString","unitIndex","length","toFixed"],"mappings":"AAAO,SAASA,EAAeC,GAAeC,KAAEA,EAAO,IAAIC,MAAEA,EAAQ,CAAC,IAAK,IAAK,IAAK,IAAK,MAAS,IAAY,IAAAC,EAC7G,GAAIH,EAAQC,EACV,OAAOD,EAAMI,WAGf,IAAIC,GAAY,EAChB,KAAOL,GAASC,GAAQI,EAAYH,EAAMI,OAAS,GACjDN,GAASC,EACTI,IAGF,OAAOL,EAAMO,QAAQ,WAAEJ,EAAID,EAAMG,IAAUF,EAAI,GACjD"}
package/dist/mail.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"mail.cjs","sources":["../src/mail.ts"],"sourcesContent":["export interface MailData {\n from: string;\n subject: string;\n text: string;\n}\n\nclass MailTemplates {\n resetPassword(appName: string, resetUrl: string, expirationDuration?: string): MailData {\n return {\n from: 'no-reply@willbooster.dev',\n subject: 'パスワード再設定のご案内',\n text: `\n${appName} をご利用いただき誠にありがとうございます。\n\nお客様からパスワード再設定のリクエストを受け取りました。\n以下のURLをクリックして、新しいパスワードを設定してください。\n\n${resetUrl}\n${\n expirationDuration\n ? `\n上記のURLは発行から約${expirationDuration}で失効します。\n期限を過ぎてしまった場合や、URLが機能しない場合は、\n恐れ入りますが、再度パスワードを再設定してください。\n`\n : ''\n}\nなお、本メールアドレスは配信専用ですので、返信いただけません。\n\n引き続き ${appName} をよろしくお願い申し上げます。\n `.trim(),\n };\n }\n}\n\nexport const mailTemplates = new MailTemplates();\n"],"names":["mailTemplates","resetPassword","appName","resetUrl","expirationDuration","from","subject","text","trim"],"mappings":"mBAmCaA,EAAgB,IA7B7B,MACEC,aAAAA,CAAcC,EAAiBC,EAAkBC,GAC/C,MAAO,CACLC,KAAM,2BACNC,QAAS,eACTC,KAAM,KACVL,gGAKAC,MAEAC,EACI,iBACQA,sEAIR,+CAICF,0BACDM,OAEJ"}
1
+ {"version":3,"file":"mail.cjs","sources":["../src/mail.ts"],"sourcesContent":["export type MailData = {\n from: string;\n subject: string;\n text: string;\n};\n\nclass MailTemplates {\n resetPassword(appName: string, resetUrl: string, expirationDuration?: string): MailData {\n return {\n from: 'no-reply@willbooster.dev',\n subject: 'パスワード再設定のご案内',\n text: `\n${appName} をご利用いただき誠にありがとうございます。\n\nお客様からパスワード再設定のリクエストを受け取りました。\n以下のURLをクリックして、新しいパスワードを設定してください。\n\n${resetUrl}\n${\n expirationDuration\n ? `\n上記のURLは発行から約${expirationDuration}で失効します。\n期限を過ぎてしまった場合や、URLが機能しない場合は、\n恐れ入りますが、再度パスワードを再設定してください。\n`\n : ''\n}\nなお、本メールアドレスは配信専用ですので、返信いただけません。\n\n引き続き ${appName} をよろしくお願い申し上げます。\n `.trim(),\n };\n }\n}\n\nexport const mailTemplates = new MailTemplates();\n"],"names":["mailTemplates","resetPassword","appName","resetUrl","expirationDuration","from","subject","text","trim"],"mappings":"mBAmCaA,EAAgB,IA7B7B,MACEC,aAAAA,CAAcC,EAAiBC,EAAkBC,GAC/C,MAAO,CACLC,KAAM,2BACNC,QAAS,eACTC,KAAM,KACVL,gGAKAC,MAEAC,EACI,iBACQA,sEAIR,+CAICF,0BACDM,OAEJ"}
package/dist/mail.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- export interface MailData {
1
+ export type MailData = {
2
2
  from: string;
3
3
  subject: string;
4
4
  text: string;
5
- }
5
+ };
6
6
  declare class MailTemplates {
7
7
  resetPassword(appName: string, resetUrl: string, expirationDuration?: string): MailData;
8
8
  }
package/dist/mail.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"mail.js","sources":["../src/mail.ts"],"sourcesContent":["export interface MailData {\n from: string;\n subject: string;\n text: string;\n}\n\nclass MailTemplates {\n resetPassword(appName: string, resetUrl: string, expirationDuration?: string): MailData {\n return {\n from: 'no-reply@willbooster.dev',\n subject: 'パスワード再設定のご案内',\n text: `\n${appName} をご利用いただき誠にありがとうございます。\n\nお客様からパスワード再設定のリクエストを受け取りました。\n以下のURLをクリックして、新しいパスワードを設定してください。\n\n${resetUrl}\n${\n expirationDuration\n ? `\n上記のURLは発行から約${expirationDuration}で失効します。\n期限を過ぎてしまった場合や、URLが機能しない場合は、\n恐れ入りますが、再度パスワードを再設定してください。\n`\n : ''\n}\nなお、本メールアドレスは配信専用ですので、返信いただけません。\n\n引き続き ${appName} をよろしくお願い申し上げます。\n `.trim(),\n };\n }\n}\n\nexport const mailTemplates = new MailTemplates();\n"],"names":["mailTemplates","resetPassword","appName","resetUrl","expirationDuration","from","subject","text","trim"],"mappings":"MAmCaA,EAAgB,IA7B7B,MACEC,aAAAA,CAAcC,EAAiBC,EAAkBC,GAC/C,MAAO,CACLC,KAAM,2BACNC,QAAS,eACTC,KAAM,KACVL,gGAKAC,MAEAC,EACI,iBACQA,sEAIR,+CAICF,0BACDM,OAEJ"}
1
+ {"version":3,"file":"mail.js","sources":["../src/mail.ts"],"sourcesContent":["export type MailData = {\n from: string;\n subject: string;\n text: string;\n};\n\nclass MailTemplates {\n resetPassword(appName: string, resetUrl: string, expirationDuration?: string): MailData {\n return {\n from: 'no-reply@willbooster.dev',\n subject: 'パスワード再設定のご案内',\n text: `\n${appName} をご利用いただき誠にありがとうございます。\n\nお客様からパスワード再設定のリクエストを受け取りました。\n以下のURLをクリックして、新しいパスワードを設定してください。\n\n${resetUrl}\n${\n expirationDuration\n ? `\n上記のURLは発行から約${expirationDuration}で失効します。\n期限を過ぎてしまった場合や、URLが機能しない場合は、\n恐れ入りますが、再度パスワードを再設定してください。\n`\n : ''\n}\nなお、本メールアドレスは配信専用ですので、返信いただけません。\n\n引き続き ${appName} をよろしくお願い申し上げます。\n `.trim(),\n };\n }\n}\n\nexport const mailTemplates = new MailTemplates();\n"],"names":["mailTemplates","resetPassword","appName","resetUrl","expirationDuration","from","subject","text","trim"],"mappings":"MAmCaA,EAAgB,IA7B7B,MACEC,aAAAA,CAAcC,EAAiBC,EAAkBC,GAC/C,MAAO,CACLC,KAAM,2BACNC,QAAS,eACTC,KAAM,KACVL,gGAKAC,MAEAC,EACI,iBACQA,sEAIR,+CAICF,0BACDM,OAEJ"}
@@ -1 +1 @@
1
- {"version":3,"file":"shuffle.cjs","sources":["../src/shuffle.ts"],"sourcesContent":["export function shuffle<T>(array: T[]): T[] {\n for (let index = array.length - 1; index > 0; index--) {\n const index_ = Math.floor(Math.random() * (index + 1));\n [array[index], array[index_]] = [array[index_], array[index]];\n }\n return array;\n}\n"],"names":["array","index","length","index_","Math","floor","random"],"mappings":"6BAAO,SAAoBA,GACzB,IAAK,IAAIC,EAAQD,EAAME,OAAS,EAAGD,EAAQ,EAAGA,IAAS,CACrD,MAAME,EAASC,KAAKC,MAAMD,KAAKE,UAAYL,EAAQ,KAClDD,EAAMC,GAAQD,EAAMG,IAAW,CAACH,EAAMG,GAASH,EAAMC,GACxD,CACA,OAAOD,CACT"}
1
+ {"version":3,"file":"shuffle.cjs","sources":["../src/shuffle.ts"],"sourcesContent":["export function shuffle<T>(array: T[]): T[] {\n for (let index = array.length - 1; index > 0; index--) {\n const index_ = Math.floor(Math.random() * (index + 1));\n [array[index], array[index_]] = [array[index_], array[index]] as [T, T];\n }\n return array;\n}\n"],"names":["array","index","length","index_","Math","floor","random"],"mappings":"6BAAO,SAAoBA,GACzB,IAAK,IAAIC,EAAQD,EAAME,OAAS,EAAGD,EAAQ,EAAGA,IAAS,CACrD,MAAME,EAASC,KAAKC,MAAMD,KAAKE,UAAYL,EAAQ,KAClDD,EAAMC,GAAQD,EAAMG,IAAW,CAACH,EAAMG,GAASH,EAAMC,GACxD,CACA,OAAOD,CACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"shuffle.js","sources":["../src/shuffle.ts"],"sourcesContent":["export function shuffle<T>(array: T[]): T[] {\n for (let index = array.length - 1; index > 0; index--) {\n const index_ = Math.floor(Math.random() * (index + 1));\n [array[index], array[index_]] = [array[index_], array[index]];\n }\n return array;\n}\n"],"names":["shuffle","array","index","length","index_","Math","floor","random"],"mappings":"AAAO,SAASA,EAAWC,GACzB,IAAK,IAAIC,EAAQD,EAAME,OAAS,EAAGD,EAAQ,EAAGA,IAAS,CACrD,MAAME,EAASC,KAAKC,MAAMD,KAAKE,UAAYL,EAAQ,KAClDD,EAAMC,GAAQD,EAAMG,IAAW,CAACH,EAAMG,GAASH,EAAMC,GACxD,CACA,OAAOD,CACT"}
1
+ {"version":3,"file":"shuffle.js","sources":["../src/shuffle.ts"],"sourcesContent":["export function shuffle<T>(array: T[]): T[] {\n for (let index = array.length - 1; index > 0; index--) {\n const index_ = Math.floor(Math.random() * (index + 1));\n [array[index], array[index_]] = [array[index_], array[index]] as [T, T];\n }\n return array;\n}\n"],"names":["shuffle","array","index","length","index_","Math","floor","random"],"mappings":"AAAO,SAASA,EAAWC,GACzB,IAAK,IAAIC,EAAQD,EAAME,OAAS,EAAGD,EAAQ,EAAGA,IAAS,CACrD,MAAME,EAASC,KAAKC,MAAMD,KAAKE,UAAYL,EAAQ,KAClDD,EAAMC,GAAQD,EAAMG,IAAW,CAACH,EAAMG,GAASH,EAAMC,GACxD,CACA,OAAOD,CACT"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@willbooster/shared-lib",
3
- "version": "6.0.4",
3
+ "version": "6.0.6",
4
4
  "license": "Apache-2.0",
5
5
  "author": "WillBooster Inc.",
6
6
  "sideEffects": false,
@@ -40,10 +40,10 @@
40
40
  "devDependencies": {
41
41
  "@types/eslint": "9.6.1",
42
42
  "@types/micromatch": "4.0.9",
43
- "@willbooster/eslint-config-ts": "11.4.1",
43
+ "@willbooster/eslint-config-ts": "11.4.6",
44
44
  "@willbooster/prettier-config": "10.2.0",
45
- "build-ts": "15.0.17",
46
- "eslint": "9.32.0",
45
+ "build-ts": "16.0.3",
46
+ "eslint": "9.33.0",
47
47
  "eslint-config-flat-gitignore": "2.1.0",
48
48
  "eslint-config-prettier": "10.1.8",
49
49
  "eslint-import-resolver-typescript": "4.4.4",
@@ -51,15 +51,15 @@
51
51
  "eslint-plugin-sort-class-members": "1.21.0",
52
52
  "eslint-plugin-sort-destructure-keys": "2.0.0",
53
53
  "eslint-plugin-unicorn": "60.0.0",
54
- "eslint-plugin-unused-imports": "4.1.4",
55
- "globals": "16.3.0",
56
- "lint-staged": "16.1.5",
54
+ "eslint-plugin-unused-imports": "4.2.0",
55
+ "globals": "16.4.0",
56
+ "lint-staged": "16.1.6",
57
57
  "micromatch": "4.0.8",
58
58
  "prettier": "3.6.2",
59
- "prettier-plugin-java": "2.7.4",
59
+ "prettier-plugin-java": "2.7.5",
60
60
  "sort-package-json": "3.4.0",
61
61
  "typescript": "5.9.2",
62
- "typescript-eslint": "8.39.0",
62
+ "typescript-eslint": "8.43.0",
63
63
  "vitest": "3.2.4"
64
64
  },
65
65
  "publishConfig": {