@cyberskill/shared 1.47.0 → 1.48.0

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.
Files changed (133) hide show
  1. package/dist/_tsup-dts-rollup.d.cts +410 -30
  2. package/dist/_tsup-dts-rollup.d.ts +410 -30
  3. package/dist/cli.cjs +2136 -1
  4. package/dist/cli.d.cts +2 -1
  5. package/dist/cli.d.ts +2 -1
  6. package/dist/cli.js +2056 -1
  7. package/dist/configs/commitlint/base.cjs +64 -1
  8. package/dist/configs/commitlint/base.js +7 -1
  9. package/dist/configs/eslint/base.cjs +121 -1
  10. package/dist/configs/eslint/base.js +52 -1
  11. package/dist/configs/eslint/nestjs.cjs +155 -1
  12. package/dist/configs/eslint/nestjs.js +85 -1
  13. package/dist/configs/eslint/nextjs.cjs +155 -1
  14. package/dist/configs/eslint/nextjs.js +85 -1
  15. package/dist/configs/eslint/nodejs.cjs +156 -1
  16. package/dist/configs/eslint/nodejs.js +86 -1
  17. package/dist/configs/eslint/vite-react.cjs +159 -1
  18. package/dist/configs/eslint/vite-react.js +89 -1
  19. package/dist/configs/graphql/graphql-codegen.cjs +125 -1
  20. package/dist/configs/graphql/graphql-codegen.js +64 -1
  21. package/dist/configs/graphql/index.cjs +126 -1
  22. package/dist/configs/graphql/index.js +64 -1
  23. package/dist/configs/i18n/react/i18next.cjs +80 -1
  24. package/dist/configs/i18n/react/i18next.js +7 -1
  25. package/dist/configs/i18n/react/index.cjs +81 -1
  26. package/dist/configs/i18n/react/index.js +7 -1
  27. package/dist/configs/index.cjs +232 -1
  28. package/dist/configs/index.js +166 -1
  29. package/dist/configs/lint-staged/base.cjs +64 -1
  30. package/dist/configs/lint-staged/base.js +7 -1
  31. package/dist/configs/vitest/react/e2e.cjs +128 -1
  32. package/dist/configs/vitest/react/e2e.js +59 -1
  33. package/dist/configs/vitest/react/unit.cjs +305 -1
  34. package/dist/configs/vitest/react/unit.js +228 -1
  35. package/dist/configs/vitest/react/unit.setup.cjs +60 -1
  36. package/dist/configs/vitest/react/unit.setup.js +8 -1
  37. package/dist/constants/index.cjs +678 -1
  38. package/dist/constants/index.d.cts +31 -1
  39. package/dist/constants/index.d.ts +31 -1
  40. package/dist/constants/index.js +469 -1
  41. package/dist/constants/path.cjs +423 -1
  42. package/dist/constants/path.d.cts +31 -1
  43. package/dist/constants/path.d.ts +31 -1
  44. package/dist/constants/path.js +218 -1
  45. package/dist/constants/response-status.cjs +313 -1
  46. package/dist/constants/response-status.js +252 -1
  47. package/dist/index.cjs +4546 -1
  48. package/dist/index.d.cts +51 -7
  49. package/dist/index.d.ts +51 -7
  50. package/dist/index.js +4133 -1
  51. package/dist/nodejs/index.cjs +2138 -1
  52. package/dist/nodejs/index.js +2054 -1
  53. package/dist/nodejs/mongo.cjs +2137 -1
  54. package/dist/nodejs/mongo.js +2054 -1
  55. package/dist/react/apollo-client.cjs +177 -1
  56. package/dist/react/apollo-client.js +116 -1
  57. package/dist/react/index.cjs +990 -1
  58. package/dist/react/index.js +876 -1
  59. package/dist/react/loading.cjs +301 -1
  60. package/dist/react/loading.js +216 -1
  61. package/dist/react/next-intl.cjs +744 -1
  62. package/dist/react/next-intl.js +655 -1
  63. package/dist/react/storage.cjs +631 -1
  64. package/dist/react/storage.js +558 -1
  65. package/dist/typescript/api-response.cjs +48 -1
  66. package/dist/typescript/apollo.cjs +48 -1
  67. package/dist/typescript/command.cjs +68 -1
  68. package/dist/typescript/command.d.cts +4 -0
  69. package/dist/typescript/command.d.ts +4 -0
  70. package/dist/typescript/command.js +7 -1
  71. package/dist/typescript/config.cjs +48 -1
  72. package/dist/typescript/fs.cjs +48 -0
  73. package/dist/typescript/fs.d.cts +1 -0
  74. package/dist/typescript/fs.d.ts +1 -0
  75. package/dist/typescript/fs.js +0 -0
  76. package/dist/typescript/graphql-codegen.cjs +48 -1
  77. package/dist/typescript/index.cjs +175 -1
  78. package/dist/typescript/index.d.cts +5 -0
  79. package/dist/typescript/index.d.ts +5 -0
  80. package/dist/typescript/index.js +151 -1
  81. package/dist/typescript/loading.cjs +48 -1
  82. package/dist/typescript/log.cjs +48 -1
  83. package/dist/typescript/mongo.cjs +164 -1
  84. package/dist/typescript/mongo.js +145 -1
  85. package/dist/typescript/next-intl.cjs +48 -1
  86. package/dist/typescript/react.cjs +48 -1
  87. package/dist/typescript/serializer.cjs +48 -1
  88. package/dist/typescript/string.cjs +48 -1
  89. package/dist/utils/command.cjs +1387 -1
  90. package/dist/utils/command.d.cts +2 -0
  91. package/dist/utils/command.d.ts +2 -0
  92. package/dist/utils/command.js +1287 -1
  93. package/dist/utils/common.cjs +300 -1
  94. package/dist/utils/common.js +219 -1
  95. package/dist/utils/config.cjs +146 -1
  96. package/dist/utils/config.js +89 -1
  97. package/dist/utils/fs.cjs +118 -1
  98. package/dist/utils/fs.d.cts +4 -1
  99. package/dist/utils/fs.d.ts +4 -1
  100. package/dist/utils/fs.js +37 -1
  101. package/dist/utils/index-nodejs.cjs +1738 -1
  102. package/dist/utils/index-nodejs.d.cts +15 -6
  103. package/dist/utils/index-nodejs.d.ts +15 -6
  104. package/dist/utils/index-nodejs.js +1571 -1
  105. package/dist/utils/index.cjs +727 -1
  106. package/dist/utils/index.js +625 -1
  107. package/dist/utils/log.cjs +330 -1
  108. package/dist/utils/log.js +269 -1
  109. package/dist/utils/package.cjs +941 -0
  110. package/dist/utils/package.d.cts +3 -0
  111. package/dist/utils/package.d.ts +3 -0
  112. package/dist/utils/package.js +857 -0
  113. package/dist/utils/path.cjs +291 -0
  114. package/dist/utils/path.d.cts +6 -0
  115. package/dist/utils/path.d.ts +6 -0
  116. package/dist/utils/path.js +191 -0
  117. package/dist/utils/serializer.cjs +91 -1
  118. package/dist/utils/serializer.js +30 -1
  119. package/dist/utils/storage-client.cjs +349 -1
  120. package/dist/utils/storage-client.js +276 -1
  121. package/dist/utils/storage-server.cjs +636 -1
  122. package/dist/utils/storage-server.d.cts +1 -1
  123. package/dist/utils/storage-server.d.ts +1 -1
  124. package/dist/utils/storage-server.js +550 -1
  125. package/dist/utils/string.cjs +152 -1
  126. package/dist/utils/string.js +75 -1
  127. package/dist/utils/validate.cjs +90 -1
  128. package/dist/utils/validate.js +33 -1
  129. package/package.json +11 -11
  130. package/dist/utils/npm-package.cjs +0 -1
  131. package/dist/utils/npm-package.d.cts +0 -5
  132. package/dist/utils/npm-package.d.ts +0 -5
  133. package/dist/utils/npm-package.js +0 -1
package/dist/index.js CHANGED
@@ -1 +1,4133 @@
1
- function e(e,r){if(r==null||r>e.length)r=e.length;for(var t=0,n=new Array(r);t<r;t++)n[t]=e[t];return n}function r(e){if(Array.isArray(e))return e}function t(r){if(Array.isArray(r))return e(r)}function n(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function s(e,r,t,n,s,a,o){try{var i=e[a](o);var c=i.value}catch(e){t(e);return}if(i.done){r(c)}else{Promise.resolve(c).then(n,s)}}function a(e){return function(){var r=this,t=arguments;return new Promise(function(n,a){var o=e.apply(r,t);function i(e){s(o,n,a,i,c,"next",e)}function c(e){s(o,n,a,i,c,"throw",e)}i(undefined)})}}function o(e,r,t){r=f(r);return A(e,C()?Reflect.construct(r,t||[],f(e).constructor):r.apply(e,t))}function i(e,r){if(!(e instanceof r)){throw new TypeError("Cannot call a class as a function")}}function c(e,r){for(var t=0;t<r.length;t++){var n=r[t];n.enumerable=n.enumerable||false;n.configurable=true;if("value"in n)n.writable=true;Object.defineProperty(e,n.key,n)}}function u(e,r,t){if(r)c(e.prototype,r);if(t)c(e,t);return e}function l(e,r,t){if(r in e){Object.defineProperty(e,r,{value:t,enumerable:true,configurable:true,writable:true})}else{e[r]=t}return e}function f(e){f=Object.setPrototypeOf?Object.getPrototypeOf:function e(e){return e.__proto__||Object.getPrototypeOf(e)};return f(e)}function d(e,r){if(typeof r!=="function"&&r!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(r&&r.prototype,{constructor:{value:e,writable:true,configurable:true}});if(r)_(e,r)}function E(e,r){if(r!=null&&typeof Symbol!=="undefined"&&r[Symbol.hasInstance]){return!!r[Symbol.hasInstance](e)}else{return e instanceof r}}function h(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function v(e,r){var t=e==null?null:typeof Symbol!=="undefined"&&e[Symbol.iterator]||e["@@iterator"];if(t==null)return;var n=[];var s=true;var a=false;var o,i;try{for(t=t.call(e);!(s=(o=t.next()).done);s=true){n.push(o.value);if(r&&n.length===r)break}}catch(e){a=true;i=e}finally{try{if(!s&&t["return"]!=null)t["return"]()}finally{if(a)throw i}}return n}function m(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function g(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function p(e){for(var r=1;r<arguments.length;r++){var t=arguments[r]!=null?arguments[r]:{};var n=Object.keys(t);if(typeof Object.getOwnPropertySymbols==="function"){n=n.concat(Object.getOwnPropertySymbols(t).filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))}n.forEach(function(r){l(e,r,t[r])})}return e}function y(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);if(r){n=n.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})}t.push.apply(t,n)}return t}function S(e,r){r=r!=null?r:{};if(Object.getOwnPropertyDescriptors){Object.defineProperties(e,Object.getOwnPropertyDescriptors(r))}else{y(Object(r)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))})}return e}function O(e,r){if(e==null)return{};var t=R(e,r);var n,s;if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(s=0;s<a.length;s++){n=a[s];if(r.indexOf(n)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;t[n]=e[n]}}return t}function R(e,r){if(e==null)return{};var t={};var n=Object.keys(e);var s,a;for(a=0;a<n.length;a++){s=n[a];if(r.indexOf(s)>=0)continue;t[s]=e[s]}return t}function A(e,r){if(r&&(N(r)==="object"||typeof r==="function")){return r}return n(e)}function _(e,r){_=Object.setPrototypeOf||function e(e,r){e.__proto__=r;return e};return _(e,r)}function b(e,t){return r(e)||v(e,t)||w(e,t)||m()}function D(e){return t(e)||h(e)||w(e)||g()}function N(e){"@swc/helpers - typeof";return e&&typeof Symbol!=="undefined"&&e.constructor===Symbol?"symbol":typeof e}function w(r,t){if(!r)return;if(typeof r==="string")return e(r,t);var n=Object.prototype.toString.call(r).slice(8,-1);if(n==="Object"&&r.constructor)n=r.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return e(r,t)}function C(){try{var e=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(e){}return(C=function(){return!!e})()}function T(e,r){var t,n,s,a,o={label:0,sent:function(){if(s[0]&1)throw s[1];return s[1]},trys:[],ops:[]};return a={next:i(0),"throw":i(1),"return":i(2)},typeof Symbol==="function"&&(a[Symbol.iterator]=function(){return this}),a;function i(e){return function(r){return c([e,r])}}function c(a){if(t)throw new TypeError("Generator is already executing.");while(o)try{if(t=1,n&&(s=a[0]&2?n["return"]:a[0]?n["throw"]||((s=n["return"])&&s.call(n),0):n.next)&&!(s=s.call(n,a[1])).done)return s;if(n=0,s)a=[a[0]&2,s.value];switch(a[0]){case 0:case 1:s=a;break;case 4:o.label++;return{value:a[1],done:false};case 5:o.label++;n=a[1];a=[0];continue;case 7:a=o.ops.pop();o.trys.pop();continue;default:if(!(s=o.trys,s=s.length>0&&s[s.length-1])&&(a[0]===6||a[0]===2)){o=0;continue}if(a[0]===3&&(!s||a[1]>s[0]&&a[1]<s[3])){o.label=a[1];break}if(a[0]===6&&o.label<s[1]){o.label=s[1];s=a;break}if(s&&o.label<s[2]){o.label=s[2];o.ops.push(a);break}if(s[2])o.ops.pop();o.trys.pop();continue}a=r.call(e,o)}catch(e){a=[6,e];n=0}finally{t=s=0}if(a[0]&5)throw a[1];return{value:a[0]?a[1]:void 0,done:true}}}import I from"@antfu/eslint-config";function M(){for(var e=arguments.length,r=new Array(e),t=0;t<e;t++){r[t]=arguments[t]}var n=function(e,r){var t=p({},e);return Object.keys(r).forEach(function(e){if(!Object.hasOwnProperty.call(r,e))return;var s=r[e],a=t[e];Array.isArray(s)?t[e]=D(new Set(D(Array.isArray(a)?a:[]).concat(D(s)))):(typeof s==="undefined"?"undefined":N(s))=="object"&&s!==null&&!Array.isArray(s)?t[e]=n((typeof a==="undefined"?"undefined":N(a))=="object"&&a!==null&&!Array.isArray(a)?a:{},s):t[e]=s}),t};return r.flatMap(function(e){return Array.isArray(e)?e:[e]}).reduce(function(e,r){return n(e,r)},{})}import{dirname as P}from"node:path";import L from"node:process";import{fileURLToPath as G}from"node:url";var k=G(import.meta.url),U=P(k),x=L.env.INIT_CWD||L.cwd();var j={GRAPHQL_PARSE_FAILED:{CODE:"GRAPHQL_PARSE_FAILED",MESSAGE:"The GraphQL operation string contains a syntax error."},GRAPHQL_VALIDATION_FAILED:{CODE:"GRAPHQL_VALIDATION_FAILED",MESSAGE:"The GraphQL operation is not valid against the server's schema."},BAD_USER_INPUT:{CODE:"BAD_USER_INPUT",MESSAGE:"The GraphQL operation includes an invalid value for a field argument."},PERSISTED_QUERY_NOT_FOUND:{CODE:"PERSISTED_QUERY_NOT_FOUND",MESSAGE:"A client sent the hash of a query string to execute via automatic persisted queries, but the query was not in the APQ cache."},PERSISTED_QUERY_NOT_SUPPORTED:{CODE:"PERSISTED_QUERY_NOT_SUPPORTED",MESSAGE:"A client sent the hash of a query string to execute via automatic persisted queries, but the server has disabled APQ."},OPERATION_RESOLUTION_FAILURE:{CODE:"OPERATION_RESOLUTION_FAILURE",MESSAGE:"The request was parsed successfully and is valid against the server's schema, but the server couldn't resolve which operation to run. This occurs when a request containing multiple named operations doesn't specify which operation to run (i.e.,operationName), or if the named operation isn't included in the request."},CONTINUE:{CODE:100,MESSAGE:"Continue"},SWITCHING_PROTOCOLS:{CODE:101,MESSAGE:"Switching Protocols"},PROCESSING:{CODE:102,MESSAGE:"Processing"},OK:{CODE:200,MESSAGE:"OK"},CREATED:{CODE:201,MESSAGE:"Created"},ACCEPTED:{CODE:202,MESSAGE:"Accepted"},NON_AUTHORITATIVE_INFORMATION:{CODE:203,MESSAGE:"Non Authoritative Information"},NO_CONTENT:{CODE:204,MESSAGE:"No Content"},RESET_CONTENT:{CODE:205,MESSAGE:"Reset Content"},PARTIAL_CONTENT:{CODE:206,MESSAGE:"Partial Content"},MULTI_STATUS:{CODE:207,MESSAGE:"Multi-Status"},MULTIPLE_CHOICES:{CODE:300,MESSAGE:"Multiple Choices"},MOVED_PERMANENTLY:{CODE:301,MESSAGE:"Moved Permanently"},MOVED_TEMPORARILY:{CODE:302,MESSAGE:"Moved Temporarily"},SEE_OTHER:{CODE:303,MESSAGE:"See Other"},NOT_MODIFIED:{CODE:304,MESSAGE:"Not Modified"},USE_PROXY:{CODE:305,MESSAGE:"Use Proxy"},TEMPORARY_REDIRECT:{CODE:307,MESSAGE:"Temporary Redirect"},PERMANENT_REDIRECT:{CODE:308,MESSAGE:"Permanent Redirect"},BAD_REQUEST:{CODE:400,MESSAGE:"Bad Request"},UNAUTHORIZED:{CODE:401,MESSAGE:"Unauthorized"},PAYMENT_REQUIRED:{CODE:402,MESSAGE:"Payment Required"},FORBIDDEN:{CODE:403,MESSAGE:"Forbidden"},NOT_FOUND:{CODE:404,MESSAGE:"Not Found"},METHOD_NOT_ALLOWED:{CODE:405,MESSAGE:"Method Not Allowed"},NOT_ACCEPTABLE:{CODE:406,MESSAGE:"Not Acceptable"},PROXY_AUTHENTICATION_REQUIRED:{CODE:407,MESSAGE:"Proxy Authentication Required"},REQUEST_TIMEOUT:{CODE:408,MESSAGE:"Request Timeout"},CONFLICT:{CODE:409,MESSAGE:"Conflict"},GONE:{CODE:410,MESSAGE:"Gone"},LENGTH_REQUIRED:{CODE:411,MESSAGE:"Length Required"},PRECONDITION_FAILED:{CODE:412,MESSAGE:"Precondition Failed"},REQUEST_TOO_LONG:{CODE:413,MESSAGE:"Request Entity Too Large"},REQUEST_URI_TOO_LONG:{CODE:414,MESSAGE:"Request-URI Too Long"},UNSUPPORTED_MEDIA_TYPE:{CODE:415,MESSAGE:"Unsupported Media Type"},REQUESTED_RANGE_NOT_SATISFIABLE:{CODE:416,MESSAGE:"Requested Range Not Satisfiable"},EXPECTATION_FAILED:{CODE:417,MESSAGE:"Expectation Failed"},IM_A_TEAPOT:{CODE:418,MESSAGE:"I'm a teapot"},INSUFFICIENT_SPACE_ON_RESOURCE:{CODE:419,MESSAGE:"Insufficient Space on Resource"},METHOD_FAILURE:{CODE:420,MESSAGE:"Method Failure"},MISDIRECTED_REQUEST:{CODE:421,MESSAGE:"Misdirected Request"},UNPROCESSABLE_ENTITY:{CODE:422,MESSAGE:"Unprocessable Entity"},LOCKED:{CODE:423,MESSAGE:"Locked"},FAILED_DEPENDENCY:{CODE:424,MESSAGE:"Failed Dependency"},PRECONDITION_REQUIRED:{CODE:428,MESSAGE:"Precondition Required"},TOO_MANY_REQUESTS:{CODE:429,MESSAGE:"Too Many Requests"},REQUEST_HEADER_FIELDS_TOO_LARGE:{CODE:431,MESSAGE:"Request Header Fields Too Large"},UNAVAILABLE_FOR_LEGAL_REASONS:{CODE:451,MESSAGE:"Unavailable For Legal Reasons"},INTERNAL_SERVER_ERROR:{CODE:500,MESSAGE:"Internal Server Error"},NOT_IMPLEMENTED:{CODE:501,MESSAGE:"Not Implemented"},BAD_GATEWAY:{CODE:502,MESSAGE:"Bad Gateway"},SERVICE_UNAVAILABLE:{CODE:503,MESSAGE:"Service Unavailable"},GATEWAY_TIMEOUT:{CODE:504,MESSAGE:"Gateway Timeout"},HTTP_VERSION_NOT_SUPPORTED:{CODE:505,MESSAGE:"HTTP Version Not Supported"},INSUFFICIENT_STORAGE:{CODE:507,MESSAGE:"Insufficient Storage"},NETWORK_AUTHENTICATION_REQUIRED:{CODE:511,MESSAGE:"Network Authentication Required"}};import{format as F}from"date-fns";import{Document as q}from"mongoose";import Q from"mongoose-aggregate-paginate-v2";import V from"mongoose-paginate-v2";import{v4 as H}from"uuid";import B from"crypto-js";import Y from"slugify";var J=Y.default||Y;function W(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"",r=arguments.length>1?arguments[1]:void 0;var t=r||{},n=t.lower,s=n===void 0?!0:n,a=t.locale,o=a===void 0?"vi":a,i=O(t,["lower","locale"]);return J(e,p({lower:s,locale:o},i))}function $(e){var r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:4;return B.SHA256(e).toString(B.enc.Hex).slice(0,r)}var z={isEmpty:function e(e){return e==null?!0:Array.isArray(e)?e.length===0:(typeof e==="undefined"?"undefined":N(e))=="object"?E(e,Date)?!1:Object.keys(e).length===0:typeof e=="string"?e.trim().length===0:!1}};var K={getDateTime:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:new Date;return F(e,"yyyy-MM-dd HH:mm:ss.SSS")},createGenericFields:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=e.returnDateAs,t=r===void 0?"string":r;var n=t==="string"?K.getDateTime():new Date;return{id:H(),isDel:!1,createdAt:n,updatedAt:n}},applyPlugins:function e(e,r){r.filter(function(e){return typeof e=="function"}).forEach(function(r){return e.plugin(r)})},applyMiddlewares:function e(e,r){r.forEach(function(r){var t=r.method,n=r.pre,s=r.post;t&&n&&e.pre(t,n),t&&s&&e.post(t,s)})},createGenericSchema:function e(e){return new e.Schema({id:{type:String,default:H,required:!0,unique:!0},isDel:{type:Boolean,default:!1,required:!0}},{timestamps:!0})},createSchema:function e(e){var r=e.mongoose,t=e.schema,n=e.virtuals,s=n===void 0?[]:n,a=e.standalone,o=a===void 0?!1:a;var i=new r.Schema(t,{strict:!0});return s.forEach(function(e){var r=e.name,t=e.options,n=e.get;var s=i.virtual(r,t);n&&s.get(n)}),o||i.add(K.createGenericSchema(r)),i},createModel:function e(e){var r=e.mongoose,t=e.name,n=e.schema,s=e.pagination,a=s===void 0?!1:s,o=e.aggregate,i=o===void 0?!1:o,c=e.virtuals,u=c===void 0?[]:c,l=e.middlewares,f=l===void 0?[]:l;if(!t)throw new Error("Model name is required.");if(r.models[t])return r.models[t];var d=K.createSchema({mongoose:r,schema:n,virtuals:u});return K.applyPlugins(d,[a&&V,i&&Q]),K.applyMiddlewares(d,f),r.model(t,d)},createSlugQuery:function e(e){var r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=arguments.length>2?arguments[2]:void 0;return S(p({},r,t&&{id:{$ne:t}}),{$or:[{slug:e},{slugHistory:e}]})},validator:{isEmpty:function e(){return /*#__PURE__*/function(){var e=a(function(e){return T(this,function(r){return[2,!z.isEmpty(e)]})});return function(r){return e.apply(this,arguments)}}()},isUnique:function e(e){return /*#__PURE__*/function(){var r=a(function(r){var t;return T(this,function(n){switch(n.label){case 0:if(!Array.isArray(e)||e.length===0)throw new Error("Fields must be a non-empty array of strings.");t={$or:e.map(function(e){return l({},e,r)})};return[4,this.constructor.findOne(t)];case 1:return[2,!n.sent()]}})});return function(e){return r.apply(this,arguments)}}()},matchesRegex:function e(e){return /*#__PURE__*/function(){var r=a(function(r){return T(this,function(t){if(!Array.isArray(e)||e.some(function(e){return!E(e,RegExp)}))throw new Error("regexArray must be an array of valid RegExp objects.");return[2,e.every(function(e){return e.test(r)})]})});return function(e){return r.apply(this,arguments)}}()}}},X=/*#__PURE__*/function(){"use strict";function e(r,t){i(this,e);this.collection=r.collection(t)}u(e,[{key:"createOne",value:function e(e){var r=this;return a(function(){var t,n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);t=p({},K.createGenericFields(),e);n={success:!0,message:"Document created successfully"};return[4,r.collection.insertOne(t)];case 1:return[2,(n.result=a.sent(),n)];case 2:s=a.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"createMany",value:function e(e){var r=this;return a(function(){var t,n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);t=e.map(function(e){return p({},K.createGenericFields(),e)});return[4,r.collection.insertMany(t)];case 1:n=a.sent();return[2,n.insertedCount===0?{success:!1,message:"No documents were inserted"}:{success:!0,message:"".concat(n.insertedCount," documents created successfully"),result:n}];case 2:s=a.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"findOne",value:function e(e){var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,r.collection.findOne(e)];case 1:t=s.sent();return[2,t?{success:!0,message:"Document found",result:t}:{success:!1,message:"Document not found"}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"findAll",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);t={success:!0,message:"Documents retrieved successfully"};return[4,r.collection.find(e).toArray()];case 1:return[2,(t.result=s.sent(),t)];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"count",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);t={success:!0,message:"Count retrieved successfully"};return[4,r.collection.countDocuments(e)];case 1:return[2,(t.result=s.sent(),t)];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"updateOne",value:function e(e,r){var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);return[4,t.collection.updateOne(e,{$set:r})];case 1:n=a.sent();return[2,n.matchedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Document updated successfully",result:n}];case 2:s=a.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"updateMany",value:function e(e,r){var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);return[4,t.collection.updateMany(e,{$set:r})];case 1:n=a.sent();return[2,n.matchedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Documents updated successfully",result:n}];case 2:s=a.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"deleteOne",value:function e(e){var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,r.collection.deleteOne(e)];case 1:t=s.sent();return[2,t.deletedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Document deleted successfully",result:t}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"deleteMany",value:function e(e){var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,r.collection.deleteMany(e)];case 1:t=s.sent();return[2,t.deletedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Documents deleted successfully",result:t}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}}]);return e}(),Z=/*#__PURE__*/function(){"use strict";function e(r){i(this,e);this.model=r}u(e,[{key:"getModelName",value:function e(){return this.model.modelName}},{key:"findOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=arguments.length>3?arguments[3]:void 0;var s=this;return a(function(){var a,o,i;return T(this,function(c){switch(c.label){case 0:c.trys.push([0,2,,3]);a=s.model.findOne(e,r,t);n&&a.populate(n);return[4,a.exec()];case 1:o=c.sent();return[2,o?{success:!0,result:o}:{success:!1,message:"No ".concat(s.getModelName()," found."),code:j.NOT_FOUND.CODE}];case 2:i=c.sent();return[2,{success:!1,message:i.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findAll",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=arguments.length>3?arguments[3]:void 0;var s=this;return a(function(){var a,o,i;return T(this,function(c){switch(c.label){case 0:c.trys.push([0,2,,3]);a=s.model.find(e,r,t);n&&a.populate(n);o={success:!0};return[4,a.exec()];case 1:return[2,(o.result=c.sent(),o)];case 2:i=c.sent();return[2,{success:!1,message:i.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findPaging",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);n={success:!0};return[4,t.model.paginate(e,r)];case 1:return[2,(n.result=a.sent(),n)];case 2:s=a.sent();return[2,{success:!1,message:s.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findPagingAggregate",value:function e(e){var r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);n={success:!0};return[4,t.model.aggregatePaginate(t.model.aggregate(e),r)];case 1:return[2,(n.result=a.sent(),n)];case 2:s=a.sent();return[2,{success:!1,message:s.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"count",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);t={success:!0};return[4,r.model.countDocuments(e)];case 1:return[2,(t.result=s.sent(),t)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createOne",value:function e(e){var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);t={success:!0};return[4,r.model.create(e)];case 1:return[2,(t.result=s.sent(),t)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createMany",value:function e(e){var r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);n={success:!0};return[4,t.model.insertMany(e,r)];case 1:return[2,(n.result=a.sent().map(function(e){return E(e,q)?e.toObject():null}).filter(function(e){return e!==null}),n)];case 2:s=a.sent();return[2,{success:!1,message:s.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"updateOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return a(function(){var s,a;return T(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);return[4,n.model.findOneAndUpdate(e,r,p({new:!0},t)).exec()];case 1:s=o.sent();return[2,s?{success:!0,result:s}:{success:!1,message:"Failed to update ".concat(n.getModelName(),"."),code:j.NOT_FOUND.CODE}];case 2:a=o.sent();return[2,{success:!1,message:a.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"updateMany",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return a(function(){var s,a;return T(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);s={success:!0};return[4,n.model.updateMany(e,r,t).exec()];case 1:return[2,(s.result=o.sent(),s)];case 2:a=o.sent();return[2,{success:!1,message:a.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"deleteOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);return[4,t.model.findOneAndDelete(e,r).exec()];case 1:n=a.sent();return[2,n?{success:!0,result:n}:{success:!1,message:"No ".concat(t.getModelName()," found to delete."),code:j.NOT_FOUND.CODE}];case 2:s=a.sent();return[2,{success:!1,message:s.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"deleteMany",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var t=this;return a(function(){var n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);return[4,t.model.deleteMany(e,r).exec()];case 1:n=a.sent();return[2,n.deletedCount===0?{success:!1,message:"No documents found to delete.",code:j.NOT_FOUND.CODE}:{success:!0,result:n}];case 2:s=a.sent();return[2,{success:!1,message:s.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createShortId",value:function e(e){var r=arguments.length>1&&arguments[1]!==void 0?arguments[1]:4;var t=this;return a(function(){var n,s,a,o;return T(this,function(i){switch(i.label){case 0:n=new Set;s=0;i.label=1;case 1:if(!(s<10))return[3,5];a=$(e,s+r);o=!n.has(a);if(!o)return[3,3];n.add(a);return[4,t.model.exists({shortId:a})];case 2:o=!i.sent();i.label=3;case 3:if(o)return[2,{success:!0,result:a}];i.label=4;case 4:s++;return[3,1];case 5:return[2,{success:!1,message:"Failed to create a unique shortId",code:j.INTERNAL_SERVER_ERROR.CODE}]}})})()}},{key:"createSlug",value:function e(e,r){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return a(function(){var s,o,i,c,u,l,f,d,E,h,v;return T(this,function(m){switch(m.label){case 0:m.trys.push([0,8,,9]);s=r[e],o=/*#__PURE__*/function(){var e=a(function(e){var s,a,o;return T(this,function(i){switch(i.label){case 0:return[4,n.model.findOne(K.createSlugQuery(e,t,r.id))];case 1:s=i.sent();if(!s)return[2,e];a=1;i.label=2;case 2:o="".concat(e,"-").concat(a);return[4,n.model.findOne(K.createSlugQuery(o,t,r.id))];case 3:s=i.sent(),a++;i.label=4;case 4:if(s)return[3,2];i.label=5;case 5:return[2,o]}})});return function r(r){return e.apply(this,arguments)}}();if(!((typeof s==="undefined"?"undefined":N(s))=="object"))return[3,5];i={};c=[];for(u in s)c.push(u);l=0;m.label=1;case 1:if(!(l<c.length))return[3,4];f=c[l];d=W(s[f]);return[4,o(d)];case 2:i[f]=m.sent();m.label=3;case 3:l++;return[3,1];case 4:return[2,{success:!0,result:i}];case 5:E=W(s);h={success:!0};return[4,o(E)];case 6:return[2,(h.result=m.sent(),h)];case 7:return[3,9];case 8:v=m.sent();return[2,{success:!1,message:"Failed to create a unique slug: ".concat(v.message),code:j.INTERNAL_SERVER_ERROR.CODE}];case 9:return[2]}})})()}},{key:"aggregate",value:function e(e){var r=this;return a(function(){var t,n;return T(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);t={success:!0};return[4,r.model.aggregate(e)];case 1:return[2,(t.result=s.sent(),t)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:j.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}}]);return e}();import{ApolloClient as ee,ApolloLink as er,ApolloProvider as et,HttpLink as en,InMemoryCache as es,split as ea}from"@apollo/client";import{onError as eo}from"@apollo/client/link/error";import{GraphQLWsLink as ei}from"@apollo/client/link/subscriptions";import{getMainDefinition as ec}from"@apollo/client/utilities";import{createClient as eu}from"graphql-ws";import{jsx as el}from"react/jsx-runtime";function ef(e){var r=eo(function(e){var r=e.graphQLErrors,t=e.networkError;r===null||r===void 0?void 0:r.forEach(function(e){var r=e.message,t=e.locations,n=e.path;return console.error("[GraphQL error]: Message: ".concat(r,", Location: ").concat(t,", Path: ").concat(n))}),t&&console.error("[Network error]: ".concat(t))}),t=new en({uri:e===null||e===void 0?void 0:e.uri,credentials:"include"}),n=(e===null||e===void 0?void 0:e.wsUrl)?new ei(eu({url:e.wsUrl})):null,s=n?ea(function(e){var r=e.query;var t=ec(r);if(t.kind==="OperationDefinition"){var n=t.operation;return n==="subscription"}return!1},n,t):t,a=new er(function(e,r){return e.variables&&(e.variables=JSON.parse(JSON.stringify(e.variables),function(e,r){return e==="__typename"?void 0:r})),r(e)});return{errorLink:r,httpLink:t,wsLink:n,splitLink:s,cleanTypeName:a}}function ed(e){var r=e.isNextJS,t=e.options,n=e.children,s=e.client,a=e.provider,o=e.cache;var i=s!==null&&s!==void 0?s:ee;if(typeof i!="function")throw new TypeError("Invalid ApolloClient provided. Ensure CustomClient is a class.");var c=a||et,u=o||es,l=ef(t),f=l.cleanTypeName,d=l.errorLink,h=l.splitLink,v=new i(p({cache:E(u,es)?u:new es,link:er.from([f,d,h].filter(Boolean))},t));return r?el(c,{makeClient:function(){return v},children:n}):el(c,{client:v,children:n})}import eE from"classnames";import{createContext as eh,use as ev,useCallback as em,useMemo as eg,useState as ep}from"react";import ey from"./react/loading.module.scss";import{jsx as eS,jsxs as eO}from"react/jsx-runtime";var eR=eh(void 0);function eA(){var e=ev(eR);if(!e)throw new Error("useLoading must be used within a LoadingProvider");return e}function e_(e){var r=e.full,t=r===void 0?!1:r,n=e.block,s=n===void 0?!1:n,a=e.className,o=a===void 0?"":a,i=e.message,c=i===void 0?"Loading":i,u=O(e,["full","block","className","message"]);function l(){return eO("div",S(p({className:ey.container},u),{children:[eS("div",{className:ey.ring}),eS("div",{className:ey.ring}),eS("div",{className:ey.ring}),eS("div",{className:ey.ring}),c&&eS("div",{className:ey.message,children:c})]}))}return t?eS("div",{className:eE(ey.fullscreen,o),children:l()}):s?eS("div",{className:eE(ey.block,o),children:l()}):l()}function eb(e){var r=e.children;var t=b(ep(!1),2),n=t[0],s=t[1],a=b(ep(!1),2),o=a[0],i=a[1],c=em(function(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;s(!0),i(e)},[]),u=em(function(){s(!1),i(!1)},[]),l=eg(function(){return{isLoading:n,isGlobalLoading:o,showLoading:c,hideLoading:u}},[n,o,c,u]);return eS(eR,{value:l,children:n?eS(e_,{full:o}):r})}import{NextIntlClientProvider as eD,useTranslations as eN}from"next-intl";import{createContext as ew,use as eC,useMemo as eT}from"react";import{useCallback as eI,useEffect as eM,useState as eP}from"react";var eL={serialize:function(e){return JSON.stringify(e,function(e,r){return E(r,Date)?{__type:"Date",value:r.toISOString()}:r})},deserialize:function(e){return JSON.parse(e,function(e,r){return(r===null||r===void 0?void 0:r.__type)==="Date"?new Date(r.value):r})}};import eG from"localforage";var ek={get:function e(e){return a(function(){var r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,2,,3]);return[4,eG.getItem(e)];case 1:return[2,t.sent()];case 2:r=t.sent();return[2,(console.error('❌ [Storage:get] Error getting key "'.concat(e,'":'),r),null)];case 3:return[2]}})})()},set:function e(e,r){return a(function(){var t;return T(this,function(n){switch(n.label){case 0:n.trys.push([0,2,,3]);return[4,eG.setItem(e,r)];case 1:n.sent();return[3,3];case 2:t=n.sent();console.error('❌ [Storage:set] Error setting key "'.concat(e,'":'),t);return[3,3];case 3:return[2]}})})()},remove:function e(e){return a(function(){var r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,2,,3]);return[4,eG.removeItem(e)];case 1:t.sent();return[3,3];case 2:r=t.sent();console.error('❌ [Storage:remove] Error removing key "'.concat(e,'":'),r);return[3,3];case 3:return[2]}})})()},keys:function e(){return a(function(){var e,r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,2,,3]);return[4,eG.keys()];case 1:return[2,(e=t.sent())!==null&&e!==void 0?e:[]];case 2:r=t.sent();return[2,(console.error("❌ [Storage:keys] Error getting keys:",r),[])];case 3:return[2]}})})()}};function eU(e,r){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:eL;var n=b(eP(r),2),s=n[0],o=n[1],i=b(eP(!1),2),c=i[0],u=i[1];eM(function(){var n=!0;return a(function(){var s,a,i,c;return T(this,function(l){switch(l.label){case 0:l.trys.push([0,6,7,8]);return[4,ek.get(e)];case 1:s=l.sent();if(!n)return[3,5];if(!(s!==null))return[3,2];a=t.deserialize(s);o(a);return[3,5];case 2:if(!(r!==void 0))return[3,4];i=t.serialize(r);return[4,ek.set(e,i)];case 3:l.sent(),o(r);return[3,5];case 4:o(void 0);l.label=5;case 5:return[3,8];case 6:c=l.sent();console.error('Error loading value for key "'.concat(e,'":'),c),n&&o(r);return[3,8];case 7:n&&u(!0);return[7];case 8:return[2]}})})(),function(){n=!1,u(!1)}},[e,r,t]),eM(function(){if(!c)return;a(function(){var r,n;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,3,,4]);if(!(s!==void 0))return[3,2];r=t.serialize(s);return[4,ek.set(e,r)];case 1:a.sent();a.label=2;case 2:return[3,4];case 3:n=a.sent();console.error('Error saving value for key "'.concat(e,'":'),n);return[3,4];case 4:return[2]}})})()},[s,e,t,c]);var l=eI(function(e){o(function(r){return typeof e=="function"?e(r):e})},[]),f=eI(/*#__PURE__*/a(function(){var r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,2,,3]);return[4,ek.remove(e)];case 1:t.sent(),o(void 0);return[3,3];case 2:r=t.sent();console.error('Error removing key "'.concat(e,'":'),r);return[3,3];case 3:return[2]}})}),[e]);return{value:s,set:l,remove:f}}import{Fragment as ex,jsx as ej}from"react/jsx-runtime";var eF=ew(void 0);function eq(){var e=eC(eF);if(!e)throw new Error("useNextIntl must be used within a NextIntlProvider");return e}var eQ=eN;function eV(e){var r=function(r){var t;var n=eq(),s=n.currentLanguage,a=r.messages,o=r.languages,i="en",c=a[(s===null||s===void 0?void 0:s.value)||i],u=(t=o.find(function(e){return e.value===(s===null||s===void 0?void 0:s.value)}))===null||t===void 0?void 0:t.timezone;return a?ej(eD,{locale:(s===null||s===void 0?void 0:s.value)||i,messages:c,timeZone:u,children:ej(e,p({},r))}):(console.warn("Missing messages for language: ".concat((s===null||s===void 0?void 0:s.value)||i)),null)};return r.displayName="withNextIntl(".concat(e.displayName||e.name||"Component",")"),r}function eH(e){var r=e.children;return ej(ex,{children:r})}var eB=eV(eH);function eY(e){var r=e.children,t=e.languages,n=e.messages;var s;var a=eU("lang",(s=t===null||t===void 0?void 0:t[0])!==null&&s!==void 0?s:{}),o=a.value,i=a.set,c=eT(function(){return{languages:t,currentLanguage:o,setCurrentLanguage:i}},[t,i,o]);return ej(eF,{value:c,children:ej(eB,{languages:t,messages:n,children:r})})}var eJ=function(e){return e.Error="error",e.Warning="warning",e}(eJ||{});import{Collection as eW,Db as e$}from"mongodb";import{Document as ez,Model as eK}from"mongoose";var eX=/*#__PURE__*/function(e){"use strict";d(r,e);function r(){i(this,r);return o(this,r,arguments)}return r}(e$),eZ=/*#__PURE__*/function(e){"use strict";d(r,e);function r(){i(this,r);return o(this,r,arguments)}return r}(ez),e0=/*#__PURE__*/function(e){"use strict";d(r,e);function r(){i(this,r);return o(this,r,arguments)}return r}(eK),e2=/*#__PURE__*/function(e){"use strict";d(r,e);function r(){i(this,r);return o(this,r,arguments)}return r}(eW);import e1 from"boxen";import e3 from"chalk";import{exec as e4}from"node:child_process";import e5 from"node:process";import*as e8 from"node:util";import e6 from"node-persist";import e7 from"node:os";import e9 from"node:path";import re from"node:process";var rr=re.env.CYBERSKILL_STORAGE_DIR||e9.join(e7.homedir(),".cyberskill-storage");function rt(){return rn.apply(this,arguments)}function rn(){rn=a(function(){var e;return T(this,function(r){switch(r.label){case 0:e=e6.defaultInstance;if(e)return[3,2];return[4,e6.init({dir:rr,stringify:JSON.stringify,parse:JSON.parse,encoding:"utf8",logging:!1,forgiveParseErrors:!0})];case 1:e=r.sent();r.label=2;case 2:e;return[2]}})});return rn.apply(this,arguments)}var rs={get:function e(e){return a(function(){var r,t;return T(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,rt()];case 1:n.sent();return[4,e6.getItem(e)];case 2:return[2,(r=n.sent())!==null&&r!==void 0?r:null];case 3:t=n.sent();return[2,(console.error('❌ [Storage:get] Error getting key "'.concat(e,'":'),t),null)];case 4:return[2]}})})()},set:function e(e,r){return a(function(){var t;return T(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,rt()];case 1:n.sent();return[4,e6.setItem(e,r)];case 2:n.sent();return[3,4];case 3:t=n.sent();console.error('❌ [Storage:set] Error setting key "'.concat(e,'":'),t);return[3,4];case 4:return[2]}})})()},remove:function e(e){return a(function(){var r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,3,,4]);return[4,rt()];case 1:t.sent();return[4,e6.removeItem(e)];case 2:t.sent();return[3,4];case 3:r=t.sent();console.error('❌ [Storage:remove] Error removing key "'.concat(e,'":'),r);return[3,4];case 4:return[2]}})})()},keys:function e(){return a(function(){var e,r;return T(this,function(t){switch(t.label){case 0:t.trys.push([0,3,,4]);return[4,rt()];case 1:t.sent();return[4,e6.keys()];case 2:e=t.sent();return[2,Array.isArray(e)?e:(console.warn("⚠️ [Storage:keys] Invalid keys response:",e),[])];case 3:r=t.sent();return[2,(console.error("❌ [Storage:keys] Error getting keys:",r),[])];case 4:return[2]}})})()},getLogLink:function e(e){return a(function(){return T(this,function(r){try{return[2,"".concat(rr," (key: ").concat(e,")")]}catch(e){return[2,(console.error("❌ [Storage:getLogLink] Error getting log link:",e),null)]}return[2]})})()}};var ra=e5.env.DEBUG==="true",ro=e8.promisify(e4),ri=e3.gray,rc=e3.blue,ru=function(){return ri("[".concat(new Date().toLocaleTimeString(),"]"))};function rl(e){var r=e3[e];return typeof r=="function"?r:e3.green}function rf(e,r,t,n){var s=rl(r);console.log("".concat(ru()," ").concat(s("".concat(t," ").concat(e))," ").concat(n))}function rd(e,r){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=t.color,s=n===void 0?"green":n,a=t.padding,o=a===void 0?1:a,i=t.margin,c=i===void 0?1:i,u=t.borderStyle,l=u===void 0?"round":u,f=t.titleColor,d=f===void 0?"bold":f;var E=rl(s),h=rl(d);if(typeof r=="string"){console.log(e1(h(E("".concat(e,"\n").concat(r))),{padding:o,margin:c,borderStyle:l,borderColor:s}));return}Array.isArray(r)&&r.length&&(r.forEach(function(e){var r=e.file,t=e.position,n=e.rule,s=e.message;console.log("".concat(ru()," ").concat(E("File:")," ").concat(rc("".concat(r).concat(t?":".concat(t):"")))),n&&console.log(" ".concat(E("Rule:")," ").concat(E(n))),console.log(" ".concat(E("Message:")," ").concat(E(s)))}),console.log(e1(h(E("".concat(e,": ").concat(r.length))),{padding:o,margin:c,borderStyle:l,borderColor:s})),console.log(ri("─".repeat(40))))}var rE={success:function(e){return rf("SUCCESS","green","✔",e)},error:function(e){return rf("ERROR","red","✖",e)},warning:function(e){return rf("WARNING","yellow","⚠",e)},info:function(e){return rf("INFO","blue","ℹ",e)},printBoxedLog:rd},rh=function(e){return"error_list:".concat(e)};function rv(e){return rm.apply(this,arguments)}function rm(){rm=a(function(e){var r,t,n;return T(this,function(s){switch(s.label){case 0:if(e.length===0)return[2];r=Date.now(),t=rh(r);s.label=1;case 1:s.trys.push([1,3,,4]);return[4,rs.set(t,{errors:e,timestamp:r})];case 2:s.sent(),setTimeout(/*#__PURE__*/a(function(){var e;return T(this,function(r){switch(r.label){case 0:return[4,rs.getLogLink(t)];case 1:e=r.sent();e&&rE.info("\uD83D\uDCC2 Open the error list manually: ".concat(e));return[2]}})}),10);return[3,4];case 3:n=s.sent();rE.error("Failed to save errors: ".concat(n.message));return[3,4];case 4:return[2]}})});return rm.apply(this,arguments)}function rg(){return rp.apply(this,arguments)}function rp(){rp=a(function(){var e,r,t;return T(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,rs.keys()];case 1:e=n.sent(),r=Array.isArray(e)?e.filter(function(e){var r;return e===null||e===void 0?void 0:(r=e.startsWith)===null||r===void 0?void 0:r.call(e,"error_list:")}):[];return[4,Promise.all(r.map(/*#__PURE__*/function(){var e=a(function(e){var r;return T(this,function(t){switch(t.label){case 0:return[4,rs.get(e)];case 1:return[2,((r=t.sent())===null||r===void 0?void 0:r.errors)||[]]}})});return function(r){return e.apply(this,arguments)}}()))];case 2:return[2,n.sent().flat()];case 3:t=n.sent();return[2,(rE.error("Failed to retrieve stored errors: ".concat(t.message)),[])];case 4:return[2]}})});return rp.apply(this,arguments)}function ry(){return rS.apply(this,arguments)}function rS(){rS=a(function(){var e,r,t;return T(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,rs.keys()];case 1:e=n.sent(),r=Array.isArray(e)?e.filter(function(e){var r;return e===null||e===void 0?void 0:(r=e.startsWith)===null||r===void 0?void 0:r.call(e,"error_list:")}):[];return[4,Promise.all(r.map(function(e){return rs.remove(e)}))];case 2:n.sent();return[3,4];case 3:t=n.sent();rE.error("Failed to clear error lists: ".concat(t.message));return[3,4];case 4:return[2]}})});return rS.apply(this,arguments)}function rO(e){var r=[],t=[],n="",s=/^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/,a=/^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/,o=/^✖\s+(.*?)\s+\[(.*?)\]$/;e.split("\n").forEach(function(e){if(e.startsWith("/"))n=e.trim();else{var i=s.exec(e)||[],c=a.exec(e)||[],u=o.exec(e)||[];i.length&&n?r.push({file:n,position:"".concat(i[1],":").concat(i[2]),type:i[3]==="error"?"error":"warning",message:i[4].trim(),rule:i[5].trim()}):c.length?r.push({file:c[1],position:"".concat(c[2],":").concat(c[3]),type:c[4]==="error"?"error":"warning",message:c[5].trim()}):u.length?r.push({file:"commitlint",type:"error",message:u[1].trim(),rule:u[2].trim()}):t.push(e.trim())}}),r.length&&rv(r),t.length&&ra&&(rE.warning("Unmatched lines:"),t.forEach(function(e){return console.log(" ".concat(e))}))}function rR(e){try{var r=JSON.parse(e),t=[];r.forEach(function(e){var r=e.filePath,n=e.messages;n.forEach(function(e){var n=e.severity,s=e.line,a=e.column,o=e.ruleId,i=e.message;t.push({type:n===2?"error":"warning",file:r,position:"".concat(s,":").concat(a),rule:o,message:i})})}),t.length&&rv(t)}catch(r){rO(e)}}function rA(e){return r_.apply(this,arguments)}function r_(){r_=a(function(e){var r,t,n,s,a,o,i,c,u;var l=arguments;return T(this,function(f){switch(f.label){case 0:r=l.length>1&&l[1]!==void 0?l[1]:rR;t=new AbortController;e5.on("SIGINT",function(){rE.warning("Process interrupted. Terminating..."),t.abort(),e5.exit()});f.label=1;case 1:f.trys.push([1,3,,4]);return[4,ro(e,{maxBuffer:0x6400000,signal:t.signal})];case 2:n=f.sent(),s=n.stdout,a=n.stderr;[s,a].forEach(function(e){return e&&r(e)});return[3,4];case 3:o=f.sent();i=o.stdout,c=o.stderr,u=o.message;[i,c].forEach(function(e){return e&&r(e)}),!c&&!i&&rE.error("Command failed: ".concat(u));return[3,4];case 4:return[2]}})});return r_.apply(this,arguments)}import*as rb from"node:fs";var rD=function(e){return rb.existsSync(e)};import{GraphQLError as rN}from"graphql";function rw(e){var r=e.message,t=e.status,n=t===void 0?j.INTERNAL_SERVER_ERROR:t,s=e.type,a=s===void 0?"graphql":s;var o;var i=(o=r!==null&&r!==void 0?r:n.MESSAGE)!==null&&o!==void 0?o:"Internal server error";throw a==="graphql"?new rN(i,{extensions:{code:n.CODE}}):new Error(i)}import rC from"node-fetch";import rT from"node:fs";import rI from"node:path";var rM=24*60*60*1e3;function rP(e){return e?rI.join(x,"node_modules",e,"package.json"):rI.join(x,"package.json")}function rL(e){return rG.apply(this,arguments)}function rG(){rG=a(function(e){var r,t,n,s,a,o,i,c,u,l;var f=arguments;return T(this,function(d){switch(d.label){case 0:r=f.length>1&&f[1]!==void 0?f[1]:!1;t="npm_version:".concat(e),n="npm_metadata:".concat(e);return[4,rs.get(t)];case 1:s=d.sent();return[4,rs.get(n)];case 2:a=d.sent(),o=s&&Date.now()-s.timestamp<rM;if(!r&&o)return[2,s.version];i={};(a===null||a===void 0?void 0:a.etag)&&(i["If-None-Match"]=a.etag),(a===null||a===void 0?void 0:a.lastModified)&&(i["If-Modified-Since"]=a.lastModified);d.label=3;case 3:d.trys.push([3,8,,9]);return[4,rC("https://registry.npmjs.org/".concat(e,"/latest"),{headers:i})];case 4:c=d.sent();if(c.status===304&&s)return[2,s.version];if(!c.ok)throw new Error("Failed to fetch latest version: ".concat(c.statusText));return[4,c.json()];case 5:u=d.sent().version;return[4,rs.set(t,{version:u,timestamp:Date.now()})];case 6:d.sent();return[4,rs.set(n,{etag:c.headers.get("ETag")||void 0,lastModified:c.headers.get("Last-Modified")||void 0})];case 7:return[2,(d.sent(),u)];case 8:l=d.sent();if(rE.error("Error fetching latest version for ".concat(e,": ").concat(l.message)),s)return[2,(rE.warning("Falling back to cached version for ".concat(e,": ").concat(s.version)),s.version)];throw l;case 9:return[2]}})});return rG.apply(this,arguments)}function rk(e){return rU.apply(this,arguments)}function rU(){rU=a(function(e){var r,t,n,s,a;var o=arguments;return T(this,function(i){switch(i.label){case 0:r=o.length>1&&o[1]!==void 0?o[1]:!0;i.label=1;case 1:i.trys.push([1,3,,4]);t=rP(e);if(!rT.existsSync(t))return[2,(rE.info("".concat(e," is not installed.")),!0)];n=JSON.parse(rT.readFileSync(t,"utf-8")).version;return[4,rL(e,r)];case 2:s=i.sent();return[2,(rE.info("Installed version of ".concat(e,": ").concat(n)),rE.info("Latest version of ".concat(e,": ").concat(s)),n!==s)];case 3:a=i.sent();return[2,(rE.warning("Failed to check version for ".concat(e,": ").concat(a.message)),!0)];case 4:return[2]}})});return rU.apply(this,arguments)}function rx(e){return rj.apply(this,arguments)}function rj(){rj=a(function(e){var r,t,n,s;return T(this,function(a){switch(a.label){case 0:a.trys.push([0,4,,5]);return[4,rL(e,!0)];case 1:r=a.sent(),t=rP();if(!rT.existsSync(t)){rE.error("package.json not found. Cannot update ".concat(e));return[2]}n=JSON.parse(rT.readFileSync(t,"utf-8"));n.dependencies=S(p({},n.dependencies),l({},e,r)),rT.writeFileSync(t,JSON.stringify(n,null,2)),rE.info("Updated ".concat(e," to version ").concat(r));return[4,rq()];case 2:a.sent();return[4,rA("pnpm run lint:fix")];case 3:a.sent(),rE.success("".concat(e," updated successfully."));return[3,5];case 4:s=a.sent();throw rE.error("Failed to update ".concat(e,": ").concat(s.message)),s;case 5:return[2]}})});return rj.apply(this,arguments)}function rF(e,r){try{var t=rI.join(e,"package.json");return rT.existsSync(t)?JSON.parse(rT.readFileSync(t,"utf-8")).name===r:!1}catch(e){return rE.error("Error reading package.json: ".concat(e.message)),!1}}function rq(){return rQ.apply(this,arguments)}function rQ(){rQ=a(function(){var e,r,t,n,s,a,o,i,c,u,l;return T(this,function(f){switch(f.label){case 0:e=[{command:"pnpm install",message:"Standard installation"},{command:"pnpm install --legacy-peer-deps",message:"Attempting installation with --legacy-peer-deps"},{command:"pnpm install --force",message:"Attempting forced installation"}];r=true,t=false,n=undefined;f.label=1;case 1:f.trys.push([1,8,9,10]);s=e[Symbol.iterator]();f.label=2;case 2:if(!!(r=(a=s.next()).done))return[3,7];o=a.value,i=o.command,c=o.message;f.label=3;case 3:f.trys.push([3,5,,6]);rE.info("".concat(c,"..."));return[4,rA(i)];case 4:f.sent(),rE.success("Dependencies installed using: ".concat(i));return[2];case 5:u=f.sent();rE.warning("Failed with: ".concat(i)),rE.error("Error: ".concat(u.message));return[3,6];case 6:r=true;return[3,2];case 7:return[3,10];case 8:l=f.sent();t=true;n=l;return[3,10];case 9:try{if(!r&&s.return!=null){s.return()}}finally{if(t){throw n}}return[7];case 10:throw new Error("Failed to install dependencies after multiple attempts.")}})});return rQ.apply(this,arguments)}import rV from"unorm";function rH(e){try{return JSON.parse(e),!0}catch(e){return!1}}var rB={a:["\xe0","\xe1","ạ","ả","\xe3","\xe2","ầ","ấ","ậ","ẩ","ẫ","ă","ằ","ắ","ặ","ẳ","ẵ"],e:["\xe8","\xe9","ẹ","ẻ","ẽ","\xea","ề","ế","ệ","ể","ễ"],i:["\xec","\xed","ị","ỉ","ĩ"],o:["\xf2","\xf3","ọ","ỏ","\xf5","\xf4","ồ","ố","ộ","ổ","ỗ","ơ","ờ","ớ","ợ","ở","ỡ"],u:["\xf9","\xfa","ụ","ủ","ũ","ư","ừ","ứ","ự","ử","ữ"],y:["ỳ","\xfd","ỵ","ỷ","ỹ"],d:["đ"]},rY=Object.entries(rB).reduce(function(e,r){var t=b(r,2),n=t[0],s=t[1];return e[n.toUpperCase()]=s.map(function(e){return e.toUpperCase()}),e},{});function rJ(e){e=rV.nfkc(e);var r=p({},rB,rY);var t=true,n=false,s=undefined;try{for(var a=Object.entries(r)[Symbol.iterator](),o;!(t=(o=a.next()).done);t=true){var i=b(o.value,2),c=i[0],u=i[1];var l="[".concat(c).concat(u.join(""),"]"),f="(".concat([c].concat(D(u)).join("|"),")");e=e.replace(new RegExp(l,"g"),f)}}catch(e){n=true;s=e}finally{try{if(!t&&a.return!=null){a.return()}}finally{if(n){throw s}}}return e}function rW(e){return e.normalize("NFD").replace(RegExp("\\p{Diacritic}","gu"),"")}export{ed as ApolloProvider,e2 as C_Collection,eX as C_Db,eZ as C_Document,e0 as C_Model,eJ as E_ErrorType,e_ as Loading,eR as LoadingContext,eb as LoadingProvider,X as MongoController,Z as MongooseController,eF as NextIntlContext,eY as NextIntlProvider,U as PROJECT_ROOT,j as RESPONSE_STATUS,x as WORKING_DIRECTORY,Q as aggregatePaginate,ry as clearAllErrorLists,rE as commandLog,M as deepMerge,rA as executeCommand,rD as fileExists,$ as generateShortId,W as generateSlug,rL as getLatestPackageVersion,rg as getStoredErrorLists,rt as initNodePersist,rq as installDependencies,rF as isCurrentProject,rH as isJson,rk as isPackageOutdated,K as mongo,V as mongoosePaginate,rJ as regexSearchMapper,rW as removeAccent,rv as saveErrorListToStorage,eL as serializer,ek as storageClient,rr as storageDir,rs as storageServer,rw as throwResponse,rx as updatePackage,eA as useLoading,eq as useNextIntl,eU as useStorage,eQ as useTranslateNextIntl,z as validate,eV as withNextIntl};
1
+ // src/configs/index.ts
2
+ function _array_like_to_array(arr, len) {
3
+ if (len == null || len > arr.length) len = arr.length;
4
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
5
+ return arr2;
6
+ }
7
+ function _array_with_holes(arr) {
8
+ if (Array.isArray(arr)) return arr;
9
+ }
10
+ function _array_without_holes(arr) {
11
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
12
+ }
13
+ function _assert_this_initialized(self) {
14
+ if (self === void 0) {
15
+ throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
16
+ }
17
+ return self;
18
+ }
19
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
20
+ try {
21
+ var info = gen[key](arg);
22
+ var value = info.value;
23
+ } catch (error) {
24
+ reject(error);
25
+ return;
26
+ }
27
+ if (info.done) {
28
+ resolve(value);
29
+ } else {
30
+ Promise.resolve(value).then(_next, _throw);
31
+ }
32
+ }
33
+ function _async_to_generator(fn) {
34
+ return function() {
35
+ var self = this, args = arguments;
36
+ return new Promise(function(resolve, reject) {
37
+ var gen = fn.apply(self, args);
38
+ function _next(value) {
39
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
40
+ }
41
+ function _throw(err) {
42
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
43
+ }
44
+ _next(undefined);
45
+ });
46
+ };
47
+ }
48
+ function _call_super(_this, derived, args) {
49
+ derived = _get_prototype_of(derived);
50
+ return _possible_constructor_return(_this, _is_native_reflect_construct() ? Reflect.construct(derived, args || [], _get_prototype_of(_this).constructor) : derived.apply(_this, args));
51
+ }
52
+ function _class_call_check(instance, Constructor) {
53
+ if (!(instance instanceof Constructor)) {
54
+ throw new TypeError("Cannot call a class as a function");
55
+ }
56
+ }
57
+ function _defineProperties(target, props) {
58
+ for(var i = 0; i < props.length; i++){
59
+ var descriptor = props[i];
60
+ descriptor.enumerable = descriptor.enumerable || false;
61
+ descriptor.configurable = true;
62
+ if ("value" in descriptor) descriptor.writable = true;
63
+ Object.defineProperty(target, descriptor.key, descriptor);
64
+ }
65
+ }
66
+ function _create_class(Constructor, protoProps, staticProps) {
67
+ if (protoProps) _defineProperties(Constructor.prototype, protoProps);
68
+ if (staticProps) _defineProperties(Constructor, staticProps);
69
+ return Constructor;
70
+ }
71
+ function _define_property(obj, key, value) {
72
+ if (key in obj) {
73
+ Object.defineProperty(obj, key, {
74
+ value: value,
75
+ enumerable: true,
76
+ configurable: true,
77
+ writable: true
78
+ });
79
+ } else {
80
+ obj[key] = value;
81
+ }
82
+ return obj;
83
+ }
84
+ function _get_prototype_of(o) {
85
+ _get_prototype_of = Object.setPrototypeOf ? Object.getPrototypeOf : function getPrototypeOf(o) {
86
+ return o.__proto__ || Object.getPrototypeOf(o);
87
+ };
88
+ return _get_prototype_of(o);
89
+ }
90
+ function _inherits(subClass, superClass) {
91
+ if (typeof superClass !== "function" && superClass !== null) {
92
+ throw new TypeError("Super expression must either be null or a function");
93
+ }
94
+ subClass.prototype = Object.create(superClass && superClass.prototype, {
95
+ constructor: {
96
+ value: subClass,
97
+ writable: true,
98
+ configurable: true
99
+ }
100
+ });
101
+ if (superClass) _set_prototype_of(subClass, superClass);
102
+ }
103
+ function _instanceof(left, right) {
104
+ if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
105
+ return !!right[Symbol.hasInstance](left);
106
+ } else {
107
+ return left instanceof right;
108
+ }
109
+ }
110
+ function _iterable_to_array(iter) {
111
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
112
+ }
113
+ function _iterable_to_array_limit(arr, i) {
114
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
115
+ if (_i == null) return;
116
+ var _arr = [];
117
+ var _n = true;
118
+ var _d = false;
119
+ var _s, _e;
120
+ try {
121
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
122
+ _arr.push(_s.value);
123
+ if (i && _arr.length === i) break;
124
+ }
125
+ } catch (err) {
126
+ _d = true;
127
+ _e = err;
128
+ } finally{
129
+ try {
130
+ if (!_n && _i["return"] != null) _i["return"]();
131
+ } finally{
132
+ if (_d) throw _e;
133
+ }
134
+ }
135
+ return _arr;
136
+ }
137
+ function _non_iterable_rest() {
138
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
139
+ }
140
+ function _non_iterable_spread() {
141
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
142
+ }
143
+ function _object_spread(target) {
144
+ for(var i = 1; i < arguments.length; i++){
145
+ var source = arguments[i] != null ? arguments[i] : {};
146
+ var ownKeys = Object.keys(source);
147
+ if (typeof Object.getOwnPropertySymbols === "function") {
148
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
149
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
150
+ }));
151
+ }
152
+ ownKeys.forEach(function(key) {
153
+ _define_property(target, key, source[key]);
154
+ });
155
+ }
156
+ return target;
157
+ }
158
+ function ownKeys(object, enumerableOnly) {
159
+ var keys = Object.keys(object);
160
+ if (Object.getOwnPropertySymbols) {
161
+ var symbols = Object.getOwnPropertySymbols(object);
162
+ if (enumerableOnly) {
163
+ symbols = symbols.filter(function(sym) {
164
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
165
+ });
166
+ }
167
+ keys.push.apply(keys, symbols);
168
+ }
169
+ return keys;
170
+ }
171
+ function _object_spread_props(target, source) {
172
+ source = source != null ? source : {};
173
+ if (Object.getOwnPropertyDescriptors) {
174
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
175
+ } else {
176
+ ownKeys(Object(source)).forEach(function(key) {
177
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
178
+ });
179
+ }
180
+ return target;
181
+ }
182
+ function _object_without_properties(source, excluded) {
183
+ if (source == null) return {};
184
+ var target = _object_without_properties_loose(source, excluded);
185
+ var key, i;
186
+ if (Object.getOwnPropertySymbols) {
187
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
188
+ for(i = 0; i < sourceSymbolKeys.length; i++){
189
+ key = sourceSymbolKeys[i];
190
+ if (excluded.indexOf(key) >= 0) continue;
191
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
192
+ target[key] = source[key];
193
+ }
194
+ }
195
+ return target;
196
+ }
197
+ function _object_without_properties_loose(source, excluded) {
198
+ if (source == null) return {};
199
+ var target = {};
200
+ var sourceKeys = Object.keys(source);
201
+ var key, i;
202
+ for(i = 0; i < sourceKeys.length; i++){
203
+ key = sourceKeys[i];
204
+ if (excluded.indexOf(key) >= 0) continue;
205
+ target[key] = source[key];
206
+ }
207
+ return target;
208
+ }
209
+ function _possible_constructor_return(self, call) {
210
+ if (call && (_type_of(call) === "object" || typeof call === "function")) {
211
+ return call;
212
+ }
213
+ return _assert_this_initialized(self);
214
+ }
215
+ function _set_prototype_of(o, p) {
216
+ _set_prototype_of = Object.setPrototypeOf || function setPrototypeOf(o, p) {
217
+ o.__proto__ = p;
218
+ return o;
219
+ };
220
+ return _set_prototype_of(o, p);
221
+ }
222
+ function _sliced_to_array(arr, i) {
223
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
224
+ }
225
+ function _to_consumable_array(arr) {
226
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
227
+ }
228
+ function _type_of(obj) {
229
+ "@swc/helpers - typeof";
230
+ return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
231
+ }
232
+ function _unsupported_iterable_to_array(o, minLen) {
233
+ if (!o) return;
234
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
235
+ var n = Object.prototype.toString.call(o).slice(8, -1);
236
+ if (n === "Object" && o.constructor) n = o.constructor.name;
237
+ if (n === "Map" || n === "Set") return Array.from(n);
238
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
239
+ }
240
+ function _is_native_reflect_construct() {
241
+ try {
242
+ var result = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));
243
+ } catch (_) {}
244
+ return (_is_native_reflect_construct = function() {
245
+ return !!result;
246
+ })();
247
+ }
248
+ function _ts_generator(thisArg, body) {
249
+ var f, y, t, g, _ = {
250
+ label: 0,
251
+ sent: function() {
252
+ if (t[0] & 1) throw t[1];
253
+ return t[1];
254
+ },
255
+ trys: [],
256
+ ops: []
257
+ };
258
+ return g = {
259
+ next: verb(0),
260
+ "throw": verb(1),
261
+ "return": verb(2)
262
+ }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
263
+ return this;
264
+ }), g;
265
+ function verb(n) {
266
+ return function(v) {
267
+ return step([
268
+ n,
269
+ v
270
+ ]);
271
+ };
272
+ }
273
+ function step(op) {
274
+ if (f) throw new TypeError("Generator is already executing.");
275
+ while(_)try {
276
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
277
+ if (y = 0, t) op = [
278
+ op[0] & 2,
279
+ t.value
280
+ ];
281
+ switch(op[0]){
282
+ case 0:
283
+ case 1:
284
+ t = op;
285
+ break;
286
+ case 4:
287
+ _.label++;
288
+ return {
289
+ value: op[1],
290
+ done: false
291
+ };
292
+ case 5:
293
+ _.label++;
294
+ y = op[1];
295
+ op = [
296
+ 0
297
+ ];
298
+ continue;
299
+ case 7:
300
+ op = _.ops.pop();
301
+ _.trys.pop();
302
+ continue;
303
+ default:
304
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
305
+ _ = 0;
306
+ continue;
307
+ }
308
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
309
+ _.label = op[1];
310
+ break;
311
+ }
312
+ if (op[0] === 6 && _.label < t[1]) {
313
+ _.label = t[1];
314
+ t = op;
315
+ break;
316
+ }
317
+ if (t && _.label < t[2]) {
318
+ _.label = t[2];
319
+ _.ops.push(op);
320
+ break;
321
+ }
322
+ if (t[2]) _.ops.pop();
323
+ _.trys.pop();
324
+ continue;
325
+ }
326
+ op = body.call(thisArg, _);
327
+ } catch (e) {
328
+ op = [
329
+ 6,
330
+ e
331
+ ];
332
+ y = 0;
333
+ } finally{
334
+ f = t = 0;
335
+ }
336
+ if (op[0] & 5) throw op[1];
337
+ return {
338
+ value: op[0] ? op[1] : void 0,
339
+ done: true
340
+ };
341
+ }
342
+ }
343
+ import antfu from "@antfu/eslint-config";
344
+ // src/utils/config.ts
345
+ function deepMerge() {
346
+ for(var _len = arguments.length, configs = new Array(_len), _key = 0; _key < _len; _key++){
347
+ configs[_key] = arguments[_key];
348
+ }
349
+ var merge = function(target, source) {
350
+ var result = _object_spread({}, target);
351
+ Object.keys(source).forEach(function(key) {
352
+ if (!Object.hasOwnProperty.call(source, key)) {
353
+ return;
354
+ }
355
+ var sourceValue = source[key];
356
+ var targetValue = result[key];
357
+ if (Array.isArray(sourceValue)) {
358
+ result[key] = _to_consumable_array(/* @__PURE__ */ new Set(_to_consumable_array(Array.isArray(targetValue) ? targetValue : []).concat(_to_consumable_array(sourceValue))));
359
+ } else if ((typeof sourceValue === "undefined" ? "undefined" : _type_of(sourceValue)) === "object" && sourceValue !== null && !Array.isArray(sourceValue)) {
360
+ result[key] = merge((typeof targetValue === "undefined" ? "undefined" : _type_of(targetValue)) === "object" && targetValue !== null && !Array.isArray(targetValue) ? targetValue : {}, sourceValue);
361
+ } else {
362
+ result[key] = sourceValue;
363
+ }
364
+ });
365
+ return result;
366
+ };
367
+ return configs.flatMap(function(config) {
368
+ return Array.isArray(config) ? config : [
369
+ config
370
+ ];
371
+ }).reduce(function(acc, config) {
372
+ return merge(acc, config);
373
+ }, {});
374
+ }
375
+ // src/constants/path.ts
376
+ import process3 from "node:process";
377
+ import { fileURLToPath } from "node:url";
378
+ // src/utils/command.ts
379
+ import boxen from "boxen";
380
+ import chalk from "chalk";
381
+ import { exec } from "node:child_process";
382
+ import process2 from "node:process";
383
+ import * as util from "node:util";
384
+ // src/typescript/command.ts
385
+ var E_ErrorType = /* @__PURE__ */ function(E_ErrorType2) {
386
+ E_ErrorType2["Error"] = "error";
387
+ E_ErrorType2["Warning"] = "warning";
388
+ return E_ErrorType2;
389
+ }(E_ErrorType || {});
390
+ // src/utils/package.ts
391
+ import fetch from "node-fetch";
392
+ // src/utils/fs.ts
393
+ import * as fs from "node:fs";
394
+ var existsSync2 = function(filePath) {
395
+ return fs.existsSync(filePath);
396
+ };
397
+ function readFileSync2(filePath, options) {
398
+ var content = fs.readFileSync(filePath, "utf-8");
399
+ if (options === null || options === void 0 ? void 0 : options.asJson) {
400
+ try {
401
+ var parsed = JSON.parse(content);
402
+ if ((typeof parsed === "undefined" ? "undefined" : _type_of(parsed)) === "object" && parsed !== null) {
403
+ return parsed;
404
+ }
405
+ throw new Error("Parsed JSON is not an object or array");
406
+ } catch (e) {
407
+ throw new Error("Failed to parse JSON from file: ".concat(filePath));
408
+ }
409
+ }
410
+ return content;
411
+ }
412
+ function writeFileSync2(filePath, data) {
413
+ var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
414
+ var tmp = options.isJson, isJson2 = tmp === void 0 ? false : tmp;
415
+ var content = isJson2 && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
416
+ fs.writeFileSync(filePath, content, "utf-8");
417
+ }
418
+ function appendFileSync2(filePath, data) {
419
+ var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
420
+ var tmp = options.isJson, isJson2 = tmp === void 0 ? false : tmp;
421
+ var content = isJson2 && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
422
+ fs.appendFileSync(filePath, content, "utf-8");
423
+ }
424
+ // src/utils/path.ts
425
+ import { createRequire } from "node:module";
426
+ import * as path from "node:path";
427
+ function resolveCyberSkillPath() {
428
+ for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
429
+ urls[_key] = arguments[_key];
430
+ }
431
+ var _path;
432
+ return (_path = path).resolve.apply(_path, [
433
+ CYBERSKILL_DIRECTORY
434
+ ].concat(_to_consumable_array(urls)));
435
+ }
436
+ function resolveWorkingPath() {
437
+ for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
438
+ urls[_key] = arguments[_key];
439
+ }
440
+ var _path;
441
+ return (_path = path).resolve.apply(_path, [
442
+ WORKING_DIRECTORY
443
+ ].concat(_to_consumable_array(urls)));
444
+ }
445
+ function resolve2() {
446
+ for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
447
+ urls[_key] = arguments[_key];
448
+ }
449
+ var _path;
450
+ return (_path = path).resolve.apply(_path, _to_consumable_array(urls));
451
+ }
452
+ function dirname2(url) {
453
+ return path.dirname(url);
454
+ }
455
+ function require2() {
456
+ return createRequire(CYBERSKILL_DIRECTORY);
457
+ }
458
+ function join2() {
459
+ for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
460
+ urls[_key] = arguments[_key];
461
+ }
462
+ var _path;
463
+ return (_path = path).join.apply(_path, _to_consumable_array(urls));
464
+ }
465
+ // src/utils/storage-server.ts
466
+ import nodePersist from "node-persist";
467
+ import os from "node:os";
468
+ import path2 from "node:path";
469
+ import process from "node:process";
470
+ function getStorageDir() {
471
+ return process.env.CYBERSKILL_STORAGE_DIR || path2.join(os.homedir(), CYBERSKILL_STORAGE);
472
+ }
473
+ function initNodePersist() {
474
+ return _initNodePersist.apply(this, arguments);
475
+ }
476
+ function _initNodePersist() {
477
+ _initNodePersist = _async_to_generator(function() {
478
+ return _ts_generator(this, function(_state) {
479
+ switch(_state.label){
480
+ case 0:
481
+ if (!!nodePersist.defaultInstance) return [
482
+ 3,
483
+ 2
484
+ ];
485
+ return [
486
+ 4,
487
+ nodePersist.init({
488
+ dir: getStorageDir(),
489
+ stringify: JSON.stringify,
490
+ parse: JSON.parse,
491
+ encoding: "utf8",
492
+ logging: false,
493
+ forgiveParseErrors: true
494
+ })
495
+ ];
496
+ case 1:
497
+ _state.sent();
498
+ _state.label = 2;
499
+ case 2:
500
+ return [
501
+ 2
502
+ ];
503
+ }
504
+ });
505
+ });
506
+ return _initNodePersist.apply(this, arguments);
507
+ }
508
+ var storageServer = {
509
+ get: function get(key) {
510
+ return _async_to_generator(function() {
511
+ var result, error;
512
+ return _ts_generator(this, function(_state) {
513
+ switch(_state.label){
514
+ case 0:
515
+ _state.trys.push([
516
+ 0,
517
+ 3,
518
+ ,
519
+ 4
520
+ ]);
521
+ return [
522
+ 4,
523
+ initNodePersist()
524
+ ];
525
+ case 1:
526
+ _state.sent();
527
+ return [
528
+ 4,
529
+ nodePersist.getItem(key)
530
+ ];
531
+ case 2:
532
+ result = _state.sent();
533
+ return [
534
+ 2,
535
+ result !== null && result !== void 0 ? result : null
536
+ ];
537
+ case 3:
538
+ error = _state.sent();
539
+ console.error('❌ [Storage:get] Error getting key "'.concat(key, '":'), error);
540
+ return [
541
+ 2,
542
+ null
543
+ ];
544
+ case 4:
545
+ return [
546
+ 2
547
+ ];
548
+ }
549
+ });
550
+ })();
551
+ },
552
+ set: function set(key, value) {
553
+ return _async_to_generator(function() {
554
+ var error;
555
+ return _ts_generator(this, function(_state) {
556
+ switch(_state.label){
557
+ case 0:
558
+ _state.trys.push([
559
+ 0,
560
+ 3,
561
+ ,
562
+ 4
563
+ ]);
564
+ return [
565
+ 4,
566
+ initNodePersist()
567
+ ];
568
+ case 1:
569
+ _state.sent();
570
+ return [
571
+ 4,
572
+ nodePersist.setItem(key, value)
573
+ ];
574
+ case 2:
575
+ _state.sent();
576
+ return [
577
+ 3,
578
+ 4
579
+ ];
580
+ case 3:
581
+ error = _state.sent();
582
+ console.error('❌ [Storage:set] Error setting key "'.concat(key, '":'), error);
583
+ return [
584
+ 3,
585
+ 4
586
+ ];
587
+ case 4:
588
+ return [
589
+ 2
590
+ ];
591
+ }
592
+ });
593
+ })();
594
+ },
595
+ remove: function remove(key) {
596
+ return _async_to_generator(function() {
597
+ var error;
598
+ return _ts_generator(this, function(_state) {
599
+ switch(_state.label){
600
+ case 0:
601
+ _state.trys.push([
602
+ 0,
603
+ 3,
604
+ ,
605
+ 4
606
+ ]);
607
+ return [
608
+ 4,
609
+ initNodePersist()
610
+ ];
611
+ case 1:
612
+ _state.sent();
613
+ return [
614
+ 4,
615
+ nodePersist.removeItem(key)
616
+ ];
617
+ case 2:
618
+ _state.sent();
619
+ return [
620
+ 3,
621
+ 4
622
+ ];
623
+ case 3:
624
+ error = _state.sent();
625
+ console.error('❌ [Storage:remove] Error removing key "'.concat(key, '":'), error);
626
+ return [
627
+ 3,
628
+ 4
629
+ ];
630
+ case 4:
631
+ return [
632
+ 2
633
+ ];
634
+ }
635
+ });
636
+ })();
637
+ },
638
+ keys: function keys() {
639
+ return _async_to_generator(function() {
640
+ var keys, error;
641
+ return _ts_generator(this, function(_state) {
642
+ switch(_state.label){
643
+ case 0:
644
+ _state.trys.push([
645
+ 0,
646
+ 3,
647
+ ,
648
+ 4
649
+ ]);
650
+ return [
651
+ 4,
652
+ initNodePersist()
653
+ ];
654
+ case 1:
655
+ _state.sent();
656
+ return [
657
+ 4,
658
+ nodePersist.keys()
659
+ ];
660
+ case 2:
661
+ keys = _state.sent();
662
+ if (!Array.isArray(keys)) {
663
+ console.warn("⚠️ [Storage:keys] Invalid keys response:", keys);
664
+ return [
665
+ 2,
666
+ []
667
+ ];
668
+ }
669
+ return [
670
+ 2,
671
+ keys
672
+ ];
673
+ case 3:
674
+ error = _state.sent();
675
+ console.error("❌ [Storage:keys] Error getting keys:", error);
676
+ return [
677
+ 2,
678
+ []
679
+ ];
680
+ case 4:
681
+ return [
682
+ 2
683
+ ];
684
+ }
685
+ });
686
+ })();
687
+ },
688
+ getLogLink: function getLogLink(key) {
689
+ return _async_to_generator(function() {
690
+ var storagePath;
691
+ return _ts_generator(this, function(_state) {
692
+ try {
693
+ storagePath = getStorageDir();
694
+ return [
695
+ 2,
696
+ "".concat(storagePath, " (key: ").concat(key, ")")
697
+ ];
698
+ } catch (error) {
699
+ console.error("❌ [Storage:getLogLink] Error getting log link:", error);
700
+ return [
701
+ 2,
702
+ null
703
+ ];
704
+ }
705
+ return [
706
+ 2
707
+ ];
708
+ });
709
+ })();
710
+ }
711
+ };
712
+ // src/utils/package.ts
713
+ var CACHE_EXPIRATION_MS = 24 * 60 * 60 * 1e3;
714
+ function getPackageJson(packageName) {
715
+ var workingPackageJsonPath = join2(WORKING_DIRECTORY, PACKAGE_JSON);
716
+ if (existsSync2(workingPackageJsonPath)) {
717
+ try {
718
+ var pkg = readFileSync2(workingPackageJsonPath, {
719
+ asJson: true
720
+ });
721
+ if (pkg.name === packageName) {
722
+ return {
723
+ path: workingPackageJsonPath,
724
+ file: pkg
725
+ };
726
+ }
727
+ } catch (error) {
728
+ commandLog.warning("Failed to read local package.json: ".concat(error.message));
729
+ }
730
+ }
731
+ var externalPackageJsonPath = join2(WORKING_DIRECTORY, NODE_MODULES, packageName, PACKAGE_JSON);
732
+ if (existsSync2(externalPackageJsonPath)) {
733
+ try {
734
+ var pkg1 = readFileSync2(externalPackageJsonPath, {
735
+ asJson: true
736
+ });
737
+ if (pkg1.name === packageName) {
738
+ return {
739
+ path: externalPackageJsonPath,
740
+ file: pkg1
741
+ };
742
+ }
743
+ } catch (error) {
744
+ commandLog.warning("Failed to read node_modules package.json for ".concat(packageName, ": ").concat(error.message));
745
+ }
746
+ }
747
+ return false;
748
+ }
749
+ function getLatestPackageVersion(packageName) {
750
+ return _getLatestPackageVersion.apply(this, arguments);
751
+ }
752
+ function _getLatestPackageVersion() {
753
+ _getLatestPackageVersion = _async_to_generator(function(packageName) {
754
+ var forceRefresh, versionCacheKey, metadataCacheKey, cached, metadata, isCacheValid, headers, response, data, latestVersion, error;
755
+ var _arguments = arguments;
756
+ return _ts_generator(this, function(_state) {
757
+ switch(_state.label){
758
+ case 0:
759
+ forceRefresh = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : false;
760
+ versionCacheKey = "npm_version:".concat(packageName);
761
+ metadataCacheKey = "npm_metadata:".concat(packageName);
762
+ return [
763
+ 4,
764
+ storageServer.get(versionCacheKey)
765
+ ];
766
+ case 1:
767
+ cached = _state.sent();
768
+ return [
769
+ 4,
770
+ storageServer.get(metadataCacheKey)
771
+ ];
772
+ case 2:
773
+ metadata = _state.sent();
774
+ isCacheValid = cached && Date.now() - cached.timestamp < CACHE_EXPIRATION_MS;
775
+ if (!forceRefresh && isCacheValid) {
776
+ return [
777
+ 2,
778
+ cached.version
779
+ ];
780
+ }
781
+ headers = {};
782
+ if (metadata === null || metadata === void 0 ? void 0 : metadata.etag) {
783
+ headers["If-None-Match"] = metadata.etag;
784
+ }
785
+ if (metadata === null || metadata === void 0 ? void 0 : metadata.lastModified) {
786
+ headers["If-Modified-Since"] = metadata.lastModified;
787
+ }
788
+ _state.label = 3;
789
+ case 3:
790
+ _state.trys.push([
791
+ 3,
792
+ 8,
793
+ ,
794
+ 9
795
+ ]);
796
+ return [
797
+ 4,
798
+ fetch("https://registry.npmjs.org/".concat(packageName, "/latest"), {
799
+ headers: headers
800
+ })
801
+ ];
802
+ case 4:
803
+ response = _state.sent();
804
+ if (response.status === 304 && cached) {
805
+ return [
806
+ 2,
807
+ cached.version
808
+ ];
809
+ }
810
+ if (!response.ok) {
811
+ throw new Error("Failed to fetch latest version: ".concat(response.statusText));
812
+ }
813
+ return [
814
+ 4,
815
+ response.json()
816
+ ];
817
+ case 5:
818
+ data = _state.sent();
819
+ latestVersion = data.version;
820
+ return [
821
+ 4,
822
+ storageServer.set(versionCacheKey, {
823
+ version: latestVersion,
824
+ timestamp: Date.now()
825
+ })
826
+ ];
827
+ case 6:
828
+ _state.sent();
829
+ return [
830
+ 4,
831
+ storageServer.set(metadataCacheKey, {
832
+ etag: response.headers.get("ETag") || void 0,
833
+ lastModified: response.headers.get("Last-Modified") || void 0
834
+ })
835
+ ];
836
+ case 7:
837
+ _state.sent();
838
+ return [
839
+ 2,
840
+ latestVersion
841
+ ];
842
+ case 8:
843
+ error = _state.sent();
844
+ commandLog.error("Error fetching latest version for ".concat(packageName, ": ").concat(error.message));
845
+ if (cached) {
846
+ commandLog.warning("Falling back to cached version for ".concat(packageName, ": ").concat(cached.version));
847
+ return [
848
+ 2,
849
+ cached.version
850
+ ];
851
+ }
852
+ throw error;
853
+ case 9:
854
+ return [
855
+ 2
856
+ ];
857
+ }
858
+ });
859
+ });
860
+ return _getLatestPackageVersion.apply(this, arguments);
861
+ }
862
+ function checkPackage(packageName) {
863
+ return _checkPackage.apply(this, arguments);
864
+ }
865
+ function _checkPackage() {
866
+ _checkPackage = _async_to_generator(function(packageName) {
867
+ var result, packageFound, cyberskillPackageJsonPath, isCurrentProject, _tmp, error;
868
+ return _ts_generator(this, function(_state) {
869
+ switch(_state.label){
870
+ case 0:
871
+ result = {
872
+ isInstalled: false,
873
+ isCurrentProject: false,
874
+ installedPath: "",
875
+ installedVersion: "",
876
+ latestVersion: "",
877
+ file: {}
878
+ };
879
+ _state.label = 1;
880
+ case 1:
881
+ _state.trys.push([
882
+ 1,
883
+ 5,
884
+ ,
885
+ 6
886
+ ]);
887
+ packageFound = getPackageJson(packageName);
888
+ if (!packageFound) {
889
+ return [
890
+ 2,
891
+ result
892
+ ];
893
+ }
894
+ cyberskillPackageJsonPath = resolveCyberSkillPath(PACKAGE_JSON);
895
+ isCurrentProject = packageFound.path === cyberskillPackageJsonPath;
896
+ result.file = packageFound.file;
897
+ result.isInstalled = true;
898
+ result.installedPath = packageFound.path;
899
+ result.installedVersion = packageFound.file.version;
900
+ result.isCurrentProject = isCurrentProject;
901
+ if (!isCurrentProject) return [
902
+ 3,
903
+ 2
904
+ ];
905
+ _tmp = packageFound.file.version;
906
+ return [
907
+ 3,
908
+ 4
909
+ ];
910
+ case 2:
911
+ return [
912
+ 4,
913
+ getLatestPackageVersion(packageName, true)
914
+ ];
915
+ case 3:
916
+ _tmp = _state.sent();
917
+ _state.label = 4;
918
+ case 4:
919
+ result.latestVersion = _tmp;
920
+ return [
921
+ 2,
922
+ result
923
+ ];
924
+ case 5:
925
+ error = _state.sent();
926
+ commandLog.error('Error checking package "'.concat(packageName, '": ').concat(error.message));
927
+ return [
928
+ 2,
929
+ result
930
+ ];
931
+ case 6:
932
+ return [
933
+ 2
934
+ ];
935
+ }
936
+ });
937
+ });
938
+ return _checkPackage.apply(this, arguments);
939
+ }
940
+ // src/utils/command.ts
941
+ var DEBUG = process2.env.DEBUG === "true";
942
+ var execPromise = util.promisify(exec);
943
+ var gray = chalk.gray, blue = chalk.blue;
944
+ var getTimeStamp = function() {
945
+ return gray("[".concat(/* @__PURE__ */ new Date().toLocaleTimeString(), "]"));
946
+ };
947
+ function chalkKeyword(color) {
948
+ var chalkColor = chalk[color];
949
+ return typeof chalkColor === "function" ? chalkColor : chalk.green;
950
+ }
951
+ function printLog(type, color, icon, message) {
952
+ var chalkColor = chalkKeyword(color);
953
+ console.log("".concat(getTimeStamp(), " ").concat(chalkColor("".concat(icon, " ").concat(type)), " ").concat(message));
954
+ }
955
+ function printBoxedLog(title, content) {
956
+ var _ref = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, _ref_color = _ref.color, color = _ref_color === void 0 ? "green" : _ref_color, _ref_padding = _ref.padding, padding = _ref_padding === void 0 ? 1 : _ref_padding, _ref_margin = _ref.margin, margin = _ref_margin === void 0 ? 1 : _ref_margin, _ref_borderStyle = _ref.borderStyle, borderStyle = _ref_borderStyle === void 0 ? "round" : _ref_borderStyle, _ref_titleColor = _ref.titleColor, titleColor = _ref_titleColor === void 0 ? "bold" : _ref_titleColor;
957
+ var chalkColor = chalkKeyword(color);
958
+ var chalkTitleColor = chalkKeyword(titleColor);
959
+ if (typeof content === "string") {
960
+ console.log(boxen(chalkTitleColor(chalkColor("".concat(title, "\n").concat(content))), {
961
+ padding: padding,
962
+ margin: margin,
963
+ borderStyle: borderStyle,
964
+ borderColor: color
965
+ }));
966
+ return;
967
+ }
968
+ if (Array.isArray(content) && content.length) {
969
+ content.forEach(function(param) {
970
+ var file = param.file, position = param.position, rule = param.rule, message = param.message;
971
+ console.log("".concat(getTimeStamp(), " ").concat(chalkColor("File:"), " ").concat(blue("".concat(file).concat(position ? ":".concat(position) : ""))));
972
+ if (rule) console.log(" ".concat(chalkColor("Rule:"), " ").concat(chalkColor(rule)));
973
+ console.log(" ".concat(chalkColor("Message:"), " ").concat(chalkColor(message)));
974
+ });
975
+ console.log(boxen(chalkTitleColor(chalkColor("".concat(title, ": ").concat(content.length))), {
976
+ padding: padding,
977
+ margin: margin,
978
+ borderStyle: borderStyle,
979
+ borderColor: color
980
+ }));
981
+ console.log(gray("\u2500".repeat(40)));
982
+ }
983
+ }
984
+ var commandLog = {
985
+ success: function(message) {
986
+ return printLog("SUCCESS", "green", "\u2714", message);
987
+ },
988
+ error: function(message) {
989
+ return printLog("ERROR", "red", "\u2716", message);
990
+ },
991
+ warning: function(message) {
992
+ return printLog("WARNING", "yellow", "\u26A0", message);
993
+ },
994
+ info: function(message) {
995
+ return printLog("INFO", "blue", "\u2139", message);
996
+ },
997
+ printBoxedLog: printBoxedLog
998
+ };
999
+ var getErrorListKey = function(timestamp) {
1000
+ return "error_list:".concat(timestamp);
1001
+ };
1002
+ function saveErrorListToStorage(errorList) {
1003
+ return _saveErrorListToStorage.apply(this, arguments);
1004
+ }
1005
+ function _saveErrorListToStorage() {
1006
+ _saveErrorListToStorage = _async_to_generator(function(errorList) {
1007
+ var timestamp, key, error;
1008
+ return _ts_generator(this, function(_state) {
1009
+ switch(_state.label){
1010
+ case 0:
1011
+ if (errorList.length === 0) {
1012
+ return [
1013
+ 2
1014
+ ];
1015
+ }
1016
+ timestamp = Date.now();
1017
+ key = getErrorListKey(timestamp);
1018
+ _state.label = 1;
1019
+ case 1:
1020
+ _state.trys.push([
1021
+ 1,
1022
+ 3,
1023
+ ,
1024
+ 4
1025
+ ]);
1026
+ return [
1027
+ 4,
1028
+ storageServer.set(key, {
1029
+ errors: errorList,
1030
+ timestamp: timestamp
1031
+ })
1032
+ ];
1033
+ case 2:
1034
+ _state.sent();
1035
+ setTimeout(/*#__PURE__*/ _async_to_generator(function() {
1036
+ var logPath;
1037
+ return _ts_generator(this, function(_state) {
1038
+ switch(_state.label){
1039
+ case 0:
1040
+ return [
1041
+ 4,
1042
+ storageServer.getLogLink(key)
1043
+ ];
1044
+ case 1:
1045
+ logPath = _state.sent();
1046
+ if (logPath) {
1047
+ commandLog.info("\uD83D\uDCC2 Open the error list manually: ".concat(logPath));
1048
+ }
1049
+ return [
1050
+ 2
1051
+ ];
1052
+ }
1053
+ });
1054
+ }), 10);
1055
+ return [
1056
+ 3,
1057
+ 4
1058
+ ];
1059
+ case 3:
1060
+ error = _state.sent();
1061
+ commandLog.error("Failed to save errors: ".concat(error.message));
1062
+ return [
1063
+ 3,
1064
+ 4
1065
+ ];
1066
+ case 4:
1067
+ return [
1068
+ 2
1069
+ ];
1070
+ }
1071
+ });
1072
+ });
1073
+ return _saveErrorListToStorage.apply(this, arguments);
1074
+ }
1075
+ function getStoredErrorLists() {
1076
+ return _getStoredErrorLists.apply(this, arguments);
1077
+ }
1078
+ function _getStoredErrorLists() {
1079
+ _getStoredErrorLists = _async_to_generator(function() {
1080
+ var keys, errorKeys, allErrors, error;
1081
+ return _ts_generator(this, function(_state) {
1082
+ switch(_state.label){
1083
+ case 0:
1084
+ _state.trys.push([
1085
+ 0,
1086
+ 3,
1087
+ ,
1088
+ 4
1089
+ ]);
1090
+ return [
1091
+ 4,
1092
+ storageServer.keys()
1093
+ ];
1094
+ case 1:
1095
+ keys = _state.sent();
1096
+ errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
1097
+ var _key_startsWith;
1098
+ return key === null || key === void 0 ? void 0 : (_key_startsWith = key.startsWith) === null || _key_startsWith === void 0 ? void 0 : _key_startsWith.call(key, "error_list:");
1099
+ }) : [];
1100
+ return [
1101
+ 4,
1102
+ Promise.all(errorKeys.map(/*#__PURE__*/ function() {
1103
+ var _ref = _async_to_generator(function(key) {
1104
+ var entry;
1105
+ return _ts_generator(this, function(_state) {
1106
+ switch(_state.label){
1107
+ case 0:
1108
+ return [
1109
+ 4,
1110
+ storageServer.get(key)
1111
+ ];
1112
+ case 1:
1113
+ entry = _state.sent();
1114
+ return [
1115
+ 2,
1116
+ (entry === null || entry === void 0 ? void 0 : entry.errors) || []
1117
+ ];
1118
+ }
1119
+ });
1120
+ });
1121
+ return function(key) {
1122
+ return _ref.apply(this, arguments);
1123
+ };
1124
+ }()))
1125
+ ];
1126
+ case 2:
1127
+ allErrors = _state.sent();
1128
+ return [
1129
+ 2,
1130
+ allErrors.flat()
1131
+ ];
1132
+ case 3:
1133
+ error = _state.sent();
1134
+ commandLog.error("Failed to retrieve stored errors: ".concat(error.message));
1135
+ return [
1136
+ 2,
1137
+ []
1138
+ ];
1139
+ case 4:
1140
+ return [
1141
+ 2
1142
+ ];
1143
+ }
1144
+ });
1145
+ });
1146
+ return _getStoredErrorLists.apply(this, arguments);
1147
+ }
1148
+ function clearAllErrorLists() {
1149
+ return _clearAllErrorLists.apply(this, arguments);
1150
+ }
1151
+ function _clearAllErrorLists() {
1152
+ _clearAllErrorLists = _async_to_generator(function() {
1153
+ var keys, errorKeys, error;
1154
+ return _ts_generator(this, function(_state) {
1155
+ switch(_state.label){
1156
+ case 0:
1157
+ _state.trys.push([
1158
+ 0,
1159
+ 3,
1160
+ ,
1161
+ 4
1162
+ ]);
1163
+ return [
1164
+ 4,
1165
+ storageServer.keys()
1166
+ ];
1167
+ case 1:
1168
+ keys = _state.sent();
1169
+ errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
1170
+ var _key_startsWith;
1171
+ return key === null || key === void 0 ? void 0 : (_key_startsWith = key.startsWith) === null || _key_startsWith === void 0 ? void 0 : _key_startsWith.call(key, "error_list:");
1172
+ }) : [];
1173
+ return [
1174
+ 4,
1175
+ Promise.all(errorKeys.map(function(key) {
1176
+ return storageServer.remove(key);
1177
+ }))
1178
+ ];
1179
+ case 2:
1180
+ _state.sent();
1181
+ return [
1182
+ 3,
1183
+ 4
1184
+ ];
1185
+ case 3:
1186
+ error = _state.sent();
1187
+ commandLog.error("Failed to clear error lists: ".concat(error.message));
1188
+ return [
1189
+ 3,
1190
+ 4
1191
+ ];
1192
+ case 4:
1193
+ return [
1194
+ 2
1195
+ ];
1196
+ }
1197
+ });
1198
+ });
1199
+ return _clearAllErrorLists.apply(this, arguments);
1200
+ }
1201
+ function parseTextErrors(output) {
1202
+ var errorList = [];
1203
+ var unmatchedLines = [];
1204
+ var lastFilePath = "";
1205
+ var eslintErrorDetailsRegex = /^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/;
1206
+ var tsRegex = /^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/;
1207
+ var commitlintRegex = /^✖\s+(.*?)\s+\[(.*?)\]$/;
1208
+ output.split("\n").forEach(function(line) {
1209
+ if (line.startsWith("/")) {
1210
+ lastFilePath = line.trim();
1211
+ } else {
1212
+ var eslintMatch = eslintErrorDetailsRegex.exec(line) || [];
1213
+ var tsMatch = tsRegex.exec(line) || [];
1214
+ var commitlintMatch = commitlintRegex.exec(line) || [];
1215
+ if (eslintMatch.length && lastFilePath) {
1216
+ errorList.push({
1217
+ file: lastFilePath,
1218
+ position: "".concat(eslintMatch[1], ":").concat(eslintMatch[2]),
1219
+ type: eslintMatch[3] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1220
+ message: eslintMatch[4].trim(),
1221
+ rule: eslintMatch[5].trim()
1222
+ });
1223
+ } else if (tsMatch.length) {
1224
+ errorList.push({
1225
+ file: tsMatch[1],
1226
+ position: "".concat(tsMatch[2], ":").concat(tsMatch[3]),
1227
+ type: tsMatch[4] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1228
+ message: tsMatch[5].trim()
1229
+ });
1230
+ } else if (commitlintMatch.length) {
1231
+ errorList.push({
1232
+ file: "commitlint",
1233
+ type: "error" /* Error */ ,
1234
+ message: commitlintMatch[1].trim(),
1235
+ rule: commitlintMatch[2].trim()
1236
+ });
1237
+ } else {
1238
+ unmatchedLines.push(line.trim());
1239
+ }
1240
+ }
1241
+ });
1242
+ if (errorList.length) {
1243
+ saveErrorListToStorage(errorList);
1244
+ }
1245
+ if (unmatchedLines.length && DEBUG) {
1246
+ commandLog.warning("Unmatched lines:");
1247
+ unmatchedLines.forEach(function(line) {
1248
+ return console.log(" ".concat(line));
1249
+ });
1250
+ }
1251
+ }
1252
+ function parseCommandOutput(output) {
1253
+ try {
1254
+ var results = JSON.parse(output);
1255
+ var errorList = [];
1256
+ results.forEach(function(param) {
1257
+ var filePath = param.filePath, messages = param.messages;
1258
+ messages.forEach(function(param) {
1259
+ var severity = param.severity, line = param.line, column = param.column, ruleId = param.ruleId, message = param.message;
1260
+ errorList.push({
1261
+ type: severity === 2 ? "error" /* Error */ : "warning" /* Warning */ ,
1262
+ file: filePath,
1263
+ position: "".concat(line, ":").concat(column),
1264
+ rule: ruleId,
1265
+ message: message
1266
+ });
1267
+ });
1268
+ });
1269
+ if (errorList.length) {
1270
+ saveErrorListToStorage(errorList);
1271
+ }
1272
+ } catch (e) {
1273
+ parseTextErrors(output);
1274
+ }
1275
+ }
1276
+ function executeCommand(command) {
1277
+ return _executeCommand.apply(this, arguments);
1278
+ }
1279
+ function _executeCommand() {
1280
+ _executeCommand = _async_to_generator(function(command) {
1281
+ var parser, controller, _ref, stdout, stderr, error, stdout1, stderr1, message;
1282
+ var _arguments = arguments;
1283
+ return _ts_generator(this, function(_state) {
1284
+ switch(_state.label){
1285
+ case 0:
1286
+ parser = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : parseCommandOutput;
1287
+ controller = new AbortController();
1288
+ process2.on("SIGINT", function() {
1289
+ commandLog.warning("Process interrupted. Terminating...");
1290
+ controller.abort();
1291
+ process2.exit();
1292
+ });
1293
+ _state.label = 1;
1294
+ case 1:
1295
+ _state.trys.push([
1296
+ 1,
1297
+ 3,
1298
+ ,
1299
+ 4
1300
+ ]);
1301
+ return [
1302
+ 4,
1303
+ execPromise(command, {
1304
+ maxBuffer: 1024 * 1024 * 100,
1305
+ signal: controller.signal
1306
+ })
1307
+ ];
1308
+ case 2:
1309
+ _ref = _state.sent(), stdout = _ref.stdout, stderr = _ref.stderr;
1310
+ [
1311
+ stdout,
1312
+ stderr
1313
+ ].forEach(function(output) {
1314
+ return output && parser(output);
1315
+ });
1316
+ return [
1317
+ 3,
1318
+ 4
1319
+ ];
1320
+ case 3:
1321
+ error = _state.sent();
1322
+ stdout1 = error.stdout, stderr1 = error.stderr, message = error.message;
1323
+ [
1324
+ stdout1,
1325
+ stderr1
1326
+ ].forEach(function(output) {
1327
+ return output && parser(output);
1328
+ });
1329
+ if (!stderr1 && !stdout1) {
1330
+ commandLog.error("Command failed: ".concat(message));
1331
+ }
1332
+ return [
1333
+ 3,
1334
+ 4
1335
+ ];
1336
+ case 4:
1337
+ return [
1338
+ 2
1339
+ ];
1340
+ }
1341
+ });
1342
+ });
1343
+ return _executeCommand.apply(this, arguments);
1344
+ }
1345
+ var commandFormatter = {
1346
+ raw: function(cmd) {
1347
+ return {
1348
+ raw: true,
1349
+ cmd: cmd
1350
+ };
1351
+ },
1352
+ isRaw: function isRaw(cmd) {
1353
+ return (typeof cmd === "undefined" ? "undefined" : _type_of(cmd)) === "object" && cmd !== null && cmd.raw === true;
1354
+ },
1355
+ format: function format(command, context) {
1356
+ if (typeof command === "function") {
1357
+ return commandFormatter.formatCLI(command(context), context);
1358
+ }
1359
+ if (commandFormatter.isRaw(command)) {
1360
+ return command.cmd;
1361
+ }
1362
+ return commandFormatter.formatCLI(command, context);
1363
+ },
1364
+ formatCLI: function formatCLI(command, context) {
1365
+ if (context === null || context === void 0 ? void 0 : context.isRemote) {
1366
+ return "".concat(PNPM_DLX_CLI, " ").concat(CYBERSKILL_PACKAGE_NAME, " ").concat(command);
1367
+ }
1368
+ if (context === null || context === void 0 ? void 0 : context.isCurrentProject) {
1369
+ return "".concat(PNPM_EXEC_CLI, " ").concat(TSX_CLI, " src/cli.ts ").concat(command);
1370
+ }
1371
+ return "".concat(PNPM_EXEC_CLI, " ").concat(CYBERSKILL_CLI, " ").concat(command);
1372
+ }
1373
+ };
1374
+ function resolveCommands(input) {
1375
+ return _resolveCommands.apply(this, arguments);
1376
+ }
1377
+ function _resolveCommands() {
1378
+ _resolveCommands = _async_to_generator(function(input) {
1379
+ var context, _context_isRemote, isRemote, isCurrentProject, _tmp, ctx, commands;
1380
+ var _arguments = arguments;
1381
+ return _ts_generator(this, function(_state) {
1382
+ switch(_state.label){
1383
+ case 0:
1384
+ context = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : {};
1385
+ isRemote = (_context_isRemote = context === null || context === void 0 ? void 0 : context.isRemote) !== null && _context_isRemote !== void 0 ? _context_isRemote : false;
1386
+ if (!isRemote) return [
1387
+ 3,
1388
+ 1
1389
+ ];
1390
+ _tmp = false;
1391
+ return [
1392
+ 3,
1393
+ 3
1394
+ ];
1395
+ case 1:
1396
+ return [
1397
+ 4,
1398
+ checkPackage(CYBERSKILL_PACKAGE_NAME)
1399
+ ];
1400
+ case 2:
1401
+ _tmp = _state.sent().isCurrentProject;
1402
+ _state.label = 3;
1403
+ case 3:
1404
+ isCurrentProject = _tmp;
1405
+ ctx = {
1406
+ isRemote: isRemote,
1407
+ isCurrentProject: isCurrentProject
1408
+ };
1409
+ commands = typeof input === "function" ? input(ctx) : input;
1410
+ return [
1411
+ 2,
1412
+ Object.fromEntries(Object.entries(commands).map(function(param) {
1413
+ var _param = _sliced_to_array(param, 2), key = _param[0], cmd = _param[1];
1414
+ return [
1415
+ key,
1416
+ commandFormatter.format(cmd, ctx)
1417
+ ];
1418
+ }))
1419
+ ];
1420
+ }
1421
+ });
1422
+ });
1423
+ return _resolveCommands.apply(this, arguments);
1424
+ }
1425
+ // src/constants/path.ts
1426
+ var __filename2 = fileURLToPath(import.meta.url);
1427
+ var __dirname2 = dirname2(__filename2);
1428
+ var CYBERSKILL_DIRECTORY = resolve2(__dirname2, "../../");
1429
+ var WORKING_DIRECTORY = process3.env.INIT_CWD || process3.cwd();
1430
+ var CYBERSKILL_PACKAGE_NAME = "@cyberskill/shared";
1431
+ var CYBERSKILL_STORAGE = ".cyberskill-storage";
1432
+ var NODE_MODULES = "node_modules";
1433
+ var BUILD_DIRECTORY = "dist";
1434
+ var PACKAGE_JSON = "package.json";
1435
+ var PACKAGE_LOCK_JSON = "package-lock.json";
1436
+ var TSCONFIG_JSON = "tsconfig.json";
1437
+ var GIT_IGNORE = ".gitignore";
1438
+ var SIMPLE_GIT_HOOK_JSON = ".simple-git-hooks.json";
1439
+ var PNPM_LOCK_YAML = "pnpm-lock.yaml";
1440
+ var GIT_HOOK = ".git/hooks";
1441
+ var GIT_COMMIT_EDITMSG = ".git/COMMIT_EDITMSG";
1442
+ var CYBERSKILL_CLI = "cyberskill";
1443
+ var ESLINT_CLI = "eslint";
1444
+ var VITEST_CLI = "vitest";
1445
+ var COMMIT_LINT_CLI = "commitlint";
1446
+ var LINT_STAGED_CLI = "lint-staged";
1447
+ var RIMRAF_CLI = "rimraf";
1448
+ var TSC_CLI = "tsc";
1449
+ var TSX_CLI = "tsx";
1450
+ var GIT_CLI = "git";
1451
+ var PNPM_CLI = "pnpm";
1452
+ var PNPM_DLX_CLI = "pnpm dlx";
1453
+ var PNPM_EXEC_CLI = "pnpm exec";
1454
+ var SIMPLE_GIT_HOOK_CLI = "simple-git-hooks";
1455
+ var ESLINT_INSPECT_CLI = "@eslint/config-inspector";
1456
+ var NODE_MODULES_INSPECT_CLI = "node_modules-inspect";
1457
+ var PATH = {
1458
+ CYBERSKILL_DIRECTORY: CYBERSKILL_DIRECTORY,
1459
+ WORKING_DIRECTORY: WORKING_DIRECTORY,
1460
+ TS_CONFIG: resolveWorkingPath(TSCONFIG_JSON),
1461
+ GIT_IGNORE: resolveWorkingPath(GIT_IGNORE),
1462
+ GIT_HOOK: resolveWorkingPath(GIT_HOOK),
1463
+ GIT_COMMIT_MSG: resolveWorkingPath(GIT_COMMIT_EDITMSG),
1464
+ SIMPLE_GIT_HOOKS: resolveWorkingPath(SIMPLE_GIT_HOOK_JSON),
1465
+ PACKAGE_JSON: resolveWorkingPath(PACKAGE_JSON),
1466
+ PACKAGE_LOCK_JSON: resolveWorkingPath(PACKAGE_LOCK_JSON),
1467
+ PNPM_LOCK_YAML: resolveWorkingPath(PNPM_LOCK_YAML),
1468
+ NODE_MODULES: resolveWorkingPath(NODE_MODULES),
1469
+ CYBERSKILL: {
1470
+ LINT_STAGED_CONFIG: resolveCyberSkillPath("./configs/lint-staged/base.js"),
1471
+ COMMITLINT_CONFIG: resolveCyberSkillPath("./configs/commitlint/base.js"),
1472
+ UNIT_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/unit.js"),
1473
+ E2E_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/e2e.js")
1474
+ }
1475
+ };
1476
+ function HOOK(param) {
1477
+ var isCurrentProject = param.isCurrentProject;
1478
+ return _object_spread({
1479
+ "postinstall": "setup",
1480
+ "pre-commit": LINT_STAGED_CLI,
1481
+ "commit-msg": COMMIT_LINT_CLI
1482
+ }, isCurrentProject && {
1483
+ "pre-push": commandFormatter.raw("".concat(GIT_CLI, " pull"))
1484
+ });
1485
+ }
1486
+ var COMMAND = {
1487
+ SIMPLE_GIT_HOOKS: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(SIMPLE_GIT_HOOK_CLI)),
1488
+ ESLINT_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_INSPECT_CLI)),
1489
+ NODE_MODULES_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(NODE_MODULES_INSPECT_CLI)),
1490
+ RESET: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(RIMRAF_CLI, " ").concat(NODE_MODULES, " ").concat(PNPM_LOCK_YAML)),
1491
+ ESLINT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY)),
1492
+ ESLINT_FIX: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY, " --fix")),
1493
+ TYPESCRIPT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(TSC_CLI, " -p ").concat(PATH.TS_CONFIG, " --noEmit")),
1494
+ CYBERSKILL: {
1495
+ TEST_UNIT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.UNIT_TEST_CONFIG)),
1496
+ TEST_E2E: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.E2E_TEST_CONFIG)),
1497
+ COMMIT_LINT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(COMMIT_LINT_CLI, " --edit ").concat(PATH.GIT_COMMIT_MSG, " --config ").concat(PATH.CYBERSKILL.COMMITLINT_CONFIG)),
1498
+ LINT_STAGED: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(LINT_STAGED_CLI, " --config ").concat(PATH.CYBERSKILL.LINT_STAGED_CONFIG))
1499
+ },
1500
+ CONFIGURE_GIT_HOOK: commandFormatter.raw("".concat(GIT_CLI, " config core.hooksPath ").concat(PATH.GIT_HOOK)),
1501
+ BUILD: commandFormatter.raw("".concat(PNPM_CLI, " run build")),
1502
+ STAGE_BUILD_DIRECTORY: commandFormatter.raw("".concat(GIT_CLI, " add ").concat(BUILD_DIRECTORY)),
1503
+ PNPM_INSTALL_STANDARD: commandFormatter.raw("".concat(PNPM_CLI, " install")),
1504
+ PNPM_INSTALL_LEGACY: commandFormatter.raw("".concat(PNPM_CLI, " install --legacy-peer-deps")),
1505
+ PNPM_INSTALL_FORCE: commandFormatter.raw("".concat(PNPM_CLI, " install --force"))
1506
+ };
1507
+ // src/constants/response-status.ts
1508
+ var RESPONSE_STATUS = {
1509
+ GRAPHQL_PARSE_FAILED: {
1510
+ CODE: "GRAPHQL_PARSE_FAILED",
1511
+ MESSAGE: "The GraphQL operation string contains a syntax error."
1512
+ },
1513
+ GRAPHQL_VALIDATION_FAILED: {
1514
+ CODE: "GRAPHQL_VALIDATION_FAILED",
1515
+ MESSAGE: "The GraphQL operation is not valid against the server's schema."
1516
+ },
1517
+ BAD_USER_INPUT: {
1518
+ CODE: "BAD_USER_INPUT",
1519
+ MESSAGE: "The GraphQL operation includes an invalid value for a field argument."
1520
+ },
1521
+ PERSISTED_QUERY_NOT_FOUND: {
1522
+ CODE: "PERSISTED_QUERY_NOT_FOUND",
1523
+ MESSAGE: "A client sent the hash of a query string to execute via automatic persisted queries, but the query was not in the APQ cache."
1524
+ },
1525
+ PERSISTED_QUERY_NOT_SUPPORTED: {
1526
+ CODE: "PERSISTED_QUERY_NOT_SUPPORTED",
1527
+ MESSAGE: "A client sent the hash of a query string to execute via automatic persisted queries, but the server has disabled APQ."
1528
+ },
1529
+ OPERATION_RESOLUTION_FAILURE: {
1530
+ CODE: "OPERATION_RESOLUTION_FAILURE",
1531
+ MESSAGE: "The request was parsed successfully and is valid against the server's schema, but the server couldn't resolve which operation to run. This occurs when a request containing multiple named operations doesn't specify which operation to run (i.e.,operationName), or if the named operation isn't included in the request."
1532
+ },
1533
+ CONTINUE: {
1534
+ CODE: 100,
1535
+ MESSAGE: "Continue"
1536
+ },
1537
+ SWITCHING_PROTOCOLS: {
1538
+ CODE: 101,
1539
+ MESSAGE: "Switching Protocols"
1540
+ },
1541
+ PROCESSING: {
1542
+ CODE: 102,
1543
+ MESSAGE: "Processing"
1544
+ },
1545
+ OK: {
1546
+ CODE: 200,
1547
+ MESSAGE: "OK"
1548
+ },
1549
+ CREATED: {
1550
+ CODE: 201,
1551
+ MESSAGE: "Created"
1552
+ },
1553
+ ACCEPTED: {
1554
+ CODE: 202,
1555
+ MESSAGE: "Accepted"
1556
+ },
1557
+ NON_AUTHORITATIVE_INFORMATION: {
1558
+ CODE: 203,
1559
+ MESSAGE: "Non Authoritative Information"
1560
+ },
1561
+ NO_CONTENT: {
1562
+ CODE: 204,
1563
+ MESSAGE: "No Content"
1564
+ },
1565
+ RESET_CONTENT: {
1566
+ CODE: 205,
1567
+ MESSAGE: "Reset Content"
1568
+ },
1569
+ PARTIAL_CONTENT: {
1570
+ CODE: 206,
1571
+ MESSAGE: "Partial Content"
1572
+ },
1573
+ MULTI_STATUS: {
1574
+ CODE: 207,
1575
+ MESSAGE: "Multi-Status"
1576
+ },
1577
+ MULTIPLE_CHOICES: {
1578
+ CODE: 300,
1579
+ MESSAGE: "Multiple Choices"
1580
+ },
1581
+ MOVED_PERMANENTLY: {
1582
+ CODE: 301,
1583
+ MESSAGE: "Moved Permanently"
1584
+ },
1585
+ MOVED_TEMPORARILY: {
1586
+ CODE: 302,
1587
+ MESSAGE: "Moved Temporarily"
1588
+ },
1589
+ SEE_OTHER: {
1590
+ CODE: 303,
1591
+ MESSAGE: "See Other"
1592
+ },
1593
+ NOT_MODIFIED: {
1594
+ CODE: 304,
1595
+ MESSAGE: "Not Modified"
1596
+ },
1597
+ USE_PROXY: {
1598
+ CODE: 305,
1599
+ MESSAGE: "Use Proxy"
1600
+ },
1601
+ TEMPORARY_REDIRECT: {
1602
+ CODE: 307,
1603
+ MESSAGE: "Temporary Redirect"
1604
+ },
1605
+ PERMANENT_REDIRECT: {
1606
+ CODE: 308,
1607
+ MESSAGE: "Permanent Redirect"
1608
+ },
1609
+ BAD_REQUEST: {
1610
+ CODE: 400,
1611
+ MESSAGE: "Bad Request"
1612
+ },
1613
+ UNAUTHORIZED: {
1614
+ CODE: 401,
1615
+ MESSAGE: "Unauthorized"
1616
+ },
1617
+ PAYMENT_REQUIRED: {
1618
+ CODE: 402,
1619
+ MESSAGE: "Payment Required"
1620
+ },
1621
+ FORBIDDEN: {
1622
+ CODE: 403,
1623
+ MESSAGE: "Forbidden"
1624
+ },
1625
+ NOT_FOUND: {
1626
+ CODE: 404,
1627
+ MESSAGE: "Not Found"
1628
+ },
1629
+ METHOD_NOT_ALLOWED: {
1630
+ CODE: 405,
1631
+ MESSAGE: "Method Not Allowed"
1632
+ },
1633
+ NOT_ACCEPTABLE: {
1634
+ CODE: 406,
1635
+ MESSAGE: "Not Acceptable"
1636
+ },
1637
+ PROXY_AUTHENTICATION_REQUIRED: {
1638
+ CODE: 407,
1639
+ MESSAGE: "Proxy Authentication Required"
1640
+ },
1641
+ REQUEST_TIMEOUT: {
1642
+ CODE: 408,
1643
+ MESSAGE: "Request Timeout"
1644
+ },
1645
+ CONFLICT: {
1646
+ CODE: 409,
1647
+ MESSAGE: "Conflict"
1648
+ },
1649
+ GONE: {
1650
+ CODE: 410,
1651
+ MESSAGE: "Gone"
1652
+ },
1653
+ LENGTH_REQUIRED: {
1654
+ CODE: 411,
1655
+ MESSAGE: "Length Required"
1656
+ },
1657
+ PRECONDITION_FAILED: {
1658
+ CODE: 412,
1659
+ MESSAGE: "Precondition Failed"
1660
+ },
1661
+ REQUEST_TOO_LONG: {
1662
+ CODE: 413,
1663
+ MESSAGE: "Request Entity Too Large"
1664
+ },
1665
+ REQUEST_URI_TOO_LONG: {
1666
+ CODE: 414,
1667
+ MESSAGE: "Request-URI Too Long"
1668
+ },
1669
+ UNSUPPORTED_MEDIA_TYPE: {
1670
+ CODE: 415,
1671
+ MESSAGE: "Unsupported Media Type"
1672
+ },
1673
+ REQUESTED_RANGE_NOT_SATISFIABLE: {
1674
+ CODE: 416,
1675
+ MESSAGE: "Requested Range Not Satisfiable"
1676
+ },
1677
+ EXPECTATION_FAILED: {
1678
+ CODE: 417,
1679
+ MESSAGE: "Expectation Failed"
1680
+ },
1681
+ IM_A_TEAPOT: {
1682
+ CODE: 418,
1683
+ MESSAGE: "I'm a teapot"
1684
+ },
1685
+ INSUFFICIENT_SPACE_ON_RESOURCE: {
1686
+ CODE: 419,
1687
+ MESSAGE: "Insufficient Space on Resource"
1688
+ },
1689
+ METHOD_FAILURE: {
1690
+ CODE: 420,
1691
+ MESSAGE: "Method Failure"
1692
+ },
1693
+ MISDIRECTED_REQUEST: {
1694
+ CODE: 421,
1695
+ MESSAGE: "Misdirected Request"
1696
+ },
1697
+ UNPROCESSABLE_ENTITY: {
1698
+ CODE: 422,
1699
+ MESSAGE: "Unprocessable Entity"
1700
+ },
1701
+ LOCKED: {
1702
+ CODE: 423,
1703
+ MESSAGE: "Locked"
1704
+ },
1705
+ FAILED_DEPENDENCY: {
1706
+ CODE: 424,
1707
+ MESSAGE: "Failed Dependency"
1708
+ },
1709
+ PRECONDITION_REQUIRED: {
1710
+ CODE: 428,
1711
+ MESSAGE: "Precondition Required"
1712
+ },
1713
+ TOO_MANY_REQUESTS: {
1714
+ CODE: 429,
1715
+ MESSAGE: "Too Many Requests"
1716
+ },
1717
+ REQUEST_HEADER_FIELDS_TOO_LARGE: {
1718
+ CODE: 431,
1719
+ MESSAGE: "Request Header Fields Too Large"
1720
+ },
1721
+ UNAVAILABLE_FOR_LEGAL_REASONS: {
1722
+ CODE: 451,
1723
+ MESSAGE: "Unavailable For Legal Reasons"
1724
+ },
1725
+ INTERNAL_SERVER_ERROR: {
1726
+ CODE: 500,
1727
+ MESSAGE: "Internal Server Error"
1728
+ },
1729
+ NOT_IMPLEMENTED: {
1730
+ CODE: 501,
1731
+ MESSAGE: "Not Implemented"
1732
+ },
1733
+ BAD_GATEWAY: {
1734
+ CODE: 502,
1735
+ MESSAGE: "Bad Gateway"
1736
+ },
1737
+ SERVICE_UNAVAILABLE: {
1738
+ CODE: 503,
1739
+ MESSAGE: "Service Unavailable"
1740
+ },
1741
+ GATEWAY_TIMEOUT: {
1742
+ CODE: 504,
1743
+ MESSAGE: "Gateway Timeout"
1744
+ },
1745
+ HTTP_VERSION_NOT_SUPPORTED: {
1746
+ CODE: 505,
1747
+ MESSAGE: "HTTP Version Not Supported"
1748
+ },
1749
+ INSUFFICIENT_STORAGE: {
1750
+ CODE: 507,
1751
+ MESSAGE: "Insufficient Storage"
1752
+ },
1753
+ NETWORK_AUTHENTICATION_REQUIRED: {
1754
+ CODE: 511,
1755
+ MESSAGE: "Network Authentication Required"
1756
+ }
1757
+ };
1758
+ // src/nodejs/mongo.ts
1759
+ import { format } from "date-fns";
1760
+ import { Document } from "mongoose";
1761
+ import aggregatePaginate from "mongoose-aggregate-paginate-v2";
1762
+ import mongoosePaginate from "mongoose-paginate-v2";
1763
+ import { v4 as uuidv4 } from "uuid";
1764
+ // src/utils/string.ts
1765
+ import cryptoJS from "crypto-js";
1766
+ import slugifyRaw from "slugify";
1767
+ var slugify = slugifyRaw.default || slugifyRaw;
1768
+ function generateSlug() {
1769
+ var str = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : "", options = arguments.length > 1 ? arguments[1] : void 0;
1770
+ var _ref = options || {}, _ref_lower = _ref.lower, lower = _ref_lower === void 0 ? true : _ref_lower, _ref_locale = _ref.locale, locale = _ref_locale === void 0 ? "vi" : _ref_locale, rest = _object_without_properties(_ref, [
1771
+ "lower",
1772
+ "locale"
1773
+ ]);
1774
+ return slugify(str, _object_spread({
1775
+ lower: lower,
1776
+ locale: locale
1777
+ }, rest));
1778
+ }
1779
+ function generateShortId(uuid) {
1780
+ var length = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 4;
1781
+ return cryptoJS.SHA256(uuid).toString(cryptoJS.enc.Hex).slice(0, length);
1782
+ }
1783
+ // src/utils/validate.ts
1784
+ var validate = {
1785
+ isEmpty: function isEmpty(value) {
1786
+ if (value === null || value === void 0) {
1787
+ return true;
1788
+ }
1789
+ if (Array.isArray(value)) {
1790
+ return value.length === 0;
1791
+ }
1792
+ if ((typeof value === "undefined" ? "undefined" : _type_of(value)) === "object") {
1793
+ if (_instanceof(value, Date)) {
1794
+ return false;
1795
+ }
1796
+ return Object.keys(value).length === 0;
1797
+ }
1798
+ if (typeof value === "string") {
1799
+ return value.trim().length === 0;
1800
+ }
1801
+ return false;
1802
+ }
1803
+ };
1804
+ // src/nodejs/mongo.ts
1805
+ var mongo = {
1806
+ getDateTime: function getDateTime() {
1807
+ var now = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : /* @__PURE__ */ new Date();
1808
+ return format(now, "yyyy-MM-dd HH:mm:ss.SSS");
1809
+ },
1810
+ createGenericFields: function createGenericFields() {
1811
+ var _ref = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref_returnDateAs = _ref.returnDateAs, returnDateAs = _ref_returnDateAs === void 0 ? "string" : _ref_returnDateAs;
1812
+ var now = returnDateAs === "string" ? mongo.getDateTime() : /* @__PURE__ */ new Date();
1813
+ return {
1814
+ id: uuidv4(),
1815
+ isDel: false,
1816
+ createdAt: now,
1817
+ updatedAt: now
1818
+ };
1819
+ },
1820
+ applyPlugins: function applyPlugins(schema, plugins) {
1821
+ plugins.filter(function(plugin) {
1822
+ return typeof plugin === "function";
1823
+ }).forEach(function(plugin) {
1824
+ return schema.plugin(plugin);
1825
+ });
1826
+ },
1827
+ applyMiddlewares: function applyMiddlewares(schema, middlewares) {
1828
+ middlewares.forEach(function(param) {
1829
+ var method = param.method, pre = param.pre, post = param.post;
1830
+ if (method && pre) {
1831
+ schema.pre(method, pre);
1832
+ }
1833
+ if (method && post) {
1834
+ schema.post(method, post);
1835
+ }
1836
+ });
1837
+ },
1838
+ createGenericSchema: function createGenericSchema(mongoose) {
1839
+ return new mongoose.Schema({
1840
+ id: {
1841
+ type: String,
1842
+ default: uuidv4,
1843
+ required: true,
1844
+ unique: true
1845
+ },
1846
+ isDel: {
1847
+ type: Boolean,
1848
+ default: false,
1849
+ required: true
1850
+ }
1851
+ }, {
1852
+ timestamps: true
1853
+ });
1854
+ },
1855
+ createSchema: function createSchema(param) {
1856
+ var mongoose = param.mongoose, schema = param.schema, _param_virtuals = param.virtuals, virtuals = _param_virtuals === void 0 ? [] : _param_virtuals, _param_standalone = param.standalone, standalone = _param_standalone === void 0 ? false : _param_standalone;
1857
+ var createdSchema = new mongoose.Schema(schema, {
1858
+ strict: true
1859
+ });
1860
+ virtuals.forEach(function(param) {
1861
+ var name = param.name, options = param.options, get = param.get;
1862
+ var virtualInstance = createdSchema.virtual(name, options);
1863
+ if (get) virtualInstance.get(get);
1864
+ });
1865
+ if (!standalone) {
1866
+ createdSchema.add(mongo.createGenericSchema(mongoose));
1867
+ }
1868
+ return createdSchema;
1869
+ },
1870
+ createModel: function createModel(param) {
1871
+ var currentMongooseInstance = param.mongoose, name = param.name, schema = param.schema, _param_pagination = param.pagination, pagination = _param_pagination === void 0 ? false : _param_pagination, _param_aggregate = param.aggregate, aggregate = _param_aggregate === void 0 ? false : _param_aggregate, _param_virtuals = param.virtuals, virtuals = _param_virtuals === void 0 ? [] : _param_virtuals, _param_middlewares = param.middlewares, middlewares = _param_middlewares === void 0 ? [] : _param_middlewares;
1872
+ if (!name) {
1873
+ throw new Error("Model name is required.");
1874
+ }
1875
+ if (currentMongooseInstance.models[name]) {
1876
+ return currentMongooseInstance.models[name];
1877
+ }
1878
+ var createdSchema = mongo.createSchema({
1879
+ mongoose: currentMongooseInstance,
1880
+ schema: schema,
1881
+ virtuals: virtuals
1882
+ });
1883
+ mongo.applyPlugins(createdSchema, [
1884
+ pagination && mongoosePaginate,
1885
+ aggregate && aggregatePaginate
1886
+ ]);
1887
+ mongo.applyMiddlewares(createdSchema, middlewares);
1888
+ return currentMongooseInstance.model(name, createdSchema);
1889
+ },
1890
+ createSlugQuery: function createSlugQuery(slug) {
1891
+ var filters = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, id = arguments.length > 2 ? arguments[2] : void 0;
1892
+ return _object_spread_props(_object_spread({}, filters, id && {
1893
+ id: {
1894
+ $ne: id
1895
+ }
1896
+ }), {
1897
+ $or: [
1898
+ {
1899
+ slug: slug
1900
+ },
1901
+ {
1902
+ slugHistory: slug
1903
+ }
1904
+ ]
1905
+ });
1906
+ },
1907
+ validator: {
1908
+ isEmpty: function isEmpty() {
1909
+ return /*#__PURE__*/ function() {
1910
+ var _ref = _async_to_generator(function(value) {
1911
+ return _ts_generator(this, function(_state) {
1912
+ return [
1913
+ 2,
1914
+ !validate.isEmpty(value)
1915
+ ];
1916
+ });
1917
+ });
1918
+ return function(value) {
1919
+ return _ref.apply(this, arguments);
1920
+ };
1921
+ }();
1922
+ },
1923
+ isUnique: function isUnique(fields) {
1924
+ return /*#__PURE__*/ function() {
1925
+ var _ref = _async_to_generator(function(value) {
1926
+ var query, existingDocument;
1927
+ return _ts_generator(this, function(_state) {
1928
+ switch(_state.label){
1929
+ case 0:
1930
+ if (!Array.isArray(fields) || fields.length === 0) {
1931
+ throw new Error("Fields must be a non-empty array of strings.");
1932
+ }
1933
+ query = {
1934
+ $or: fields.map(function(field) {
1935
+ return _define_property({}, field, value);
1936
+ })
1937
+ };
1938
+ return [
1939
+ 4,
1940
+ this.constructor.findOne(query)
1941
+ ];
1942
+ case 1:
1943
+ existingDocument = _state.sent();
1944
+ return [
1945
+ 2,
1946
+ !existingDocument
1947
+ ];
1948
+ }
1949
+ });
1950
+ });
1951
+ return function(value) {
1952
+ return _ref.apply(this, arguments);
1953
+ };
1954
+ }();
1955
+ },
1956
+ matchesRegex: function matchesRegex(regexArray) {
1957
+ return /*#__PURE__*/ function() {
1958
+ var _ref = _async_to_generator(function(value) {
1959
+ return _ts_generator(this, function(_state) {
1960
+ if (!Array.isArray(regexArray) || regexArray.some(function(r) {
1961
+ return !_instanceof(r, RegExp);
1962
+ })) {
1963
+ throw new Error("regexArray must be an array of valid RegExp objects.");
1964
+ }
1965
+ return [
1966
+ 2,
1967
+ regexArray.every(function(regex) {
1968
+ return regex.test(value);
1969
+ })
1970
+ ];
1971
+ });
1972
+ });
1973
+ return function(value) {
1974
+ return _ref.apply(this, arguments);
1975
+ };
1976
+ }();
1977
+ }
1978
+ }
1979
+ };
1980
+ var MongoController = /*#__PURE__*/ function() {
1981
+ "use strict";
1982
+ function MongoController(db, collectionName) {
1983
+ _class_call_check(this, MongoController);
1984
+ this.collection = db.collection(collectionName);
1985
+ }
1986
+ _create_class(MongoController, [
1987
+ {
1988
+ key: "createOne",
1989
+ value: function createOne(document) {
1990
+ var _this = this;
1991
+ return _async_to_generator(function() {
1992
+ var finalDocument, result, error;
1993
+ return _ts_generator(this, function(_state) {
1994
+ switch(_state.label){
1995
+ case 0:
1996
+ _state.trys.push([
1997
+ 0,
1998
+ 2,
1999
+ ,
2000
+ 3
2001
+ ]);
2002
+ finalDocument = _object_spread({}, mongo.createGenericFields(), document);
2003
+ return [
2004
+ 4,
2005
+ _this.collection.insertOne(finalDocument)
2006
+ ];
2007
+ case 1:
2008
+ result = _state.sent();
2009
+ return [
2010
+ 2,
2011
+ {
2012
+ success: true,
2013
+ message: "Document created successfully",
2014
+ result: result
2015
+ }
2016
+ ];
2017
+ case 2:
2018
+ error = _state.sent();
2019
+ return [
2020
+ 2,
2021
+ {
2022
+ success: false,
2023
+ message: error.message
2024
+ }
2025
+ ];
2026
+ case 3:
2027
+ return [
2028
+ 2
2029
+ ];
2030
+ }
2031
+ });
2032
+ })();
2033
+ }
2034
+ },
2035
+ {
2036
+ key: "createMany",
2037
+ value: function createMany(documents) {
2038
+ var _this = this;
2039
+ return _async_to_generator(function() {
2040
+ var finalDocuments, result, error;
2041
+ return _ts_generator(this, function(_state) {
2042
+ switch(_state.label){
2043
+ case 0:
2044
+ _state.trys.push([
2045
+ 0,
2046
+ 2,
2047
+ ,
2048
+ 3
2049
+ ]);
2050
+ finalDocuments = documents.map(function(document) {
2051
+ return _object_spread({}, mongo.createGenericFields(), document);
2052
+ });
2053
+ return [
2054
+ 4,
2055
+ _this.collection.insertMany(finalDocuments)
2056
+ ];
2057
+ case 1:
2058
+ result = _state.sent();
2059
+ if (result.insertedCount === 0) {
2060
+ return [
2061
+ 2,
2062
+ {
2063
+ success: false,
2064
+ message: "No documents were inserted"
2065
+ }
2066
+ ];
2067
+ }
2068
+ return [
2069
+ 2,
2070
+ {
2071
+ success: true,
2072
+ message: "".concat(result.insertedCount, " documents created successfully"),
2073
+ result: result
2074
+ }
2075
+ ];
2076
+ case 2:
2077
+ error = _state.sent();
2078
+ return [
2079
+ 2,
2080
+ {
2081
+ success: false,
2082
+ message: error.message
2083
+ }
2084
+ ];
2085
+ case 3:
2086
+ return [
2087
+ 2
2088
+ ];
2089
+ }
2090
+ });
2091
+ })();
2092
+ }
2093
+ },
2094
+ {
2095
+ key: "findOne",
2096
+ value: function findOne(filter) {
2097
+ var _this = this;
2098
+ return _async_to_generator(function() {
2099
+ var result, error;
2100
+ return _ts_generator(this, function(_state) {
2101
+ switch(_state.label){
2102
+ case 0:
2103
+ _state.trys.push([
2104
+ 0,
2105
+ 2,
2106
+ ,
2107
+ 3
2108
+ ]);
2109
+ return [
2110
+ 4,
2111
+ _this.collection.findOne(filter)
2112
+ ];
2113
+ case 1:
2114
+ result = _state.sent();
2115
+ if (!result) {
2116
+ return [
2117
+ 2,
2118
+ {
2119
+ success: false,
2120
+ message: "Document not found"
2121
+ }
2122
+ ];
2123
+ }
2124
+ return [
2125
+ 2,
2126
+ {
2127
+ success: true,
2128
+ message: "Document found",
2129
+ result: result
2130
+ }
2131
+ ];
2132
+ case 2:
2133
+ error = _state.sent();
2134
+ return [
2135
+ 2,
2136
+ {
2137
+ success: false,
2138
+ message: error.message
2139
+ }
2140
+ ];
2141
+ case 3:
2142
+ return [
2143
+ 2
2144
+ ];
2145
+ }
2146
+ });
2147
+ })();
2148
+ }
2149
+ },
2150
+ {
2151
+ key: "findAll",
2152
+ value: function findAll() {
2153
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2154
+ var _this = this;
2155
+ return _async_to_generator(function() {
2156
+ var result, error;
2157
+ return _ts_generator(this, function(_state) {
2158
+ switch(_state.label){
2159
+ case 0:
2160
+ _state.trys.push([
2161
+ 0,
2162
+ 2,
2163
+ ,
2164
+ 3
2165
+ ]);
2166
+ return [
2167
+ 4,
2168
+ _this.collection.find(filter).toArray()
2169
+ ];
2170
+ case 1:
2171
+ result = _state.sent();
2172
+ return [
2173
+ 2,
2174
+ {
2175
+ success: true,
2176
+ message: "Documents retrieved successfully",
2177
+ result: result
2178
+ }
2179
+ ];
2180
+ case 2:
2181
+ error = _state.sent();
2182
+ return [
2183
+ 2,
2184
+ {
2185
+ success: false,
2186
+ message: error.message
2187
+ }
2188
+ ];
2189
+ case 3:
2190
+ return [
2191
+ 2
2192
+ ];
2193
+ }
2194
+ });
2195
+ })();
2196
+ }
2197
+ },
2198
+ {
2199
+ key: "count",
2200
+ value: function count() {
2201
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2202
+ var _this = this;
2203
+ return _async_to_generator(function() {
2204
+ var result, error;
2205
+ return _ts_generator(this, function(_state) {
2206
+ switch(_state.label){
2207
+ case 0:
2208
+ _state.trys.push([
2209
+ 0,
2210
+ 2,
2211
+ ,
2212
+ 3
2213
+ ]);
2214
+ return [
2215
+ 4,
2216
+ _this.collection.countDocuments(filter)
2217
+ ];
2218
+ case 1:
2219
+ result = _state.sent();
2220
+ return [
2221
+ 2,
2222
+ {
2223
+ success: true,
2224
+ message: "Count retrieved successfully",
2225
+ result: result
2226
+ }
2227
+ ];
2228
+ case 2:
2229
+ error = _state.sent();
2230
+ return [
2231
+ 2,
2232
+ {
2233
+ success: false,
2234
+ message: error.message
2235
+ }
2236
+ ];
2237
+ case 3:
2238
+ return [
2239
+ 2
2240
+ ];
2241
+ }
2242
+ });
2243
+ })();
2244
+ }
2245
+ },
2246
+ {
2247
+ key: "updateOne",
2248
+ value: function updateOne(filter, update) {
2249
+ var _this = this;
2250
+ return _async_to_generator(function() {
2251
+ var result, error;
2252
+ return _ts_generator(this, function(_state) {
2253
+ switch(_state.label){
2254
+ case 0:
2255
+ _state.trys.push([
2256
+ 0,
2257
+ 2,
2258
+ ,
2259
+ 3
2260
+ ]);
2261
+ return [
2262
+ 4,
2263
+ _this.collection.updateOne(filter, {
2264
+ $set: update
2265
+ })
2266
+ ];
2267
+ case 1:
2268
+ result = _state.sent();
2269
+ if (result.matchedCount === 0) {
2270
+ return [
2271
+ 2,
2272
+ {
2273
+ success: false,
2274
+ message: "No documents matched the filter"
2275
+ }
2276
+ ];
2277
+ }
2278
+ return [
2279
+ 2,
2280
+ {
2281
+ success: true,
2282
+ message: "Document updated successfully",
2283
+ result: result
2284
+ }
2285
+ ];
2286
+ case 2:
2287
+ error = _state.sent();
2288
+ return [
2289
+ 2,
2290
+ {
2291
+ success: false,
2292
+ message: error.message
2293
+ }
2294
+ ];
2295
+ case 3:
2296
+ return [
2297
+ 2
2298
+ ];
2299
+ }
2300
+ });
2301
+ })();
2302
+ }
2303
+ },
2304
+ {
2305
+ key: "updateMany",
2306
+ value: function updateMany(filter, update) {
2307
+ var _this = this;
2308
+ return _async_to_generator(function() {
2309
+ var result, error;
2310
+ return _ts_generator(this, function(_state) {
2311
+ switch(_state.label){
2312
+ case 0:
2313
+ _state.trys.push([
2314
+ 0,
2315
+ 2,
2316
+ ,
2317
+ 3
2318
+ ]);
2319
+ return [
2320
+ 4,
2321
+ _this.collection.updateMany(filter, {
2322
+ $set: update
2323
+ })
2324
+ ];
2325
+ case 1:
2326
+ result = _state.sent();
2327
+ if (result.matchedCount === 0) {
2328
+ return [
2329
+ 2,
2330
+ {
2331
+ success: false,
2332
+ message: "No documents matched the filter"
2333
+ }
2334
+ ];
2335
+ }
2336
+ return [
2337
+ 2,
2338
+ {
2339
+ success: true,
2340
+ message: "Documents updated successfully",
2341
+ result: result
2342
+ }
2343
+ ];
2344
+ case 2:
2345
+ error = _state.sent();
2346
+ return [
2347
+ 2,
2348
+ {
2349
+ success: false,
2350
+ message: error.message
2351
+ }
2352
+ ];
2353
+ case 3:
2354
+ return [
2355
+ 2
2356
+ ];
2357
+ }
2358
+ });
2359
+ })();
2360
+ }
2361
+ },
2362
+ {
2363
+ key: "deleteOne",
2364
+ value: function deleteOne(filter) {
2365
+ var _this = this;
2366
+ return _async_to_generator(function() {
2367
+ var result, error;
2368
+ return _ts_generator(this, function(_state) {
2369
+ switch(_state.label){
2370
+ case 0:
2371
+ _state.trys.push([
2372
+ 0,
2373
+ 2,
2374
+ ,
2375
+ 3
2376
+ ]);
2377
+ return [
2378
+ 4,
2379
+ _this.collection.deleteOne(filter)
2380
+ ];
2381
+ case 1:
2382
+ result = _state.sent();
2383
+ if (result.deletedCount === 0) {
2384
+ return [
2385
+ 2,
2386
+ {
2387
+ success: false,
2388
+ message: "No documents matched the filter"
2389
+ }
2390
+ ];
2391
+ }
2392
+ return [
2393
+ 2,
2394
+ {
2395
+ success: true,
2396
+ message: "Document deleted successfully",
2397
+ result: result
2398
+ }
2399
+ ];
2400
+ case 2:
2401
+ error = _state.sent();
2402
+ return [
2403
+ 2,
2404
+ {
2405
+ success: false,
2406
+ message: error.message
2407
+ }
2408
+ ];
2409
+ case 3:
2410
+ return [
2411
+ 2
2412
+ ];
2413
+ }
2414
+ });
2415
+ })();
2416
+ }
2417
+ },
2418
+ {
2419
+ key: "deleteMany",
2420
+ value: function deleteMany(filter) {
2421
+ var _this = this;
2422
+ return _async_to_generator(function() {
2423
+ var result, error;
2424
+ return _ts_generator(this, function(_state) {
2425
+ switch(_state.label){
2426
+ case 0:
2427
+ _state.trys.push([
2428
+ 0,
2429
+ 2,
2430
+ ,
2431
+ 3
2432
+ ]);
2433
+ return [
2434
+ 4,
2435
+ _this.collection.deleteMany(filter)
2436
+ ];
2437
+ case 1:
2438
+ result = _state.sent();
2439
+ if (result.deletedCount === 0) {
2440
+ return [
2441
+ 2,
2442
+ {
2443
+ success: false,
2444
+ message: "No documents matched the filter"
2445
+ }
2446
+ ];
2447
+ }
2448
+ return [
2449
+ 2,
2450
+ {
2451
+ success: true,
2452
+ message: "Documents deleted successfully",
2453
+ result: result
2454
+ }
2455
+ ];
2456
+ case 2:
2457
+ error = _state.sent();
2458
+ return [
2459
+ 2,
2460
+ {
2461
+ success: false,
2462
+ message: error.message
2463
+ }
2464
+ ];
2465
+ case 3:
2466
+ return [
2467
+ 2
2468
+ ];
2469
+ }
2470
+ });
2471
+ })();
2472
+ }
2473
+ }
2474
+ ]);
2475
+ return MongoController;
2476
+ }();
2477
+ var MongooseController = /*#__PURE__*/ function() {
2478
+ "use strict";
2479
+ function MongooseController(model) {
2480
+ _class_call_check(this, MongooseController);
2481
+ this.model = model;
2482
+ }
2483
+ _create_class(MongooseController, [
2484
+ {
2485
+ key: "getModelName",
2486
+ value: function getModelName() {
2487
+ return this.model.modelName;
2488
+ }
2489
+ },
2490
+ {
2491
+ key: "findOne",
2492
+ value: function findOne() {
2493
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, projection = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, populate = arguments.length > 3 ? arguments[3] : void 0;
2494
+ var _this = this;
2495
+ return _async_to_generator(function() {
2496
+ var query, result, error;
2497
+ return _ts_generator(this, function(_state) {
2498
+ switch(_state.label){
2499
+ case 0:
2500
+ _state.trys.push([
2501
+ 0,
2502
+ 2,
2503
+ ,
2504
+ 3
2505
+ ]);
2506
+ query = _this.model.findOne(filter, projection, options);
2507
+ if (populate) {
2508
+ query.populate(populate);
2509
+ }
2510
+ return [
2511
+ 4,
2512
+ query.exec()
2513
+ ];
2514
+ case 1:
2515
+ result = _state.sent();
2516
+ if (!result) {
2517
+ return [
2518
+ 2,
2519
+ {
2520
+ success: false,
2521
+ message: "No ".concat(_this.getModelName(), " found."),
2522
+ code: RESPONSE_STATUS.NOT_FOUND.CODE
2523
+ }
2524
+ ];
2525
+ }
2526
+ return [
2527
+ 2,
2528
+ {
2529
+ success: true,
2530
+ result: result
2531
+ }
2532
+ ];
2533
+ case 2:
2534
+ error = _state.sent();
2535
+ return [
2536
+ 2,
2537
+ {
2538
+ success: false,
2539
+ message: error.message,
2540
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2541
+ }
2542
+ ];
2543
+ case 3:
2544
+ return [
2545
+ 2
2546
+ ];
2547
+ }
2548
+ });
2549
+ })();
2550
+ }
2551
+ },
2552
+ {
2553
+ key: "findAll",
2554
+ value: function findAll() {
2555
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, projection = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, populate = arguments.length > 3 ? arguments[3] : void 0;
2556
+ var _this = this;
2557
+ return _async_to_generator(function() {
2558
+ var query, result, error;
2559
+ return _ts_generator(this, function(_state) {
2560
+ switch(_state.label){
2561
+ case 0:
2562
+ _state.trys.push([
2563
+ 0,
2564
+ 2,
2565
+ ,
2566
+ 3
2567
+ ]);
2568
+ query = _this.model.find(filter, projection, options);
2569
+ if (populate) {
2570
+ query.populate(populate);
2571
+ }
2572
+ return [
2573
+ 4,
2574
+ query.exec()
2575
+ ];
2576
+ case 1:
2577
+ result = _state.sent();
2578
+ return [
2579
+ 2,
2580
+ {
2581
+ success: true,
2582
+ result: result
2583
+ }
2584
+ ];
2585
+ case 2:
2586
+ error = _state.sent();
2587
+ return [
2588
+ 2,
2589
+ {
2590
+ success: false,
2591
+ message: error.message,
2592
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2593
+ }
2594
+ ];
2595
+ case 3:
2596
+ return [
2597
+ 2
2598
+ ];
2599
+ }
2600
+ });
2601
+ })();
2602
+ }
2603
+ },
2604
+ {
2605
+ key: "findPaging",
2606
+ value: function findPaging() {
2607
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2608
+ var _this = this;
2609
+ return _async_to_generator(function() {
2610
+ var result, error;
2611
+ return _ts_generator(this, function(_state) {
2612
+ switch(_state.label){
2613
+ case 0:
2614
+ _state.trys.push([
2615
+ 0,
2616
+ 2,
2617
+ ,
2618
+ 3
2619
+ ]);
2620
+ return [
2621
+ 4,
2622
+ _this.model.paginate(filter, options)
2623
+ ];
2624
+ case 1:
2625
+ result = _state.sent();
2626
+ return [
2627
+ 2,
2628
+ {
2629
+ success: true,
2630
+ result: result
2631
+ }
2632
+ ];
2633
+ case 2:
2634
+ error = _state.sent();
2635
+ return [
2636
+ 2,
2637
+ {
2638
+ success: false,
2639
+ message: error.message,
2640
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2641
+ }
2642
+ ];
2643
+ case 3:
2644
+ return [
2645
+ 2
2646
+ ];
2647
+ }
2648
+ });
2649
+ })();
2650
+ }
2651
+ },
2652
+ {
2653
+ key: "findPagingAggregate",
2654
+ value: function findPagingAggregate(pipeline) {
2655
+ var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2656
+ var _this = this;
2657
+ return _async_to_generator(function() {
2658
+ var result, error;
2659
+ return _ts_generator(this, function(_state) {
2660
+ switch(_state.label){
2661
+ case 0:
2662
+ _state.trys.push([
2663
+ 0,
2664
+ 2,
2665
+ ,
2666
+ 3
2667
+ ]);
2668
+ return [
2669
+ 4,
2670
+ _this.model.aggregatePaginate(_this.model.aggregate(pipeline), options)
2671
+ ];
2672
+ case 1:
2673
+ result = _state.sent();
2674
+ return [
2675
+ 2,
2676
+ {
2677
+ success: true,
2678
+ result: result
2679
+ }
2680
+ ];
2681
+ case 2:
2682
+ error = _state.sent();
2683
+ return [
2684
+ 2,
2685
+ {
2686
+ success: false,
2687
+ message: error.message,
2688
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2689
+ }
2690
+ ];
2691
+ case 3:
2692
+ return [
2693
+ 2
2694
+ ];
2695
+ }
2696
+ });
2697
+ })();
2698
+ }
2699
+ },
2700
+ {
2701
+ key: "count",
2702
+ value: function count() {
2703
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2704
+ var _this = this;
2705
+ return _async_to_generator(function() {
2706
+ var result, error;
2707
+ return _ts_generator(this, function(_state) {
2708
+ switch(_state.label){
2709
+ case 0:
2710
+ _state.trys.push([
2711
+ 0,
2712
+ 2,
2713
+ ,
2714
+ 3
2715
+ ]);
2716
+ return [
2717
+ 4,
2718
+ _this.model.countDocuments(filter)
2719
+ ];
2720
+ case 1:
2721
+ result = _state.sent();
2722
+ return [
2723
+ 2,
2724
+ {
2725
+ success: true,
2726
+ result: result
2727
+ }
2728
+ ];
2729
+ case 2:
2730
+ error = _state.sent();
2731
+ return [
2732
+ 2,
2733
+ {
2734
+ success: false,
2735
+ message: error.message,
2736
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2737
+ }
2738
+ ];
2739
+ case 3:
2740
+ return [
2741
+ 2
2742
+ ];
2743
+ }
2744
+ });
2745
+ })();
2746
+ }
2747
+ },
2748
+ {
2749
+ key: "createOne",
2750
+ value: function createOne(doc) {
2751
+ var _this = this;
2752
+ return _async_to_generator(function() {
2753
+ var result, error;
2754
+ return _ts_generator(this, function(_state) {
2755
+ switch(_state.label){
2756
+ case 0:
2757
+ _state.trys.push([
2758
+ 0,
2759
+ 2,
2760
+ ,
2761
+ 3
2762
+ ]);
2763
+ return [
2764
+ 4,
2765
+ _this.model.create(doc)
2766
+ ];
2767
+ case 1:
2768
+ result = _state.sent();
2769
+ return [
2770
+ 2,
2771
+ {
2772
+ success: true,
2773
+ result: result
2774
+ }
2775
+ ];
2776
+ case 2:
2777
+ error = _state.sent();
2778
+ return [
2779
+ 2,
2780
+ {
2781
+ success: false,
2782
+ message: error.message,
2783
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2784
+ }
2785
+ ];
2786
+ case 3:
2787
+ return [
2788
+ 2
2789
+ ];
2790
+ }
2791
+ });
2792
+ })();
2793
+ }
2794
+ },
2795
+ {
2796
+ key: "createMany",
2797
+ value: function createMany(docs) {
2798
+ var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2799
+ var _this = this;
2800
+ return _async_to_generator(function() {
2801
+ var createdDocuments, result, error;
2802
+ return _ts_generator(this, function(_state) {
2803
+ switch(_state.label){
2804
+ case 0:
2805
+ _state.trys.push([
2806
+ 0,
2807
+ 2,
2808
+ ,
2809
+ 3
2810
+ ]);
2811
+ return [
2812
+ 4,
2813
+ _this.model.insertMany(docs, options)
2814
+ ];
2815
+ case 1:
2816
+ createdDocuments = _state.sent();
2817
+ result = createdDocuments.map(function(doc) {
2818
+ if (_instanceof(doc, Document)) {
2819
+ return doc.toObject();
2820
+ }
2821
+ return null;
2822
+ }).filter(function(doc) {
2823
+ return doc !== null;
2824
+ });
2825
+ return [
2826
+ 2,
2827
+ {
2828
+ success: true,
2829
+ result: result
2830
+ }
2831
+ ];
2832
+ case 2:
2833
+ error = _state.sent();
2834
+ return [
2835
+ 2,
2836
+ {
2837
+ success: false,
2838
+ message: error.message,
2839
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2840
+ }
2841
+ ];
2842
+ case 3:
2843
+ return [
2844
+ 2
2845
+ ];
2846
+ }
2847
+ });
2848
+ })();
2849
+ }
2850
+ },
2851
+ {
2852
+ key: "updateOne",
2853
+ value: function updateOne() {
2854
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, update = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
2855
+ var _this = this;
2856
+ return _async_to_generator(function() {
2857
+ var result, error;
2858
+ return _ts_generator(this, function(_state) {
2859
+ switch(_state.label){
2860
+ case 0:
2861
+ _state.trys.push([
2862
+ 0,
2863
+ 2,
2864
+ ,
2865
+ 3
2866
+ ]);
2867
+ return [
2868
+ 4,
2869
+ _this.model.findOneAndUpdate(filter, update, _object_spread({
2870
+ new: true
2871
+ }, options)).exec()
2872
+ ];
2873
+ case 1:
2874
+ result = _state.sent();
2875
+ if (!result) {
2876
+ return [
2877
+ 2,
2878
+ {
2879
+ success: false,
2880
+ message: "Failed to update ".concat(_this.getModelName(), "."),
2881
+ code: RESPONSE_STATUS.NOT_FOUND.CODE
2882
+ }
2883
+ ];
2884
+ }
2885
+ return [
2886
+ 2,
2887
+ {
2888
+ success: true,
2889
+ result: result
2890
+ }
2891
+ ];
2892
+ case 2:
2893
+ error = _state.sent();
2894
+ return [
2895
+ 2,
2896
+ {
2897
+ success: false,
2898
+ message: error.message,
2899
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2900
+ }
2901
+ ];
2902
+ case 3:
2903
+ return [
2904
+ 2
2905
+ ];
2906
+ }
2907
+ });
2908
+ })();
2909
+ }
2910
+ },
2911
+ {
2912
+ key: "updateMany",
2913
+ value: function updateMany() {
2914
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, update = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
2915
+ var _this = this;
2916
+ return _async_to_generator(function() {
2917
+ var result, error;
2918
+ return _ts_generator(this, function(_state) {
2919
+ switch(_state.label){
2920
+ case 0:
2921
+ _state.trys.push([
2922
+ 0,
2923
+ 2,
2924
+ ,
2925
+ 3
2926
+ ]);
2927
+ return [
2928
+ 4,
2929
+ _this.model.updateMany(filter, update, options).exec()
2930
+ ];
2931
+ case 1:
2932
+ result = _state.sent();
2933
+ return [
2934
+ 2,
2935
+ {
2936
+ success: true,
2937
+ result: result
2938
+ }
2939
+ ];
2940
+ case 2:
2941
+ error = _state.sent();
2942
+ return [
2943
+ 2,
2944
+ {
2945
+ success: false,
2946
+ message: error.message,
2947
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2948
+ }
2949
+ ];
2950
+ case 3:
2951
+ return [
2952
+ 2
2953
+ ];
2954
+ }
2955
+ });
2956
+ })();
2957
+ }
2958
+ },
2959
+ {
2960
+ key: "deleteOne",
2961
+ value: function deleteOne() {
2962
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2963
+ var _this = this;
2964
+ return _async_to_generator(function() {
2965
+ var result, error;
2966
+ return _ts_generator(this, function(_state) {
2967
+ switch(_state.label){
2968
+ case 0:
2969
+ _state.trys.push([
2970
+ 0,
2971
+ 2,
2972
+ ,
2973
+ 3
2974
+ ]);
2975
+ return [
2976
+ 4,
2977
+ _this.model.findOneAndDelete(filter, options).exec()
2978
+ ];
2979
+ case 1:
2980
+ result = _state.sent();
2981
+ if (!result) {
2982
+ return [
2983
+ 2,
2984
+ {
2985
+ success: false,
2986
+ message: "No ".concat(_this.getModelName(), " found to delete."),
2987
+ code: RESPONSE_STATUS.NOT_FOUND.CODE
2988
+ }
2989
+ ];
2990
+ }
2991
+ return [
2992
+ 2,
2993
+ {
2994
+ success: true,
2995
+ result: result
2996
+ }
2997
+ ];
2998
+ case 2:
2999
+ error = _state.sent();
3000
+ return [
3001
+ 2,
3002
+ {
3003
+ success: false,
3004
+ message: error.message,
3005
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3006
+ }
3007
+ ];
3008
+ case 3:
3009
+ return [
3010
+ 2
3011
+ ];
3012
+ }
3013
+ });
3014
+ })();
3015
+ }
3016
+ },
3017
+ {
3018
+ key: "deleteMany",
3019
+ value: function deleteMany() {
3020
+ var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
3021
+ var _this = this;
3022
+ return _async_to_generator(function() {
3023
+ var result, error;
3024
+ return _ts_generator(this, function(_state) {
3025
+ switch(_state.label){
3026
+ case 0:
3027
+ _state.trys.push([
3028
+ 0,
3029
+ 2,
3030
+ ,
3031
+ 3
3032
+ ]);
3033
+ return [
3034
+ 4,
3035
+ _this.model.deleteMany(filter, options).exec()
3036
+ ];
3037
+ case 1:
3038
+ result = _state.sent();
3039
+ if (result.deletedCount === 0) {
3040
+ return [
3041
+ 2,
3042
+ {
3043
+ success: false,
3044
+ message: "No documents found to delete.",
3045
+ code: RESPONSE_STATUS.NOT_FOUND.CODE
3046
+ }
3047
+ ];
3048
+ }
3049
+ return [
3050
+ 2,
3051
+ {
3052
+ success: true,
3053
+ result: result
3054
+ }
3055
+ ];
3056
+ case 2:
3057
+ error = _state.sent();
3058
+ return [
3059
+ 2,
3060
+ {
3061
+ success: false,
3062
+ message: error.message,
3063
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3064
+ }
3065
+ ];
3066
+ case 3:
3067
+ return [
3068
+ 2
3069
+ ];
3070
+ }
3071
+ });
3072
+ })();
3073
+ }
3074
+ },
3075
+ {
3076
+ key: "createShortId",
3077
+ value: function createShortId(id) {
3078
+ var length = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 4;
3079
+ var _this = this;
3080
+ return _async_to_generator(function() {
3081
+ var maxRetries, existingShortIds, retries, shortId, shortIdExists;
3082
+ return _ts_generator(this, function(_state) {
3083
+ switch(_state.label){
3084
+ case 0:
3085
+ maxRetries = 10;
3086
+ existingShortIds = /* @__PURE__ */ new Set();
3087
+ retries = 0;
3088
+ _state.label = 1;
3089
+ case 1:
3090
+ if (!(retries < maxRetries)) return [
3091
+ 3,
3092
+ 4
3093
+ ];
3094
+ shortId = generateShortId(id, retries + length);
3095
+ if (!!existingShortIds.has(shortId)) return [
3096
+ 3,
3097
+ 3
3098
+ ];
3099
+ existingShortIds.add(shortId);
3100
+ return [
3101
+ 4,
3102
+ _this.model.exists({
3103
+ shortId: shortId
3104
+ })
3105
+ ];
3106
+ case 2:
3107
+ shortIdExists = _state.sent();
3108
+ if (!shortIdExists) {
3109
+ return [
3110
+ 2,
3111
+ {
3112
+ success: true,
3113
+ result: shortId
3114
+ }
3115
+ ];
3116
+ }
3117
+ _state.label = 3;
3118
+ case 3:
3119
+ retries++;
3120
+ return [
3121
+ 3,
3122
+ 1
3123
+ ];
3124
+ case 4:
3125
+ return [
3126
+ 2,
3127
+ {
3128
+ success: false,
3129
+ message: "Failed to create a unique shortId",
3130
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3131
+ }
3132
+ ];
3133
+ }
3134
+ });
3135
+ })();
3136
+ }
3137
+ },
3138
+ {
3139
+ key: "createSlug",
3140
+ value: function createSlug(fieldName, fields) {
3141
+ var filters = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
3142
+ var _this = this;
3143
+ return _async_to_generator(function() {
3144
+ var fieldValue, createUniqueSlug, slugResults, _tmp, _tmp1, _i, lang, slug, slug1, uniqueSlug, error;
3145
+ return _ts_generator(this, function(_state) {
3146
+ switch(_state.label){
3147
+ case 0:
3148
+ _state.trys.push([
3149
+ 0,
3150
+ 8,
3151
+ ,
3152
+ 9
3153
+ ]);
3154
+ fieldValue = fields[fieldName];
3155
+ createUniqueSlug = /*#__PURE__*/ function() {
3156
+ var _ref = _async_to_generator(function(slug) {
3157
+ var existingDoc, suffix, uniqueSlug;
3158
+ return _ts_generator(this, function(_state) {
3159
+ switch(_state.label){
3160
+ case 0:
3161
+ return [
3162
+ 4,
3163
+ _this.model.findOne(mongo.createSlugQuery(slug, filters, fields.id))
3164
+ ];
3165
+ case 1:
3166
+ existingDoc = _state.sent();
3167
+ if (!existingDoc) return [
3168
+ 2,
3169
+ slug
3170
+ ];
3171
+ suffix = 1;
3172
+ _state.label = 2;
3173
+ case 2:
3174
+ uniqueSlug = "".concat(slug, "-").concat(suffix);
3175
+ return [
3176
+ 4,
3177
+ _this.model.findOne(mongo.createSlugQuery(uniqueSlug, filters, fields.id))
3178
+ ];
3179
+ case 3:
3180
+ existingDoc = _state.sent();
3181
+ suffix++;
3182
+ _state.label = 4;
3183
+ case 4:
3184
+ if (existingDoc) return [
3185
+ 3,
3186
+ 2
3187
+ ];
3188
+ _state.label = 5;
3189
+ case 5:
3190
+ return [
3191
+ 2,
3192
+ uniqueSlug
3193
+ ];
3194
+ }
3195
+ });
3196
+ });
3197
+ return function createUniqueSlug(slug) {
3198
+ return _ref.apply(this, arguments);
3199
+ };
3200
+ }();
3201
+ if (!((typeof fieldValue === "undefined" ? "undefined" : _type_of(fieldValue)) === "object")) return [
3202
+ 3,
3203
+ 5
3204
+ ];
3205
+ slugResults = {};
3206
+ _tmp = [];
3207
+ for(_tmp1 in fieldValue)_tmp.push(_tmp1);
3208
+ _i = 0;
3209
+ _state.label = 1;
3210
+ case 1:
3211
+ if (!(_i < _tmp.length)) return [
3212
+ 3,
3213
+ 4
3214
+ ];
3215
+ lang = _tmp[_i];
3216
+ slug = generateSlug(fieldValue[lang]);
3217
+ return [
3218
+ 4,
3219
+ createUniqueSlug(slug)
3220
+ ];
3221
+ case 2:
3222
+ slugResults[lang] = _state.sent();
3223
+ _state.label = 3;
3224
+ case 3:
3225
+ _i++;
3226
+ return [
3227
+ 3,
3228
+ 1
3229
+ ];
3230
+ case 4:
3231
+ return [
3232
+ 2,
3233
+ {
3234
+ success: true,
3235
+ result: slugResults
3236
+ }
3237
+ ];
3238
+ case 5:
3239
+ slug1 = generateSlug(fieldValue);
3240
+ return [
3241
+ 4,
3242
+ createUniqueSlug(slug1)
3243
+ ];
3244
+ case 6:
3245
+ uniqueSlug = _state.sent();
3246
+ return [
3247
+ 2,
3248
+ {
3249
+ success: true,
3250
+ result: uniqueSlug
3251
+ }
3252
+ ];
3253
+ case 7:
3254
+ return [
3255
+ 3,
3256
+ 9
3257
+ ];
3258
+ case 8:
3259
+ error = _state.sent();
3260
+ return [
3261
+ 2,
3262
+ {
3263
+ success: false,
3264
+ message: "Failed to create a unique slug: ".concat(error.message),
3265
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3266
+ }
3267
+ ];
3268
+ case 9:
3269
+ return [
3270
+ 2
3271
+ ];
3272
+ }
3273
+ });
3274
+ })();
3275
+ }
3276
+ },
3277
+ {
3278
+ key: "aggregate",
3279
+ value: function aggregate(pipeline) {
3280
+ var _this = this;
3281
+ return _async_to_generator(function() {
3282
+ var result, error;
3283
+ return _ts_generator(this, function(_state) {
3284
+ switch(_state.label){
3285
+ case 0:
3286
+ _state.trys.push([
3287
+ 0,
3288
+ 2,
3289
+ ,
3290
+ 3
3291
+ ]);
3292
+ return [
3293
+ 4,
3294
+ _this.model.aggregate(pipeline)
3295
+ ];
3296
+ case 1:
3297
+ result = _state.sent();
3298
+ return [
3299
+ 2,
3300
+ {
3301
+ success: true,
3302
+ result: result
3303
+ }
3304
+ ];
3305
+ case 2:
3306
+ error = _state.sent();
3307
+ return [
3308
+ 2,
3309
+ {
3310
+ success: false,
3311
+ message: error.message,
3312
+ code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3313
+ }
3314
+ ];
3315
+ case 3:
3316
+ return [
3317
+ 2
3318
+ ];
3319
+ }
3320
+ });
3321
+ })();
3322
+ }
3323
+ }
3324
+ ]);
3325
+ return MongooseController;
3326
+ }();
3327
+ // src/react/apollo-client.tsx
3328
+ import { ApolloClient, ApolloLink, ApolloProvider as ApolloProviderDefault, HttpLink, InMemoryCache, split } from "@apollo/client";
3329
+ import { onError } from "@apollo/client/link/error";
3330
+ import { GraphQLWsLink } from "@apollo/client/link/subscriptions";
3331
+ import { getMainDefinition } from "@apollo/client/utilities";
3332
+ import { createClient as createGraphqlWebSocketClient } from "graphql-ws";
3333
+ import { jsx } from "react/jsx-runtime";
3334
+ function createLinks(options) {
3335
+ var errorLink = onError(function(param) {
3336
+ var graphQLErrors = param.graphQLErrors, networkError = param.networkError;
3337
+ graphQLErrors === null || graphQLErrors === void 0 ? void 0 : graphQLErrors.forEach(function(param) {
3338
+ var message = param.message, locations = param.locations, path3 = param.path;
3339
+ return console.error("[GraphQL error]: Message: ".concat(message, ", Location: ").concat(locations, ", Path: ").concat(path3));
3340
+ });
3341
+ if (networkError) {
3342
+ console.error("[Network error]: ".concat(networkError));
3343
+ }
3344
+ });
3345
+ var httpLink = new HttpLink({
3346
+ uri: options === null || options === void 0 ? void 0 : options.uri,
3347
+ credentials: "include"
3348
+ });
3349
+ var wsLink = (options === null || options === void 0 ? void 0 : options.wsUrl) ? new GraphQLWsLink(createGraphqlWebSocketClient({
3350
+ url: options.wsUrl
3351
+ })) : null;
3352
+ var splitLink = wsLink ? split(function(param) {
3353
+ var query = param.query;
3354
+ var mainDefinition = getMainDefinition(query);
3355
+ if (mainDefinition.kind === "OperationDefinition") {
3356
+ var operation = mainDefinition.operation;
3357
+ return operation === "subscription";
3358
+ }
3359
+ return false;
3360
+ }, wsLink, httpLink) : httpLink;
3361
+ var cleanTypeName = new ApolloLink(function(operation, forward) {
3362
+ if (operation.variables) {
3363
+ operation.variables = JSON.parse(JSON.stringify(operation.variables), function(key, value) {
3364
+ return key === "__typename" ? void 0 : value;
3365
+ });
3366
+ }
3367
+ return forward(operation);
3368
+ });
3369
+ return {
3370
+ errorLink: errorLink,
3371
+ httpLink: httpLink,
3372
+ wsLink: wsLink,
3373
+ splitLink: splitLink,
3374
+ cleanTypeName: cleanTypeName
3375
+ };
3376
+ }
3377
+ function ApolloProvider(param) {
3378
+ var isNextJS = param.isNextJS, options = param.options, children = param.children, CustomClient = param.client, CustomProvider = param.provider, CustomCache = param.cache;
3379
+ var Client = CustomClient !== null && CustomClient !== void 0 ? CustomClient : ApolloClient;
3380
+ if (typeof Client !== "function") {
3381
+ throw new TypeError("Invalid ApolloClient provided. Ensure CustomClient is a class.");
3382
+ }
3383
+ var Provider = CustomProvider || ApolloProviderDefault;
3384
+ var Cache = CustomCache || InMemoryCache;
3385
+ var _createLinks = createLinks(options), cleanTypeName = _createLinks.cleanTypeName, errorLink = _createLinks.errorLink, splitLink = _createLinks.splitLink;
3386
+ var client = new Client(_object_spread({
3387
+ cache: _instanceof(Cache, InMemoryCache) ? Cache : new InMemoryCache(),
3388
+ link: ApolloLink.from([
3389
+ cleanTypeName,
3390
+ errorLink,
3391
+ splitLink
3392
+ ].filter(Boolean))
3393
+ }, options));
3394
+ if (isNextJS) {
3395
+ return /* @__PURE__ */ jsx(Provider, {
3396
+ makeClient: function() {
3397
+ return client;
3398
+ },
3399
+ children: children
3400
+ });
3401
+ }
3402
+ return /* @__PURE__ */ jsx(Provider, {
3403
+ client: client,
3404
+ children: children
3405
+ });
3406
+ }
3407
+ // src/react/loading.tsx
3408
+ import cn from "classnames";
3409
+ import { createContext, use, useCallback, useMemo, useState } from "react";
3410
+ import styles from "./react/loading.module.scss";
3411
+ import { jsx as jsx2, jsxs } from "react/jsx-runtime";
3412
+ var LoadingContext = createContext(void 0);
3413
+ function useLoading() {
3414
+ var context = use(LoadingContext);
3415
+ if (!context) {
3416
+ throw new Error("useLoading must be used within a LoadingProvider");
3417
+ }
3418
+ return context;
3419
+ }
3420
+ function Loading(_param) {
3421
+ var _param_full = _param.full, full = _param_full === void 0 ? false : _param_full, _param_block = _param.block, block = _param_block === void 0 ? false : _param_block, _param_className = _param.className, className = _param_className === void 0 ? "" : _param_className, _param_message = _param.message, message = _param_message === void 0 ? "Loading" : _param_message, rest = _object_without_properties(_param, [
3422
+ "full",
3423
+ "block",
3424
+ "className",
3425
+ "message"
3426
+ ]);
3427
+ function _renderLoading() {
3428
+ return /* @__PURE__ */ jsxs("div", _object_spread_props(_object_spread({
3429
+ className: styles.container
3430
+ }, rest), {
3431
+ children: [
3432
+ /* @__PURE__ */ jsx2("div", {
3433
+ className: styles.ring
3434
+ }),
3435
+ /* @__PURE__ */ jsx2("div", {
3436
+ className: styles.ring
3437
+ }),
3438
+ /* @__PURE__ */ jsx2("div", {
3439
+ className: styles.ring
3440
+ }),
3441
+ /* @__PURE__ */ jsx2("div", {
3442
+ className: styles.ring
3443
+ }),
3444
+ message && /* @__PURE__ */ jsx2("div", {
3445
+ className: styles.message,
3446
+ children: message
3447
+ })
3448
+ ]
3449
+ }));
3450
+ }
3451
+ if (full) {
3452
+ return /* @__PURE__ */ jsx2("div", {
3453
+ className: cn(styles.fullscreen, className),
3454
+ children: _renderLoading()
3455
+ });
3456
+ } else if (block) {
3457
+ return /* @__PURE__ */ jsx2("div", {
3458
+ className: cn(styles.block, className),
3459
+ children: _renderLoading()
3460
+ });
3461
+ }
3462
+ return _renderLoading();
3463
+ }
3464
+ function LoadingProvider(param) {
3465
+ var children = param.children;
3466
+ var _useState = _sliced_to_array(useState(false), 2), isLoading = _useState[0], setIsLoading = _useState[1];
3467
+ var _useState1 = _sliced_to_array(useState(false), 2), isGlobalLoading = _useState1[0], setIsGlobalLoading = _useState1[1];
3468
+ var showLoading = useCallback(function() {
3469
+ var global = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false;
3470
+ setIsLoading(true);
3471
+ setIsGlobalLoading(global);
3472
+ }, []);
3473
+ var hideLoading = useCallback(function() {
3474
+ setIsLoading(false);
3475
+ setIsGlobalLoading(false);
3476
+ }, []);
3477
+ var contextValue = useMemo(function() {
3478
+ return {
3479
+ isLoading: isLoading,
3480
+ isGlobalLoading: isGlobalLoading,
3481
+ showLoading: showLoading,
3482
+ hideLoading: hideLoading
3483
+ };
3484
+ }, [
3485
+ isLoading,
3486
+ isGlobalLoading,
3487
+ showLoading,
3488
+ hideLoading
3489
+ ]);
3490
+ return /* @__PURE__ */ jsx2(LoadingContext, {
3491
+ value: contextValue,
3492
+ children: isLoading ? /* @__PURE__ */ jsx2(Loading, {
3493
+ full: isGlobalLoading
3494
+ }) : children
3495
+ });
3496
+ }
3497
+ // src/react/next-intl.tsx
3498
+ import { NextIntlClientProvider, useTranslations } from "next-intl";
3499
+ import { createContext as createContext2, use as use2, useMemo as useMemo2 } from "react";
3500
+ // src/react/storage.tsx
3501
+ import { useCallback as useCallback2, useEffect, useState as useState2 } from "react";
3502
+ // src/utils/serializer.ts
3503
+ var serializer = {
3504
+ serialize: function(value) {
3505
+ return JSON.stringify(value, function(_, v) {
3506
+ if (_instanceof(v, Date)) {
3507
+ return {
3508
+ __type: "Date",
3509
+ value: v.toISOString()
3510
+ };
3511
+ }
3512
+ return v;
3513
+ });
3514
+ },
3515
+ deserialize: function(value) {
3516
+ return JSON.parse(value, function(_, v) {
3517
+ if ((v === null || v === void 0 ? void 0 : v.__type) === "Date") {
3518
+ return new Date(v.value);
3519
+ }
3520
+ return v;
3521
+ });
3522
+ }
3523
+ };
3524
+ // src/utils/storage-client.ts
3525
+ import localForage from "localforage";
3526
+ var storageClient = {
3527
+ get: function get(key) {
3528
+ return _async_to_generator(function() {
3529
+ var error;
3530
+ return _ts_generator(this, function(_state) {
3531
+ switch(_state.label){
3532
+ case 0:
3533
+ _state.trys.push([
3534
+ 0,
3535
+ 2,
3536
+ ,
3537
+ 3
3538
+ ]);
3539
+ return [
3540
+ 4,
3541
+ localForage.getItem(key)
3542
+ ];
3543
+ case 1:
3544
+ return [
3545
+ 2,
3546
+ _state.sent()
3547
+ ];
3548
+ case 2:
3549
+ error = _state.sent();
3550
+ console.error('❌ [Storage:get] Error getting key "'.concat(key, '":'), error);
3551
+ return [
3552
+ 2,
3553
+ null
3554
+ ];
3555
+ case 3:
3556
+ return [
3557
+ 2
3558
+ ];
3559
+ }
3560
+ });
3561
+ })();
3562
+ },
3563
+ set: function set(key, value) {
3564
+ return _async_to_generator(function() {
3565
+ var error;
3566
+ return _ts_generator(this, function(_state) {
3567
+ switch(_state.label){
3568
+ case 0:
3569
+ _state.trys.push([
3570
+ 0,
3571
+ 2,
3572
+ ,
3573
+ 3
3574
+ ]);
3575
+ return [
3576
+ 4,
3577
+ localForage.setItem(key, value)
3578
+ ];
3579
+ case 1:
3580
+ _state.sent();
3581
+ return [
3582
+ 3,
3583
+ 3
3584
+ ];
3585
+ case 2:
3586
+ error = _state.sent();
3587
+ console.error('❌ [Storage:set] Error setting key "'.concat(key, '":'), error);
3588
+ return [
3589
+ 3,
3590
+ 3
3591
+ ];
3592
+ case 3:
3593
+ return [
3594
+ 2
3595
+ ];
3596
+ }
3597
+ });
3598
+ })();
3599
+ },
3600
+ remove: function remove(key) {
3601
+ return _async_to_generator(function() {
3602
+ var error;
3603
+ return _ts_generator(this, function(_state) {
3604
+ switch(_state.label){
3605
+ case 0:
3606
+ _state.trys.push([
3607
+ 0,
3608
+ 2,
3609
+ ,
3610
+ 3
3611
+ ]);
3612
+ return [
3613
+ 4,
3614
+ localForage.removeItem(key)
3615
+ ];
3616
+ case 1:
3617
+ _state.sent();
3618
+ return [
3619
+ 3,
3620
+ 3
3621
+ ];
3622
+ case 2:
3623
+ error = _state.sent();
3624
+ console.error('❌ [Storage:remove] Error removing key "'.concat(key, '":'), error);
3625
+ return [
3626
+ 3,
3627
+ 3
3628
+ ];
3629
+ case 3:
3630
+ return [
3631
+ 2
3632
+ ];
3633
+ }
3634
+ });
3635
+ })();
3636
+ },
3637
+ keys: function keys() {
3638
+ return _async_to_generator(function() {
3639
+ var keys, error;
3640
+ return _ts_generator(this, function(_state) {
3641
+ switch(_state.label){
3642
+ case 0:
3643
+ _state.trys.push([
3644
+ 0,
3645
+ 2,
3646
+ ,
3647
+ 3
3648
+ ]);
3649
+ return [
3650
+ 4,
3651
+ localForage.keys()
3652
+ ];
3653
+ case 1:
3654
+ keys = _state.sent();
3655
+ return [
3656
+ 2,
3657
+ keys !== null && keys !== void 0 ? keys : []
3658
+ ];
3659
+ case 2:
3660
+ error = _state.sent();
3661
+ console.error("❌ [Storage:keys] Error getting keys:", error);
3662
+ return [
3663
+ 2,
3664
+ []
3665
+ ];
3666
+ case 3:
3667
+ return [
3668
+ 2
3669
+ ];
3670
+ }
3671
+ });
3672
+ })();
3673
+ }
3674
+ };
3675
+ // src/react/storage.tsx
3676
+ function useStorage(key, initialValue) {
3677
+ var serializer2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : serializer;
3678
+ var _useState2 = _sliced_to_array(useState2(initialValue), 2), value = _useState2[0], setValue = _useState2[1];
3679
+ var _useState21 = _sliced_to_array(useState2(false), 2), isLoaded = _useState21[0], setIsLoaded = _useState21[1];
3680
+ useEffect(function() {
3681
+ var isMounted = true;
3682
+ var loadValue = /*#__PURE__*/ function() {
3683
+ var _ref = _async_to_generator(function() {
3684
+ var valueFound, parsedValue, serialized, error;
3685
+ return _ts_generator(this, function(_state) {
3686
+ switch(_state.label){
3687
+ case 0:
3688
+ _state.trys.push([
3689
+ 0,
3690
+ 6,
3691
+ 7,
3692
+ 8
3693
+ ]);
3694
+ return [
3695
+ 4,
3696
+ storageClient.get(key)
3697
+ ];
3698
+ case 1:
3699
+ valueFound = _state.sent();
3700
+ if (!isMounted) return [
3701
+ 3,
3702
+ 5
3703
+ ];
3704
+ if (!(valueFound !== null)) return [
3705
+ 3,
3706
+ 2
3707
+ ];
3708
+ parsedValue = serializer2.deserialize(valueFound);
3709
+ setValue(parsedValue);
3710
+ return [
3711
+ 3,
3712
+ 5
3713
+ ];
3714
+ case 2:
3715
+ if (!(initialValue !== void 0)) return [
3716
+ 3,
3717
+ 4
3718
+ ];
3719
+ serialized = serializer2.serialize(initialValue);
3720
+ return [
3721
+ 4,
3722
+ storageClient.set(key, serialized)
3723
+ ];
3724
+ case 3:
3725
+ _state.sent();
3726
+ setValue(initialValue);
3727
+ return [
3728
+ 3,
3729
+ 5
3730
+ ];
3731
+ case 4:
3732
+ setValue(void 0);
3733
+ _state.label = 5;
3734
+ case 5:
3735
+ return [
3736
+ 3,
3737
+ 8
3738
+ ];
3739
+ case 6:
3740
+ error = _state.sent();
3741
+ console.error('Error loading value for key "'.concat(key, '":'), error);
3742
+ if (isMounted) {
3743
+ setValue(initialValue);
3744
+ }
3745
+ return [
3746
+ 3,
3747
+ 8
3748
+ ];
3749
+ case 7:
3750
+ if (isMounted) setIsLoaded(true);
3751
+ return [
3752
+ 7
3753
+ ];
3754
+ case 8:
3755
+ return [
3756
+ 2
3757
+ ];
3758
+ }
3759
+ });
3760
+ });
3761
+ return function loadValue() {
3762
+ return _ref.apply(this, arguments);
3763
+ };
3764
+ }();
3765
+ loadValue();
3766
+ return function() {
3767
+ isMounted = false;
3768
+ setIsLoaded(false);
3769
+ };
3770
+ }, [
3771
+ key,
3772
+ initialValue,
3773
+ serializer2
3774
+ ]);
3775
+ useEffect(function() {
3776
+ if (!isLoaded) return;
3777
+ var saveValue = /*#__PURE__*/ function() {
3778
+ var _ref = _async_to_generator(function() {
3779
+ var serialized, error;
3780
+ return _ts_generator(this, function(_state) {
3781
+ switch(_state.label){
3782
+ case 0:
3783
+ _state.trys.push([
3784
+ 0,
3785
+ 3,
3786
+ ,
3787
+ 4
3788
+ ]);
3789
+ if (!(value !== void 0)) return [
3790
+ 3,
3791
+ 2
3792
+ ];
3793
+ serialized = serializer2.serialize(value);
3794
+ return [
3795
+ 4,
3796
+ storageClient.set(key, serialized)
3797
+ ];
3798
+ case 1:
3799
+ _state.sent();
3800
+ _state.label = 2;
3801
+ case 2:
3802
+ return [
3803
+ 3,
3804
+ 4
3805
+ ];
3806
+ case 3:
3807
+ error = _state.sent();
3808
+ console.error('Error saving value for key "'.concat(key, '":'), error);
3809
+ return [
3810
+ 3,
3811
+ 4
3812
+ ];
3813
+ case 4:
3814
+ return [
3815
+ 2
3816
+ ];
3817
+ }
3818
+ });
3819
+ });
3820
+ return function saveValue() {
3821
+ return _ref.apply(this, arguments);
3822
+ };
3823
+ }();
3824
+ saveValue();
3825
+ }, [
3826
+ value,
3827
+ key,
3828
+ serializer2,
3829
+ isLoaded
3830
+ ]);
3831
+ var set = useCallback2(function(newValue) {
3832
+ setValue(function(prev) {
3833
+ return typeof newValue === "function" ? newValue(prev) : newValue;
3834
+ });
3835
+ }, []);
3836
+ var remove = useCallback2(/*#__PURE__*/ _async_to_generator(function() {
3837
+ var error;
3838
+ return _ts_generator(this, function(_state) {
3839
+ switch(_state.label){
3840
+ case 0:
3841
+ _state.trys.push([
3842
+ 0,
3843
+ 2,
3844
+ ,
3845
+ 3
3846
+ ]);
3847
+ return [
3848
+ 4,
3849
+ storageClient.remove(key)
3850
+ ];
3851
+ case 1:
3852
+ _state.sent();
3853
+ setValue(void 0);
3854
+ return [
3855
+ 3,
3856
+ 3
3857
+ ];
3858
+ case 2:
3859
+ error = _state.sent();
3860
+ console.error('Error removing key "'.concat(key, '":'), error);
3861
+ return [
3862
+ 3,
3863
+ 3
3864
+ ];
3865
+ case 3:
3866
+ return [
3867
+ 2
3868
+ ];
3869
+ }
3870
+ });
3871
+ }), [
3872
+ key
3873
+ ]);
3874
+ return {
3875
+ value: value,
3876
+ set: set,
3877
+ remove: remove
3878
+ };
3879
+ }
3880
+ // src/react/next-intl.tsx
3881
+ import { Fragment, jsx as jsx3 } from "react/jsx-runtime";
3882
+ var NextIntlContext = createContext2(void 0);
3883
+ function useNextIntl() {
3884
+ var context = use2(NextIntlContext);
3885
+ if (!context) {
3886
+ throw new Error("useNextIntl must be used within a NextIntlProvider");
3887
+ }
3888
+ return context;
3889
+ }
3890
+ var useTranslateNextIntl = useTranslations;
3891
+ function withNextIntl(Component) {
3892
+ var PageWithI18n = function(props) {
3893
+ var _languages_find;
3894
+ var currentLanguage = useNextIntl().currentLanguage;
3895
+ var messages = props.messages, languages = props.languages;
3896
+ var defaultLang = "en";
3897
+ var defaultMessages = messages[(currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang];
3898
+ var timeZone = (_languages_find = languages.find(function(lang) {
3899
+ return lang.value === (currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value);
3900
+ })) === null || _languages_find === void 0 ? void 0 : _languages_find.timezone;
3901
+ if (!messages) {
3902
+ console.warn("Missing messages for language: ".concat((currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang));
3903
+ return null;
3904
+ }
3905
+ return /* @__PURE__ */ jsx3(NextIntlClientProvider, {
3906
+ locale: (currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang,
3907
+ messages: defaultMessages,
3908
+ timeZone: timeZone,
3909
+ children: /* @__PURE__ */ jsx3(Component, _object_spread({}, props))
3910
+ });
3911
+ };
3912
+ PageWithI18n.displayName = "withNextIntl(".concat(Component.displayName || Component.name || "Component", ")");
3913
+ return PageWithI18n;
3914
+ }
3915
+ function LanguageWrapperBase(param) {
3916
+ var children = param.children;
3917
+ return /* @__PURE__ */ jsx3(Fragment, {
3918
+ children: children
3919
+ });
3920
+ }
3921
+ var LanguageWrapper = withNextIntl(LanguageWrapperBase);
3922
+ function NextIntlProvider(param) {
3923
+ var children = param.children, languages = param.languages, messages = param.messages;
3924
+ var _languages_;
3925
+ var _useStorage = useStorage("lang", (_languages_ = languages === null || languages === void 0 ? void 0 : languages[0]) !== null && _languages_ !== void 0 ? _languages_ : {}), value = _useStorage.value, set = _useStorage.set;
3926
+ var contextValue = useMemo2(function() {
3927
+ return {
3928
+ languages: languages,
3929
+ currentLanguage: value,
3930
+ setCurrentLanguage: set
3931
+ };
3932
+ }, [
3933
+ languages,
3934
+ set,
3935
+ value
3936
+ ]);
3937
+ return /* @__PURE__ */ jsx3(NextIntlContext, {
3938
+ value: contextValue,
3939
+ children: /* @__PURE__ */ jsx3(LanguageWrapper, {
3940
+ languages: languages,
3941
+ messages: messages,
3942
+ children: children
3943
+ })
3944
+ });
3945
+ }
3946
+ // src/typescript/mongo.ts
3947
+ import { Collection, Db } from "mongodb";
3948
+ import { Document as Document2, Model } from "mongoose";
3949
+ var C_Db = /*#__PURE__*/ function(Db) {
3950
+ "use strict";
3951
+ _inherits(C_Db, Db);
3952
+ function C_Db() {
3953
+ _class_call_check(this, C_Db);
3954
+ return _call_super(this, C_Db, arguments);
3955
+ }
3956
+ return C_Db;
3957
+ }(Db);
3958
+ var C_Document = /*#__PURE__*/ function(Document2) {
3959
+ "use strict";
3960
+ _inherits(C_Document, Document2);
3961
+ function C_Document() {
3962
+ _class_call_check(this, C_Document);
3963
+ return _call_super(this, C_Document, arguments);
3964
+ }
3965
+ return C_Document;
3966
+ }(Document2);
3967
+ var C_Model = /*#__PURE__*/ function(Model) {
3968
+ "use strict";
3969
+ _inherits(C_Model, Model);
3970
+ function C_Model() {
3971
+ _class_call_check(this, C_Model);
3972
+ return _call_super(this, C_Model, arguments);
3973
+ }
3974
+ return C_Model;
3975
+ }(Model);
3976
+ var C_Collection = /*#__PURE__*/ function(Collection) {
3977
+ "use strict";
3978
+ _inherits(C_Collection, Collection);
3979
+ function C_Collection() {
3980
+ _class_call_check(this, C_Collection);
3981
+ return _call_super(this, C_Collection, arguments);
3982
+ }
3983
+ return C_Collection;
3984
+ }(Collection);
3985
+ // src/utils/log.ts
3986
+ import { GraphQLError } from "graphql";
3987
+ function throwResponse(param) {
3988
+ var message = param.message, _param_status = param.status, status = _param_status === void 0 ? RESPONSE_STATUS.INTERNAL_SERVER_ERROR : _param_status, _param_type = param.type, type = _param_type === void 0 ? "graphql" : _param_type;
3989
+ var _ref;
3990
+ var responseMessage = (_ref = message !== null && message !== void 0 ? message : status.MESSAGE) !== null && _ref !== void 0 ? _ref : "Internal server error";
3991
+ if (type === "graphql") {
3992
+ throw new GraphQLError(responseMessage, {
3993
+ extensions: {
3994
+ code: status.CODE
3995
+ }
3996
+ });
3997
+ } else {
3998
+ throw new Error(responseMessage);
3999
+ }
4000
+ }
4001
+ // src/utils/common.ts
4002
+ import unorm from "unorm";
4003
+ function isJson(str) {
4004
+ try {
4005
+ JSON.parse(str);
4006
+ return true;
4007
+ } catch (e) {
4008
+ return false;
4009
+ }
4010
+ }
4011
+ var charMap = {
4012
+ a: [
4013
+ "\xE0",
4014
+ "\xE1",
4015
+ "\u1EA1",
4016
+ "\u1EA3",
4017
+ "\xE3",
4018
+ "\xE2",
4019
+ "\u1EA7",
4020
+ "\u1EA5",
4021
+ "\u1EAD",
4022
+ "\u1EA9",
4023
+ "\u1EAB",
4024
+ "\u0103",
4025
+ "\u1EB1",
4026
+ "\u1EAF",
4027
+ "\u1EB7",
4028
+ "\u1EB3",
4029
+ "\u1EB5"
4030
+ ],
4031
+ e: [
4032
+ "\xE8",
4033
+ "\xE9",
4034
+ "\u1EB9",
4035
+ "\u1EBB",
4036
+ "\u1EBD",
4037
+ "\xEA",
4038
+ "\u1EC1",
4039
+ "\u1EBF",
4040
+ "\u1EC7",
4041
+ "\u1EC3",
4042
+ "\u1EC5"
4043
+ ],
4044
+ i: [
4045
+ "\xEC",
4046
+ "\xED",
4047
+ "\u1ECB",
4048
+ "\u1EC9",
4049
+ "\u0129"
4050
+ ],
4051
+ o: [
4052
+ "\xF2",
4053
+ "\xF3",
4054
+ "\u1ECD",
4055
+ "\u1ECF",
4056
+ "\xF5",
4057
+ "\xF4",
4058
+ "\u1ED3",
4059
+ "\u1ED1",
4060
+ "\u1ED9",
4061
+ "\u1ED5",
4062
+ "\u1ED7",
4063
+ "\u01A1",
4064
+ "\u1EDD",
4065
+ "\u1EDB",
4066
+ "\u1EE3",
4067
+ "\u1EDF",
4068
+ "\u1EE1"
4069
+ ],
4070
+ u: [
4071
+ "\xF9",
4072
+ "\xFA",
4073
+ "\u1EE5",
4074
+ "\u1EE7",
4075
+ "\u0169",
4076
+ "\u01B0",
4077
+ "\u1EEB",
4078
+ "\u1EE9",
4079
+ "\u1EF1",
4080
+ "\u1EED",
4081
+ "\u1EEF"
4082
+ ],
4083
+ y: [
4084
+ "\u1EF3",
4085
+ "\xFD",
4086
+ "\u1EF5",
4087
+ "\u1EF7",
4088
+ "\u1EF9"
4089
+ ],
4090
+ d: [
4091
+ "\u0111"
4092
+ ]
4093
+ };
4094
+ var upperCharMap = Object.entries(charMap).reduce(function(map, param) {
4095
+ var _param = _sliced_to_array(param, 2), key = _param[0], value = _param[1];
4096
+ map[key.toUpperCase()] = value.map(function(char) {
4097
+ return char.toUpperCase();
4098
+ });
4099
+ return map;
4100
+ }, {});
4101
+ function regexSearchMapper(str) {
4102
+ str = unorm.nfkc(str);
4103
+ var combinedMap = _object_spread({}, charMap, upperCharMap);
4104
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
4105
+ try {
4106
+ for(var _iterator = Object.entries(combinedMap)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
4107
+ var _step_value = _sliced_to_array(_step.value, 2), baseChar = _step_value[0], variations = _step_value[1];
4108
+ var pattern = "[".concat(baseChar).concat(variations.join(""), "]");
4109
+ var replacement = "(".concat([
4110
+ baseChar
4111
+ ].concat(_to_consumable_array(variations)).join("|"), ")");
4112
+ str = str.replace(new RegExp(pattern, "g"), replacement);
4113
+ }
4114
+ } catch (err) {
4115
+ _didIteratorError = true;
4116
+ _iteratorError = err;
4117
+ } finally{
4118
+ try {
4119
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
4120
+ _iterator.return();
4121
+ }
4122
+ } finally{
4123
+ if (_didIteratorError) {
4124
+ throw _iteratorError;
4125
+ }
4126
+ }
4127
+ }
4128
+ return str;
4129
+ }
4130
+ function removeAccent(str) {
4131
+ return str.normalize("NFD").replace(RegExp("\\p{Diacritic}", "gu"), "");
4132
+ }
4133
+ export { ApolloProvider, BUILD_DIRECTORY, COMMAND, COMMIT_LINT_CLI, CYBERSKILL_CLI, CYBERSKILL_DIRECTORY, CYBERSKILL_PACKAGE_NAME, CYBERSKILL_STORAGE, C_Collection, C_Db, C_Document, C_Model, ESLINT_CLI, ESLINT_INSPECT_CLI, E_ErrorType, GIT_CLI, GIT_COMMIT_EDITMSG, GIT_HOOK, GIT_IGNORE, HOOK, LINT_STAGED_CLI, Loading, LoadingContext, LoadingProvider, MongoController, MongooseController, NODE_MODULES, NODE_MODULES_INSPECT_CLI, NextIntlContext, NextIntlProvider, PACKAGE_JSON, PACKAGE_LOCK_JSON, PATH, PNPM_CLI, PNPM_DLX_CLI, PNPM_EXEC_CLI, PNPM_LOCK_YAML, RESPONSE_STATUS, RIMRAF_CLI, SIMPLE_GIT_HOOK_CLI, SIMPLE_GIT_HOOK_JSON, TSCONFIG_JSON, TSC_CLI, TSX_CLI, VITEST_CLI, WORKING_DIRECTORY, aggregatePaginate, appendFileSync2 as appendFileSync, checkPackage, clearAllErrorLists, commandFormatter, commandLog, deepMerge, dirname2 as dirname, executeCommand, existsSync2 as existsSync, generateShortId, generateSlug, getLatestPackageVersion, getPackageJson, getStorageDir, getStoredErrorLists, initNodePersist, isJson, join2 as join, mongo, mongoosePaginate, readFileSync2 as readFileSync, regexSearchMapper, removeAccent, require2 as require, resolve2 as resolve, resolveCommands, resolveCyberSkillPath, resolveWorkingPath, saveErrorListToStorage, serializer, storageClient, storageServer, throwResponse, useLoading, useNextIntl, useStorage, useTranslateNextIntl, validate, withNextIntl, writeFileSync2 as writeFileSync };