@restforgejs/platform 5.3.5 → 5.3.7

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 (172) hide show
  1. package/bin/restforge-designer-linux +0 -0
  2. package/bin/restforge-designer.exe +0 -0
  3. package/build-info.json +2 -2
  4. package/cli/consumer-deploy.js +1 -1
  5. package/cli/consumer.js +1 -1
  6. package/cli/designer.js +3 -0
  7. package/generators/cli/fast-track.js +105 -34
  8. package/generators/lib/templates/dashboard-catalog.js +1 -1
  9. package/generators/lib/templates/db-connection-env.js +1 -1
  10. package/generators/lib/templates/dbschema-catalog.js +1 -1
  11. package/generators/lib/templates/field-validation-catalog.js +1 -1
  12. package/generators/lib/templates/mysql-template.js +1 -1
  13. package/generators/lib/templates/oracle-template.js +1 -1
  14. package/generators/lib/templates/postgres-template.js +1 -1
  15. package/generators/lib/templates/query-declarative-catalog.js +1 -1
  16. package/generators/lib/templates/sqlite-template.js +1 -1
  17. package/integrity-manifest.json +18 -18
  18. package/package.json +3 -2
  19. package/scripts/verify-integrity.js +1 -1
  20. package/server.js +1 -1
  21. package/src/components/handlers/adjust_handler.js +1 -1
  22. package/src/components/handlers/audit_handler.js +1 -1
  23. package/src/components/handlers/delete_handler.js +1 -1
  24. package/src/components/handlers/export_handler.js +1 -1
  25. package/src/components/handlers/import_handler.js +1 -1
  26. package/src/components/handlers/insert_handler.js +1 -1
  27. package/src/components/handlers/update_handler.js +1 -1
  28. package/src/components/handlers/upload_handler.js +1 -1
  29. package/src/components/handlers/workflow_handler.js +1 -1
  30. package/src/components/integrations/webhook.js +1 -1
  31. package/src/consumers/baseConsumer.js +1 -1
  32. package/src/consumers/declarativeMapper.js +1 -1
  33. package/src/consumers/handlers/apiHandler.js +1 -1
  34. package/src/consumers/handlers/consoleHandler.js +1 -1
  35. package/src/consumers/handlers/databaseHandler.js +1 -1
  36. package/src/consumers/handlers/index.js +1 -1
  37. package/src/consumers/handlers/kafkaHandler.js +1 -1
  38. package/src/consumers/index.js +1 -1
  39. package/src/consumers/messageTransformer.js +1 -1
  40. package/src/consumers/validator.js +1 -1
  41. package/src/core/db/dialect/base-dialect.js +1 -1
  42. package/src/core/db/dialect/index.js +1 -1
  43. package/src/core/db/dialect/mysql-dialect.js +1 -1
  44. package/src/core/db/dialect/oracle-dialect.js +1 -1
  45. package/src/core/db/dialect/postgres-dialect.js +1 -1
  46. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  47. package/src/core/db/flatten-helper.js +1 -1
  48. package/src/core/db/query-builder-error.js +1 -1
  49. package/src/core/db/query-builder.js +1 -1
  50. package/src/core/db/relation-helper.js +1 -1
  51. package/src/core/handlers/delete_handler.js +1 -1
  52. package/src/core/handlers/insert_handler.js +1 -1
  53. package/src/core/handlers/update_handler.js +1 -1
  54. package/src/core/models/base-model.js +1 -1
  55. package/src/core/utils/cache-manager.js +1 -1
  56. package/src/core/utils/component-engine.js +1 -1
  57. package/src/core/utils/context-builder.js +1 -1
  58. package/src/core/utils/datetime-formatter.js +1 -1
  59. package/src/core/utils/datetime-parser.js +1 -1
  60. package/src/core/utils/db.js +1 -1
  61. package/src/core/utils/logger.js +1 -1
  62. package/src/core/utils/payload-loader.js +1 -1
  63. package/src/core/utils/security-checks.js +1 -1
  64. package/src/middleware/body-options.js +1 -1
  65. package/src/middleware/cors.js +1 -1
  66. package/src/middleware/idempotency.js +1 -1
  67. package/src/middleware/rate-limiter.js +1 -1
  68. package/src/middleware/request-logger.js +1 -1
  69. package/src/middleware/security-headers.js +1 -1
  70. package/src/models/base-model-mysql.js +1 -1
  71. package/src/models/base-model-oracle.js +1 -1
  72. package/src/models/base-model-sqlite.js +1 -1
  73. package/src/models/base-model.js +1 -1
  74. package/src/pro/caching/redis-client.js +1 -1
  75. package/src/pro/caching/redis-helper.js +1 -1
  76. package/src/pro/consumers/baseConsumer.js +1 -1
  77. package/src/pro/consumers/declarativeMapper.js +1 -1
  78. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  79. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  80. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  81. package/src/pro/consumers/handlers/index.js +1 -1
  82. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  83. package/src/pro/consumers/index.js +1 -1
  84. package/src/pro/consumers/messageTransformer.js +1 -1
  85. package/src/pro/consumers/validator.js +1 -1
  86. package/src/pro/database/base-model-mysql.js +1 -1
  87. package/src/pro/database/base-model-oracle.js +1 -1
  88. package/src/pro/database/base-model-sqlite.js +1 -1
  89. package/src/pro/database/db-mysql.js +1 -1
  90. package/src/pro/database/db-oracle.js +1 -1
  91. package/src/pro/database/db-sqlite.js +1 -1
  92. package/src/pro/excel/excel-generator.js +1 -1
  93. package/src/pro/excel/excel-parser.js +1 -1
  94. package/src/pro/excel/export-service.js +1 -1
  95. package/src/pro/excel/export_handler.js +1 -1
  96. package/src/pro/excel/import-service.js +1 -1
  97. package/src/pro/excel/import-validator.js +1 -1
  98. package/src/pro/excel/import_handler.js +1 -1
  99. package/src/pro/excel/upsert-builder.js +1 -1
  100. package/src/pro/idgen/idgen-routes.js +1 -1
  101. package/src/pro/integrations/lookup-resolver.js +1 -1
  102. package/src/pro/integrations/upload-handler-v2.js +1 -1
  103. package/src/pro/integrations/upload-handler.js +1 -1
  104. package/src/pro/integrations/webhook.js +1 -1
  105. package/src/pro/locking/lock-routes.js +1 -1
  106. package/src/pro/locking/resource-lock-manager.js +1 -1
  107. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  108. package/src/pro/messaging/kafkaService.js +1 -1
  109. package/src/pro/messaging/messagehubService.js +1 -1
  110. package/src/pro/messaging/rabbitmqService.js +1 -1
  111. package/src/pro/scheduler/job-manager.js +1 -1
  112. package/src/pro/scheduler/job-routes.js +1 -1
  113. package/src/pro/scheduler/job-validator.js +1 -1
  114. package/src/pro/storage/base-storage-provider.js +1 -1
  115. package/src/pro/storage/file-metadata-helper.js +1 -1
  116. package/src/pro/storage/index.js +1 -1
  117. package/src/pro/storage/local-storage-provider.js +1 -1
  118. package/src/pro/storage/s3-storage-provider.js +1 -1
  119. package/src/pro/storage/upload-cleanup-job.js +1 -1
  120. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  121. package/src/pro/storage/upload-pending-tracker.js +1 -1
  122. package/src/pro/websocket/broadcast-helper.js +1 -1
  123. package/src/pro/websocket/index.js +1 -1
  124. package/src/pro/websocket/livesync-server.js +1 -1
  125. package/src/pro/websocket/ws-broadcaster.js +1 -1
  126. package/src/services/export-service.js +1 -1
  127. package/src/services/import-service.js +1 -1
  128. package/src/services/kafkaConsumerService.js +1 -1
  129. package/src/services/kafkaService.js +1 -1
  130. package/src/services/messagehubService.js +1 -1
  131. package/src/services/rabbitmqService.js +1 -1
  132. package/src/utils/cache-invalidation-registry.js +1 -1
  133. package/src/utils/cache-manager.js +1 -1
  134. package/src/utils/component-engine.js +1 -1
  135. package/src/utils/config-extractor.js +1 -1
  136. package/src/utils/consumerLogger.js +1 -1
  137. package/src/utils/context-builder.js +1 -1
  138. package/src/utils/dashboard-helpers.js +1 -1
  139. package/src/utils/dateHelper.js +1 -1
  140. package/src/utils/datetime-formatter.js +1 -1
  141. package/src/utils/datetime-parser.js +1 -1
  142. package/src/utils/db-bootstrap.js +1 -1
  143. package/src/utils/db-mysql.js +1 -1
  144. package/src/utils/db-oracle.js +1 -1
  145. package/src/utils/db-sqlite.js +1 -1
  146. package/src/utils/db.js +1 -1
  147. package/src/utils/demo-generator.js +1 -1
  148. package/src/utils/excel-generator.js +1 -1
  149. package/src/utils/excel-parser.js +1 -1
  150. package/src/utils/file-watcher.js +1 -1
  151. package/src/utils/id-generator.js +1 -1
  152. package/src/utils/idempotency-manager.js +1 -1
  153. package/src/utils/import-validator.js +1 -1
  154. package/src/utils/license-client.js +1 -1
  155. package/src/utils/lock-manager.js +1 -1
  156. package/src/utils/logger.js +1 -1
  157. package/src/utils/lookup-resolver.js +1 -1
  158. package/src/utils/payload-loader.js +1 -1
  159. package/src/utils/processor-response.js +1 -1
  160. package/src/utils/rabbitmq.js +1 -1
  161. package/src/utils/redis-client.js +1 -1
  162. package/src/utils/redis-helper.js +1 -1
  163. package/src/utils/request-scope.js +1 -1
  164. package/src/utils/security-checks.js +1 -1
  165. package/src/utils/service-resolver.js +1 -1
  166. package/src/utils/shutdown-coordinator.js +1 -1
  167. package/src/utils/soft-delete-dashboard-guard.js +1 -1
  168. package/src/utils/sql-table-extractor.js +1 -1
  169. package/src/utils/trusted-keys.js +1 -1
  170. package/src/utils/upload-handler.js +1 -1
  171. package/src/utils/upsert-builder.js +1 -1
  172. package/src/utils/workflow-hook-executor.js +1 -1
@@ -1 +1 @@
1
- const a0_0x4a5439=a0_0x4df1;(function(_0x37ee56,_0x2d4eb8){const _0x5ed142=a0_0x4df1,_0x43908e=_0x37ee56();while(!![]){try{const _0x470b56=-parseInt(_0x5ed142(0xcd))/0x1+parseInt(_0x5ed142(0xe3))/0x2*(parseInt(_0x5ed142(0xb7))/0x3)+-parseInt(_0x5ed142(0xac))/0x4*(-parseInt(_0x5ed142(0xaa))/0x5)+parseInt(_0x5ed142(0xe8))/0x6*(parseInt(_0x5ed142(0xc7))/0x7)+parseInt(_0x5ed142(0xe0))/0x8+parseInt(_0x5ed142(0xab))/0x9*(parseInt(_0x5ed142(0xb9))/0xa)+-parseInt(_0x5ed142(0xd2))/0xb*(parseInt(_0x5ed142(0x98))/0xc);if(_0x470b56===_0x2d4eb8)break;else _0x43908e['push'](_0x43908e['shift']());}catch(_0x7b11e1){_0x43908e['push'](_0x43908e['shift']());}}}(a0_0x17b1,0x534ad));function a0_0x17b1(){const _0x5cf029=['zurmu2m','mtK1nZeYmM14thvvwa','zgvIDwC','yNvPBgrmB2nRs2v5','tg9JAYbuveWGzxH0zw5Kzwq','v1jjveuGBg9JAYbYzwXLyxnLza','BgfZDeLUzgv4t2y','D29YA2vYswq','ChjLzML4','v1jjveuGBg9JAYbYzwPLy3rLzcaTihjLy29YzcbIDxn5','CgLK','uKvbrcbSB2nRigvYCM9Y','C2XLzxa','mJyXnLP3B1rdEq','v1jjveuGBg9JAYbLCNjVCG','zNrVAuO','z2v0','zxHWAxjL','zgvMyxvSDfruta','A01hEgy','tNPTDwi','ALzHyuG','x2rLzMf1BhruveW','Aw5JBhvKzxm','v1jjveuGBg9JAYbHy3f1AxjLzcaOCMvQzwn0ig1VzguP','De1pv3y','s0TAAw4','Bg9JA19JB25MAwDFAw5PDa','v1jjveuGBg9JAYbHy3f1AxjLzcaOCMv0CNKGBw9KzsK','zw52','ywnXDwLYzvDYAxrLtg9JAW','mJi0nZGZnunZBhLQEq','mtuYotCWm0fzzgjdzW','nfHQt0LLqG','D3jPDgu','x3n0CMf0zwD5','Bg9JA19LEhrLBMrLza','AxnfBMfIBgvK','te9ds19esvnuuKLcvvrfrf9srvrswq','zgvJCG','cIaGicaGicaGAwyGCMvKAxmUy2fSBcGIz2v0iIWGs0vzu1SXxsKGpt0GqvjhvLSXxsb0AgvUcIaGicaGicaGicbYzxr1CM4GCMvKAxmUy2fSBcGIzxHWAxjLiIWGs0vzu1SXxsWGqvjhvLSYxsKkicaGicaGicbLBhnLcIaGicaGicaGicbYzxr1CM4GmaOGicaGicaGigvUzaOGicaGica','D3jPDgvFBg9JA190Aw1LB3v0','CMy6Bg9JAZO','A0ncq3G','mtGYmuDQvKzVDq','D2fYBG','mtbjwLrKDvi','cIaGicaGicaGAwyGCMvKAxmUy2fSBcGIz2v0iIWGs0vzu1SXxsKGpt0GqvjhvLSXxsb0AgvUcIaGicaGicaGicbYzxr1CM4GCMvKAxmUy2fSBcGIzgvSiIWGs0vzu1SXxsKkicaGicaGicbLBhnLcIaGicaGicaGicbYzxr1CM4GmaOGicaGicaGigvUzaOGicaGica','CMvHzf9SB2nRx2vYCM9Y','z2v0q2XPzw50','sKXpBLC','u1zNC2q','uKvbrcbSB2nRigfJCxvPCMvK','D3jPDgvFBg9JA193ywL0Aw5N','x3bYzwzPEa','zxH0zw5Ktg9JAW','CMvHzf9SB2nRx3jLBgvHC2vK','Aw5MBW','x3jLDhj5q291BNq','CMvQzwn0','n1jADKHlAq','BwvZC2fNzq','DMnerxy','te9ds19esvnuuKLcvvrfrf9uveW','x2LUAxrdB25MAwC','x3jLDhj5rgvSyxK','mJy0odCYBfbLsM9L','Bg9JA19YzwXLyxnLx25VDf9VD25LCG','qw1SzxK','Cg93','zw5HyMXLza','nty0nZrYwMzcDgi','q2fUBM90ihjLBgvHC2uGBg9JAYaTig5VDcbVD25LCG','CMvHzf9SB2nRx2fJCxvPCMvK','C3vIC3rYAw5N','D3jPDgvFBg9JA19YzwXLyxnLza','x2vUywjSzwq','v2fPDgLUzYbMB3iGBg9JA3mGDg8GCMvSzwfZzq','z2v0tg9JA0LUzM8','CMv0CNLezwXHEq','v2fPDgLUzYbMB3iGv1jjveuGBg9JAYb0BYbYzwXLyxnL','x3DVCMTLCKLK','zxzHBa','CMvHza','tg9JAYbJB25MAwD1CMf0Aw9UigLUAxrPywXPEMvKic0Gzw5HyMXLzdOG','mJC0ndC2mgXwwgHMBG','v1jjveuGBg9JAYbHy3f1AxjLihrPBwvVDxq','x2vUC3vYzuLUAxrPywXPEMvK','mtqZohnrB1vfAq','zxjYB3i','BM93','t2nYzxO'];a0_0x17b1=function(){return _0x5cf029;};return a0_0x17b1();}function a0_0x4df1(_0x3d384c,_0x1ab866){_0x3d384c=_0x3d384c-0x8e;const _0x17b17e=a0_0x17b1();let _0x4df1ce=_0x17b17e[_0x3d384c];if(a0_0x4df1['UUaDSo']===undefined){var _0x269948=function(_0x1e64d6){const _0x376ea7='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x3295b7='',_0x2ac974='';for(let _0x2d7818=0x0,_0x3e8b42,_0x514c72,_0x2c92a7=0x0;_0x514c72=_0x1e64d6['charAt'](_0x2c92a7++);~_0x514c72&&(_0x3e8b42=_0x2d7818%0x4?_0x3e8b42*0x40+_0x514c72:_0x514c72,_0x2d7818++%0x4)?_0x3295b7+=String['fromCharCode'](0xff&_0x3e8b42>>(-0x2*_0x2d7818&0x6)):0x0){_0x514c72=_0x376ea7['indexOf'](_0x514c72);}for(let _0x1e2f81=0x0,_0x470118=_0x3295b7['length'];_0x1e2f81<_0x470118;_0x1e2f81++){_0x2ac974+='%'+('00'+_0x3295b7['charCodeAt'](_0x1e2f81)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2ac974);};a0_0x4df1['hiTLDU']=_0x269948,a0_0x4df1['kLUhYA']={},a0_0x4df1['UUaDSo']=!![];}const _0x2a08ea=_0x17b17e[0x0],_0x4036c4=_0x3d384c+_0x2a08ea,_0x30e259=a0_0x4df1['kLUhYA'][_0x4036c4];return!_0x30e259?(_0x4df1ce=a0_0x4df1['hiTLDU'](_0x4df1ce),a0_0x4df1['kLUhYA'][_0x4036c4]=_0x4df1ce):_0x4df1ce=_0x30e259,_0x4df1ce;}const redisClient=require('./redis-client'),{logger}=require('./logger'),{v4:uuidv4}=require('uuid');class LockManager{constructor(){const _0x28fd18=a0_0x4df1;this['_prefix']=null,this[_0x28fd18(0xd7)]=null,this[_0x28fd18(0xa1)]=null,this['_retryCount']=null,this['_retryDelay']=null,this[_0x28fd18(0xae)]=null,this['_workerId']=null,this['_initialized']=![];}['_initConfig'](){const _0x37237d=a0_0x4df1,_0x490ab6={'Nzmub':'true'};this['_prefix']=_0x37237d(0xb5),this[_0x37237d(0xd7)]=process['env']['LOCK_DISTRIBUTED_ENABLED']===_0x490ab6[_0x37237d(0x9f)],this['_defaultTTL']=parseInt(process['env'][_0x37237d(0xca)],0xa)||0xa,this[_0x37237d(0xc5)]=parseInt(process[_0x37237d(0xa8)][_0x37237d(0xb1)],0xa)||0x3,this[_0x37237d(0xcc)]=parseInt(process[_0x37237d(0xa8)]['LOCK_DISTRIBUTED_RETRY_DELAY'],0xa)||0x64,this['_strategy']=process[_0x37237d(0xa8)]['LOCK_DISTRIBUTED_STRATEGY']||'retry',this['_workerId']='worker-'+process[_0x37237d(0x95)],this['_initialized']=!![],logger[_0x37237d(0xc4)]({'event':_0x37237d(0xa6),'enabled':this[_0x37237d(0xd7)],'strategy':this['_strategy'],'ttl':this['_defaultTTL'],'retryCount':this[_0x37237d(0xc5)],'retryDelay':this['_retryDelay'],'workerId':this['_workerId']},_0x37237d(0xdf)+this['_enabled']+',\x20strategy:\x20'+this[_0x37237d(0xae)]);}['_ensureInitialized'](){const _0x3c8c86=a0_0x4df1;!this['_initialized']&&this[_0x3c8c86(0xcb)]();}get['prefix'](){const _0x3d34fb=a0_0x4df1;return this[_0x3d34fb(0xe2)](),this[_0x3d34fb(0xc1)];}get['enabled'](){const _0x59413b=a0_0x4df1;return this['_ensureInitialized'](),this[_0x59413b(0xd7)];}get['defaultTTL'](){const _0x261c88=a0_0x4df1;return this[_0x261c88(0xe2)](),this['_defaultTTL'];}get['retryCount'](){const _0x48d63f=a0_0x4df1;return this[_0x48d63f(0xe2)](),this[_0x48d63f(0xc5)];}get[a0_0x4a5439(0xda)](){return this['_ensureInitialized'](),this['_retryDelay'];}get['strategy'](){const _0xdaf72d=a0_0x4a5439;return this[_0xdaf72d(0xe2)](),this['_strategy'];}get[a0_0x4a5439(0x92)](){const _0x171c38=a0_0x4a5439;return this['_ensureInitialized'](),this[_0x171c38(0xdc)];}[a0_0x4a5439(0x8e)](_0x142cf2){const _0x2cb1d7=a0_0x4a5439,{module:_0x4e59e9,endpoint:_0x1aeaf2,lockType:_0x2463da,recordId:_0x2a5489}=_0x142cf2;if(_0x2a5489)return''+this[_0x2cb1d7(0x93)]+_0x4e59e9+':'+_0x1aeaf2+':'+_0x2a5489+':'+_0x2463da;return''+this['prefix']+_0x4e59e9+':'+_0x1aeaf2+':'+_0x2463da;}['generateLockValue'](){const _0x5edc69=a0_0x4a5439;return this['workerId']+':'+uuidv4()+':'+Date[_0x5edc69(0xe5)]();}async['acquireReadLock'](_0x411f25){const _0x579f7a=a0_0x4a5439,_0x380b9e={'SVgsd':_0x579f7a(0xbf),'ftoiJ':_0x579f7a(0xdb),'KKZin':function(_0x4c0170,_0x5d240c){return _0x4c0170*_0x5d240c;},'jVaaH':'READ\x20lock\x20acquire\x20timeout'};if(!this[_0x579f7a(0xd1)])return{'success':!![],'lockValue':null,'lockKey':null};const _0x2ca665=this[_0x579f7a(0x8e)]({..._0x411f25,'lockType':_0x579f7a(0xad)}),_0x2f017e=this[_0x579f7a(0x8e)]({..._0x411f25,'lockType':_0x579f7a(0xde)}),_0x19751e=this['generateLockValue']();try{const _0x12e6ca=redisClient[_0x579f7a(0xbc)]();for(let _0x121981=0x0;_0x121981<this['retryCount'];_0x121981++){const _0xdd7bf6=await _0x12e6ca['get'](_0x2ca665);if(!_0xdd7bf6){await _0x12e6ca['incr'](_0x2f017e),await _0x12e6ca[_0x579f7a(0x9c)](_0x2f017e,this['defaultTTL']);const _0x46134c=_0x2f017e+':'+_0x19751e;return await _0x12e6ca['setex'](_0x46134c,this[_0x579f7a(0x9d)],_0x19751e),logger['debug']({'event':_0x579f7a(0xd4),'key':_0x2f017e,'value':_0x19751e},_0x380b9e[_0x579f7a(0xbe)]),{'success':!![],'lockValue':_0x19751e,'lockKey':_0x46134c};}logger['debug']({'event':'read_lock_waiting','writeKey':_0x2ca665,'attempt':_0x121981},_0x380b9e[_0x579f7a(0x9a)]),await this[_0x579f7a(0x97)](_0x380b9e[_0x579f7a(0xa5)](this[_0x579f7a(0xda)],Math[_0x579f7a(0xd0)](0x2,_0x121981)));}return logger['warn']({'event':'read_lock_timeout','key':_0x2f017e},_0x380b9e[_0x579f7a(0xa0)]),{'success':![],'lockValue':null,'lockKey':null};}catch(_0xd7c14f){return logger['error']({'event':_0x579f7a(0xbb),'error':_0xd7c14f['message']},_0x579f7a(0x96)),{'success':![],'lockValue':null,'lockKey':null};}}async[a0_0x4a5439(0xa9)](_0x7c8fea){const _0x3e798a=a0_0x4a5439,_0x4cf4ed={'bjwEf':'write','ZLCEI':_0x3e798a(0xc6),'phPsx':_0x3e798a(0xa3),'NeRDI':_0x3e798a(0x94),'Amley':function(_0x3abfa6,_0x286aa4){return _0x3abfa6(_0x286aa4);},'kCBCx':function(_0x5bb272,_0x3d9c24){return _0x5bb272===_0x3d9c24;},'kMGxf':'write_lock_acquired','vcDEv':'retry','jcmwT':_0x3e798a(0xd8),'pDGGK':function(_0x44285e,_0x5c0093){return _0x44285e*_0x5c0093;},'Ocrez':_0x3e798a(0x99)};if(!this[_0x3e798a(0xd1)])return{'success':!![],'lockValue':null,'lockKey':null};const _0xf09275=this['buildLockKey']({..._0x7c8fea,'lockType':_0x4cf4ed['bjwEf']}),_0x159049=this[_0x3e798a(0x8e)]({..._0x7c8fea,'lockType':_0x3e798a(0xde)}),_0x1cee7a=this['generateLockValue']();try{const _0x18a1ee=redisClient[_0x3e798a(0xbc)]();if(this['strategy']===_0x3e798a(0xc6)){const _0xee3bec=await _0x18a1ee['set'](_0xf09275,_0x1cee7a,'EX',this[_0x3e798a(0x9d)],'NX');if(_0xee3bec==='OK')return logger[_0x3e798a(0xe9)]({'event':'write_lock_acquired','key':_0xf09275,'value':_0x1cee7a,'strategy':_0x4cf4ed['ZLCEI']},_0x4cf4ed['phPsx']),{'success':!![],'lockValue':_0x1cee7a,'lockKey':_0xf09275};return logger[_0x3e798a(0xe9)]({'event':'write_lock_rejected','key':_0xf09275},_0x4cf4ed['NeRDI']),{'success':![],'lockValue':null,'lockKey':null};}for(let _0x519582=0x0;_0x519582<this['retryCount'];_0x519582++){const [_0x558911,_0x224386]=await Promise['all']([_0x18a1ee[_0x3e798a(0x9b)](_0x159049),_0x18a1ee[_0x3e798a(0x9b)](_0xf09275)]);if(!_0x224386&&(!_0x558911||_0x4cf4ed[_0x3e798a(0xcf)](parseInt,_0x558911)===0x0)){const _0x5ca96f=await _0x18a1ee['set'](_0xf09275,_0x1cee7a,'EX',this[_0x3e798a(0x9d)],'NX');if(_0x4cf4ed[_0x3e798a(0xb6)](_0x5ca96f,'OK'))return logger['debug']({'event':_0x4cf4ed[_0x3e798a(0x9e)],'key':_0xf09275,'value':_0x1cee7a,'strategy':_0x4cf4ed[_0x3e798a(0xc9)]},_0x3e798a(0xa7)),{'success':!![],'lockValue':_0x1cee7a,'lockKey':_0xf09275};}logger[_0x3e798a(0xe9)]({'event':_0x3e798a(0xc0),'writeKey':_0xf09275,'readCount':_0x558911,'attempt':_0x519582},_0x4cf4ed['jcmwT']),await this[_0x3e798a(0x97)](_0x4cf4ed['pDGGK'](this['retryDelay'],Math['pow'](0x2,_0x519582)));}return logger[_0x3e798a(0xb8)]({'event':_0x3e798a(0xb4),'key':_0xf09275},_0x3e798a(0xe1)),{'success':![],'lockValue':null,'lockKey':null};}catch(_0x5df93d){return logger['error']({'event':'write_lock_error','error':_0x5df93d[_0x3e798a(0xc8)]},_0x4cf4ed[_0x3e798a(0xe6)]),{'success':![],'lockValue':null,'lockKey':null};}}async['releaseLock'](_0x16b111,_0x263918){const _0x853a39=a0_0x4a5439,_0x4dc32b={'QmEsp':function(_0x411905,_0x57a0a5){return _0x411905>_0x57a0a5;},'tMOWv':'READ\x20lock\x20released','DhCjf':function(_0x37fca4,_0x13596d){return _0x37fca4===_0x13596d;},'FCLIt':_0x853a39(0x90),'JLOnW':'lock_release_error'};if(!this[_0x853a39(0xd1)]||!_0x16b111)return!![];try{const _0x5d19a0=redisClient[_0x853a39(0xbc)]();if(_0x16b111[_0x853a39(0xa2)](':read:')){await _0x5d19a0['del'](_0x16b111);const _0x107c32=_0x16b111[_0x853a39(0xd5)](0x0,_0x16b111[_0x853a39(0x91)](':')),_0xb1e9e=await _0x5d19a0[_0x853a39(0x9b)](_0x107c32);return _0xb1e9e&&_0x4dc32b['QmEsp'](parseInt(_0xb1e9e),0x0)&&await _0x5d19a0[_0x853a39(0xb2)](_0x107c32),logger[_0x853a39(0xe9)]({'event':_0x853a39(0xc3),'key':_0x16b111},_0x4dc32b[_0x853a39(0xa4)]),!![];}const _0x2a03fc=_0x853a39(0xba),_0x4220b1=await _0x5d19a0[_0x853a39(0xdd)](_0x2a03fc,0x1,_0x16b111,_0x263918);if(_0x4dc32b['DhCjf'](_0x4220b1,0x1))return logger['debug']({'event':_0x853a39(0xd6),'key':_0x16b111},_0x4dc32b['FCLIt']),!![];return logger['warn']({'event':_0x853a39(0xce),'key':_0x16b111},_0x853a39(0xd3)),![];}catch(_0x3a5e4d){return logger[_0x853a39(0xe4)]({'event':_0x4dc32b[_0x853a39(0xbd)],'key':_0x16b111,'error':_0x3a5e4d['message']},'Lock\x20release\x20error'),![];}}async[a0_0x4a5439(0xc2)](_0x7e0b91,_0xd3148d,_0x3745a2=null){const _0x528a4e=a0_0x4a5439,_0x1044c9={'RHJnF':function(_0x2a9bdc,_0x47994e){return _0x2a9bdc===_0x47994e;},'BDAGS':_0x528a4e(0xaf),'eDLSc':_0x528a4e(0x8f),'UddCx':'lock_extend_error','YSNSH':'Lock\x20extend\x20error'};if(!this['enabled']||!_0x7e0b91)return!![];try{const _0x1060a7=redisClient['getClient'](),_0x3a997e=_0x528a4e(0xb3),_0x5a9286=await _0x1060a7[_0x528a4e(0xdd)](_0x3a997e,0x1,_0x7e0b91,_0xd3148d,_0x3745a2||this[_0x528a4e(0x9d)]);if(_0x1044c9['RHJnF'](_0x5a9286,0x1))return logger['debug']({'event':_0x1044c9['BDAGS'],'key':_0x7e0b91,'ttl':_0x3745a2||this[_0x528a4e(0x9d)]},_0x1044c9[_0x528a4e(0xe7)]),!![];return![];}catch(_0xb663d1){return logger[_0x528a4e(0xe4)]({'event':_0x1044c9['UddCx'],'key':_0x7e0b91,'error':_0xb663d1['message']},_0x1044c9['YSNSH']),![];}}[a0_0x4a5439(0xb0)](){const _0x33f265=a0_0x4a5439;return this[_0x33f265(0xd1)];}[a0_0x4a5439(0x97)](_0x559660){return new Promise(_0x359fab=>setTimeout(_0x359fab,_0x559660));}async[a0_0x4a5439(0xd9)](_0x5a6616){const _0x53117b=a0_0x4a5439,_0x4ecd5b={'RNeAP':'write','JlOaf':function(_0x7149b2,_0x2f8eda){return _0x7149b2||_0x2f8eda;},'BQSEm':function(_0x4fe5e0,_0x29eab4){return _0x4fe5e0(_0x29eab4);}};if(!this[_0x53117b(0xd1)])return{'enabled':![]};try{const _0x5a9c5d=redisClient[_0x53117b(0xbc)](),_0x2fbfb3=this[_0x53117b(0x8e)]({..._0x5a6616,'lockType':_0x4ecd5b['RNeAP']}),_0x2bb243=this['buildLockKey']({..._0x5a6616,'lockType':'read'}),[_0x4fa790,_0x2adcf0]=await Promise['all']([_0x5a9c5d[_0x53117b(0x9b)](_0x2fbfb3),_0x5a9c5d[_0x53117b(0x9b)](_0x2bb243)]);return{'enabled':!![],'writeLock':_0x4ecd5b['JlOaf'](_0x4fa790,null),'readCount':_0x4ecd5b['BQSEm'](parseInt,_0x2adcf0)||0x0,'writeKey':_0x2fbfb3,'readKey':_0x2bb243};}catch(_0x20261a){return{'enabled':!![],'error':_0x20261a['message']};}}}module['exports']=new LockManager();
1
+ const a0_0x1834cf=a0_0x1a31;(function(_0xb57c1a,_0x4bbfd1){const _0x1a3f99=a0_0x1a31,_0x6bd0d5=_0xb57c1a();while(!![]){try{const _0x30eeae=-parseInt(_0x1a3f99(0x13a))/0x1*(-parseInt(_0x1a3f99(0x165))/0x2)+parseInt(_0x1a3f99(0x18a))/0x3*(parseInt(_0x1a3f99(0x16d))/0x4)+-parseInt(_0x1a3f99(0x185))/0x5+-parseInt(_0x1a3f99(0x182))/0x6*(-parseInt(_0x1a3f99(0x16f))/0x7)+parseInt(_0x1a3f99(0x15e))/0x8*(-parseInt(_0x1a3f99(0x14d))/0x9)+-parseInt(_0x1a3f99(0x15d))/0xa+-parseInt(_0x1a3f99(0x17f))/0xb;if(_0x30eeae===_0x4bbfd1)break;else _0x6bd0d5['push'](_0x6bd0d5['shift']());}catch(_0x3a61a){_0x6bd0d5['push'](_0x6bd0d5['shift']());}}}(a0_0x33f3,0xba67f));const redisClient=require(a0_0x1834cf(0x136)),{logger}=require(a0_0x1834cf(0x13f)),{v4:uuidv4}=require('uuid');class LockManager{constructor(){const _0x6ec259=a0_0x1834cf,_0x58fbd8={'dfFIh':'4|1|6|0|5|3|2|7'},_0x132b5f=_0x58fbd8['dfFIh']['split']('|');let _0x2d54c1=0x0;while(!![]){switch(_0x132b5f[_0x2d54c1++]){case'0':this[_0x6ec259(0x15c)]=null;continue;case'1':this['_enabled']=null;continue;case'2':this['_workerId']=null;continue;case'3':this['_strategy']=null;continue;case'4':this[_0x6ec259(0x159)]=null;continue;case'5':this['_retryDelay']=null;continue;case'6':this[_0x6ec259(0x15b)]=null;continue;case'7':this[_0x6ec259(0x167)]=![];continue;}break;}}[a0_0x1834cf(0x180)](){const _0x54452a=a0_0x1834cf,_0x142b91={'aphey':'rf:lock:','sQWWD':function(_0x418fca,_0x5082f5,_0x1c8dc5){return _0x418fca(_0x5082f5,_0x1c8dc5);},'kSddJ':function(_0x2efdad,_0x2ea569,_0x15a93d){return _0x2efdad(_0x2ea569,_0x15a93d);}};this[_0x54452a(0x159)]=_0x142b91[_0x54452a(0x18b)],this[_0x54452a(0x13c)]=process[_0x54452a(0x158)][_0x54452a(0x178)]===_0x54452a(0x161),this[_0x54452a(0x15b)]=_0x142b91['sQWWD'](parseInt,process['env'][_0x54452a(0x17d)],0xa)||0xa,this['_retryCount']=_0x142b91['kSddJ'](parseInt,process['env']['LOCK_DISTRIBUTED_RETRY'],0xa)||0x3,this[_0x54452a(0x17a)]=parseInt(process[_0x54452a(0x158)]['LOCK_DISTRIBUTED_RETRY_DELAY'],0xa)||0x64,this['_strategy']=process['env']['LOCK_DISTRIBUTED_STRATEGY']||'retry',this[_0x54452a(0x138)]='worker-'+process[_0x54452a(0x169)],this[_0x54452a(0x167)]=!![],logger[_0x54452a(0x183)]({'event':'lock_config_init','enabled':this['_enabled'],'strategy':this['_strategy'],'ttl':this[_0x54452a(0x15b)],'retryCount':this[_0x54452a(0x15c)],'retryDelay':this[_0x54452a(0x17a)],'workerId':this[_0x54452a(0x138)]},_0x54452a(0x18c)+this[_0x54452a(0x13c)]+_0x54452a(0x142)+this[_0x54452a(0x186)]);}['_ensureInitialized'](){!this['_initialized']&&this['_initConfig']();}get[a0_0x1834cf(0x189)](){const _0xa4ab78=a0_0x1834cf;return this[_0xa4ab78(0x151)](),this[_0xa4ab78(0x159)];}get['enabled'](){const _0x45b22b=a0_0x1834cf;return this['_ensureInitialized'](),this[_0x45b22b(0x13c)];}get[a0_0x1834cf(0x137)](){const _0x559437=a0_0x1834cf;return this['_ensureInitialized'](),this[_0x559437(0x15b)];}get[a0_0x1834cf(0x160)](){return this['_ensureInitialized'](),this['_retryCount'];}get['retryDelay'](){const _0x2b228f=a0_0x1834cf;return this['_ensureInitialized'](),this[_0x2b228f(0x17a)];}get[a0_0x1834cf(0x176)](){const _0x8a8aee=a0_0x1834cf;return this[_0x8a8aee(0x151)](),this[_0x8a8aee(0x186)];}get[a0_0x1834cf(0x179)](){const _0x238cbe=a0_0x1834cf;return this['_ensureInitialized'](),this[_0x238cbe(0x138)];}['buildLockKey'](_0x3a7900){const _0x35e824=a0_0x1834cf,{module:_0x55b3ed,endpoint:_0x4e4c82,lockType:_0x2d920c,recordId:_0x30131f}=_0x3a7900;if(_0x30131f)return''+this[_0x35e824(0x189)]+_0x55b3ed+':'+_0x4e4c82+':'+_0x30131f+':'+_0x2d920c;return''+this[_0x35e824(0x189)]+_0x55b3ed+':'+_0x4e4c82+':'+_0x2d920c;}['generateLockValue'](){const _0xb502ab=a0_0x1834cf;return this[_0xb502ab(0x179)]+':'+uuidv4()+':'+Date[_0xb502ab(0x172)]();}async[a0_0x1834cf(0x174)](_0x105d3c){const _0x142e06=a0_0x1834cf,_0x2f05b0={'xfSzF':'read_lock_acquired','JTFcF':_0x142e06(0x141),'UnhyC':_0x142e06(0x14c),'azVXd':'read_lock_timeout','TpDof':'READ\x20lock\x20acquire\x20timeout','Ndxad':'read_lock_error','RWKCE':'READ\x20lock\x20error'};if(!this[_0x142e06(0x15f)])return{'success':!![],'lockValue':null,'lockKey':null};const _0x2e96ce=this[_0x142e06(0x156)]({..._0x105d3c,'lockType':'write'}),_0x27112=this[_0x142e06(0x156)]({..._0x105d3c,'lockType':'read'}),_0x2e7fea=this[_0x142e06(0x17c)]();try{const _0x52f49c=redisClient[_0x142e06(0x177)]();for(let _0x164e23=0x0;_0x164e23<this[_0x142e06(0x160)];_0x164e23++){const _0x40dfde=await _0x52f49c[_0x142e06(0x13e)](_0x2e96ce);if(!_0x40dfde){await _0x52f49c[_0x142e06(0x168)](_0x27112),await _0x52f49c['expire'](_0x27112,this[_0x142e06(0x137)]);const _0x394191=_0x27112+':'+_0x2e7fea;return await _0x52f49c[_0x142e06(0x16c)](_0x394191,this['defaultTTL'],_0x2e7fea),logger[_0x142e06(0x187)]({'event':_0x2f05b0['xfSzF'],'key':_0x27112,'value':_0x2e7fea},_0x142e06(0x171)),{'success':!![],'lockValue':_0x2e7fea,'lockKey':_0x394191};}logger['debug']({'event':_0x2f05b0['JTFcF'],'writeKey':_0x2e96ce,'attempt':_0x164e23},_0x2f05b0[_0x142e06(0x157)]),await this[_0x142e06(0x145)](this[_0x142e06(0x14b)]*Math[_0x142e06(0x175)](0x2,_0x164e23));}return logger[_0x142e06(0x139)]({'event':_0x2f05b0['azVXd'],'key':_0x27112},_0x2f05b0['TpDof']),{'success':![],'lockValue':null,'lockKey':null};}catch(_0x4d5f9f){return logger[_0x142e06(0x149)]({'event':_0x2f05b0['Ndxad'],'error':_0x4d5f9f[_0x142e06(0x184)]},_0x2f05b0['RWKCE']),{'success':![],'lockValue':null,'lockKey':null};}}async['acquireWriteLock'](_0x59cf39){const _0x1a31d5=a0_0x1834cf,_0x623d9c={'IlSem':'write','YwBtN':_0x1a31d5(0x16b),'tfrUS':function(_0x24b9b6,_0x18f5c5){return _0x24b9b6===_0x18f5c5;},'fBLiX':_0x1a31d5(0x162),'yokdl':_0x1a31d5(0x14f),'HVeYb':_0x1a31d5(0x147),'NghRo':function(_0xd82c79,_0x797556){return _0xd82c79===_0x797556;},'OWYGO':'retry','seoFM':_0x1a31d5(0x143),'tItpy':function(_0x3cadd7,_0x52871e){return _0x3cadd7*_0x52871e;},'OOTDF':_0x1a31d5(0x152)};if(!this['enabled'])return{'success':!![],'lockValue':null,'lockKey':null};const _0x3e8df4=this['buildLockKey']({..._0x59cf39,'lockType':_0x623d9c[_0x1a31d5(0x166)]}),_0x56be73=this['buildLockKey']({..._0x59cf39,'lockType':_0x623d9c['YwBtN']}),_0x40a92a=this['generateLockValue']();try{const _0x39b66a=redisClient[_0x1a31d5(0x177)]();if(this['strategy']===_0x1a31d5(0x14f)){const _0x2a8652=await _0x39b66a['set'](_0x3e8df4,_0x40a92a,'EX',this[_0x1a31d5(0x137)],'NX');if(_0x623d9c[_0x1a31d5(0x16e)](_0x2a8652,'OK'))return logger[_0x1a31d5(0x187)]({'event':_0x623d9c['fBLiX'],'key':_0x3e8df4,'value':_0x40a92a,'strategy':_0x623d9c[_0x1a31d5(0x181)]},_0x1a31d5(0x150)),{'success':!![],'lockValue':_0x40a92a,'lockKey':_0x3e8df4};return logger['debug']({'event':_0x1a31d5(0x188),'key':_0x3e8df4},_0x623d9c[_0x1a31d5(0x134)]),{'success':![],'lockValue':null,'lockKey':null};}for(let _0x5949e7=0x0;_0x5949e7<this[_0x1a31d5(0x160)];_0x5949e7++){const [_0x133057,_0xf73014]=await Promise['all']([_0x39b66a[_0x1a31d5(0x13e)](_0x56be73),_0x39b66a['get'](_0x3e8df4)]);if(!_0xf73014&&(!_0x133057||_0x623d9c[_0x1a31d5(0x16e)](parseInt(_0x133057),0x0))){const _0x569d6d=await _0x39b66a['set'](_0x3e8df4,_0x40a92a,'EX',this[_0x1a31d5(0x137)],'NX');if(_0x623d9c['NghRo'](_0x569d6d,'OK'))return logger[_0x1a31d5(0x187)]({'event':_0x1a31d5(0x162),'key':_0x3e8df4,'value':_0x40a92a,'strategy':_0x623d9c['OWYGO']},_0x1a31d5(0x146)),{'success':!![],'lockValue':_0x40a92a,'lockKey':_0x3e8df4};}logger['debug']({'event':_0x1a31d5(0x173),'writeKey':_0x3e8df4,'readCount':_0x133057,'attempt':_0x5949e7},_0x623d9c['seoFM']),await this['sleep'](_0x623d9c[_0x1a31d5(0x13b)](this[_0x1a31d5(0x14b)],Math['pow'](0x2,_0x5949e7)));}return logger[_0x1a31d5(0x139)]({'event':_0x623d9c[_0x1a31d5(0x153)],'key':_0x3e8df4},_0x1a31d5(0x135)),{'success':![],'lockValue':null,'lockKey':null};}catch(_0x21ec87){return logger['error']({'event':_0x1a31d5(0x133),'error':_0x21ec87['message']},'WRITE\x20lock\x20error'),{'success':![],'lockValue':null,'lockKey':null};}}async[a0_0x1834cf(0x17b)](_0xca308a,_0x1e92eb){const _0x315b67=a0_0x1834cf,_0x90b0fa={'naZOi':':read:','rqXLV':'read_lock_released','qwTZV':function(_0x33c888,_0xfe727e){return _0x33c888===_0xfe727e;},'GofVA':'WRITE\x20lock\x20released','Owmgc':_0x315b67(0x148),'KUCsb':_0x315b67(0x154),'xUTBB':_0x315b67(0x170)};if(!this['enabled']||!_0xca308a)return!![];try{const _0xf46375=redisClient['getClient']();if(_0xca308a[_0x315b67(0x17e)](_0x90b0fa[_0x315b67(0x144)])){await _0xf46375['del'](_0xca308a);const _0x327606=_0xca308a['substring'](0x0,_0xca308a['lastIndexOf'](':')),_0x14fff0=await _0xf46375['get'](_0x327606);return _0x14fff0&&parseInt(_0x14fff0)>0x0&&await _0xf46375[_0x315b67(0x15a)](_0x327606),logger[_0x315b67(0x187)]({'event':_0x90b0fa['rqXLV'],'key':_0xca308a},'READ\x20lock\x20released'),!![];}const _0xb4beb6='\x0a\x20\x20\x20\x20\x20\x20\x20\x20if\x20redis.call(\x22get\x22,\x20KEYS[1])\x20==\x20ARGV[1]\x20then\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20return\x20redis.call(\x22del\x22,\x20KEYS[1])\x0a\x20\x20\x20\x20\x20\x20\x20\x20else\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20return\x200\x0a\x20\x20\x20\x20\x20\x20\x20\x20end\x0a\x20\x20\x20\x20\x20\x20',_0x2276d8=await _0xf46375['eval'](_0xb4beb6,0x1,_0xca308a,_0x1e92eb);if(_0x90b0fa[_0x315b67(0x14e)](_0x2276d8,0x1))return logger[_0x315b67(0x187)]({'event':'write_lock_released','key':_0xca308a},_0x90b0fa[_0x315b67(0x163)]),!![];return logger[_0x315b67(0x139)]({'event':_0x90b0fa['Owmgc'],'key':_0xca308a},_0x90b0fa['KUCsb']),![];}catch(_0x11ba28){return logger['error']({'event':'lock_release_error','key':_0xca308a,'error':_0x11ba28[_0x315b67(0x184)]},_0x90b0fa[_0x315b67(0x155)]),![];}}async['extendLock'](_0x22baa7,_0x5b3b57,_0x2db277=null){const _0x1f7ca0=a0_0x1834cf,_0x58812e={'MSKxB':function(_0x38bb45,_0x286deb){return _0x38bb45===_0x286deb;},'FvIta':'lock_extended','XGARO':_0x1f7ca0(0x13d),'qmduO':_0x1f7ca0(0x18d)};if(!this[_0x1f7ca0(0x15f)]||!_0x22baa7)return!![];try{const _0x1ffc54=redisClient['getClient'](),_0x5cf0c8=_0x1f7ca0(0x16a),_0x3997c7=await _0x1ffc54['eval'](_0x5cf0c8,0x1,_0x22baa7,_0x5b3b57,_0x2db277||this[_0x1f7ca0(0x137)]);if(_0x58812e['MSKxB'](_0x3997c7,0x1))return logger['debug']({'event':_0x58812e[_0x1f7ca0(0x132)],'key':_0x22baa7,'ttl':_0x2db277||this[_0x1f7ca0(0x137)]},_0x58812e[_0x1f7ca0(0x164)]),!![];return![];}catch(_0x1856b0){return logger['error']({'event':'lock_extend_error','key':_0x22baa7,'error':_0x1856b0[_0x1f7ca0(0x184)]},_0x58812e['qmduO']),![];}}['isEnabled'](){return this['enabled'];}['sleep'](_0x2e36d7){return new Promise(_0x50a81b=>setTimeout(_0x50a81b,_0x2e36d7));}async['getLockInfo'](_0x598581){const _0x975c2c=a0_0x1834cf,_0x13f29b={'NZpZI':function(_0x410167,_0x19987b){return _0x410167(_0x19987b);}};if(!this['enabled'])return{'enabled':![]};try{const _0x30c623=redisClient['getClient'](),_0x43973c=this['buildLockKey']({..._0x598581,'lockType':_0x975c2c(0x14a)}),_0x146a48=this['buildLockKey']({..._0x598581,'lockType':'read'}),[_0x318229,_0x165a4a]=await Promise['all']([_0x30c623[_0x975c2c(0x13e)](_0x43973c),_0x30c623[_0x975c2c(0x13e)](_0x146a48)]);return{'enabled':!![],'writeLock':_0x318229||null,'readCount':_0x13f29b[_0x975c2c(0x140)](parseInt,_0x165a4a)||0x0,'writeKey':_0x43973c,'readKey':_0x146a48};}catch(_0x388892){return{'enabled':!![],'error':_0x388892['message']};}}}function a0_0x1a31(_0x4a5ad7,_0x2f22dc){_0x4a5ad7=_0x4a5ad7-0x132;const _0x33f38a=a0_0x33f3();let _0x1a314b=_0x33f38a[_0x4a5ad7];if(a0_0x1a31['HEJgaH']===undefined){var _0x141368=function(_0xd1e4b0){const _0x14a894='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x244e65='',_0x5e7b5a='';for(let _0x27c37e=0x0,_0x42d05a,_0x122088,_0xc444=0x0;_0x122088=_0xd1e4b0['charAt'](_0xc444++);~_0x122088&&(_0x42d05a=_0x27c37e%0x4?_0x42d05a*0x40+_0x122088:_0x122088,_0x27c37e++%0x4)?_0x244e65+=String['fromCharCode'](0xff&_0x42d05a>>(-0x2*_0x27c37e&0x6)):0x0){_0x122088=_0x14a894['indexOf'](_0x122088);}for(let _0x55ed77=0x0,_0x5ce992=_0x244e65['length'];_0x55ed77<_0x5ce992;_0x55ed77++){_0x5e7b5a+='%'+('00'+_0x244e65['charCodeAt'](_0x55ed77)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x5e7b5a);};a0_0x1a31['oyMlvu']=_0x141368,a0_0x1a31['yPSWDS']={},a0_0x1a31['HEJgaH']=!![];}const _0x1182aa=_0x33f38a[0x0],_0x93c0cf=_0x4a5ad7+_0x1182aa,_0x5ad8bb=a0_0x1a31['yPSWDS'][_0x93c0cf];return!_0x5ad8bb?(_0x1a314b=a0_0x1a31['oyMlvu'](_0x1a314b),a0_0x1a31['yPSWDS'][_0x93c0cf]=_0x1a314b):_0x1a314b=_0x5ad8bb,_0x1a314b;}module['exports']=new LockManager();function a0_0x33f3(){const _0x246b86=['v2fPDgLUzYbMB3iGv1jjveuGBg9JAYb0BYbYzwXLyxnL','mtyZmtC5CxLTwMLI','CxDuwLy','CMvQzwn0','v1jjveuGBg9JAYbHy3f1AxjLzcaOCMvQzwn0ig1VzguP','x2vUC3vYzuLUAxrPywXPEMvK','D3jPDgvFBg9JA190Aw1LB3v0','t09urey','q2fUBM90ihjLBgvHC2uGBg9JAYaTig5VDcbVD25LCG','EfvuqKi','yNvPBgrmB2nRs2v5','vw5OEum','zw52','x3bYzwzPEa','zgvJCG','x2rLzMf1BhruveW','x3jLDhj5q291BNq','mJCWotG1mgzNwvv5sW','odbIsKvdzwG','zw5HyMXLza','CMv0CNLdB3vUDa','Dhj1zq','D3jPDgvFBg9JA19Hy3f1AxjLza','r29MvKe','weDbuK8','mtm0mZzVz2XKruS','swXtzw0','x2LUAxrPywXPEMvK','Aw5JCG','CgLK','cIaGicaGicaGAwyGCMvKAxmUy2fSBcGIz2v0iIWGs0vzu1SXxsKGpt0GqvjhvLSXxsb0AgvUcIaGicaGicaGicbYzxr1CM4GCMvKAxmUy2fSBcGIzxHWAxjLiIWGs0vzu1SXxsWGqvjhvLSYxsKkicaGicaGicbLBhnLcIaGicaGicaGicbYzxr1CM4GmaOGicaGicaGigvUzaOGicaGica','CMvHza','C2v0zxG','mJaZmJblqNncsge','DgzYvvm','mZmYnZuYzhjmueHN','tg9JAYbYzwXLyxnLigvYCM9Y','uKvbrcbSB2nRigfJCxvPCMvK','BM93','D3jPDgvFBg9JA193ywL0Aw5N','ywnXDwLYzvjLywrmB2nR','Cg93','C3rYyxrLz3K','z2v0q2XPzw50','te9ds19esvnuuKLcvvrfrf9ftKfcteve','D29YA2vYswq','x3jLDhj5rgvSyxK','CMvSzwfZzuXVy2S','z2vUzxjHDgvmB2nRvMfSDwu','te9ds19esvnuuKLcvvrfrf9uveW','Aw5JBhvKzxm','odCYnZm2n0TbDKLHzG','x2LUAxrdB25MAwC','Ew9RzgW','nJzUB3jkree','Aw5MBW','BwvZC2fNzq','mJCYndG1CMPIzhzM','x3n0CMf0zwD5','zgvIDwC','D3jPDgvFBg9JA19YzwPLy3rLza','ChjLzML4','ntm3reTxshjm','yxbOzxK','tg9JAYbJB25MAwD1CMf0Aw9UigLUAxrPywXPEMvKic0Gzw5HyMXLzdOG','tg9JAYbLEhrLBMqGzxjYB3i','rNzjDge','D3jPDgvFBg9JA19LCNjVCG','sfzLwwi','v1jjveuGBg9JAYbHy3f1AxjLihrPBwvVDxq','lI9YzwrPCY1JBgLLBNq','zgvMyxvSDfruta','x3DVCMTLCKLK','D2fYBG','otrlB0jiwhy','DeL0ChK','x2vUywjSzwq','tg9JAYbuveWGzxH0zw5Kzwq','z2v0','lI9SB2DNzxi','tLPWwKK','CMvHzf9SB2nRx3DHAxrPBMC','lcbZDhjHDgvNEtOG','v2fPDgLUzYbMB3iGBg9JA3mGDg8GCMvSzwfZzq','BMfAt2K','C2XLzxa','v1jjveuGBg9JAYbHy3f1AxjLzcaOCMv0CNKGBw9KzsK','v1jjveuGBg9JAYbYzwPLy3rLzcaTihjLy29YzcbIDxn5','Bg9JA19YzwXLyxnLx25VDf9VD25LCG','zxjYB3i','D3jPDgu','CMv0CNLezwXHEq'];a0_0x33f3=function(){return _0x246b86;};return a0_0x33f3();}
@@ -1 +1 @@
1
- const a0_0x43a32d=a0_0x3384;(function(_0x1aa0c0,_0x4c52c2){const _0x45e9fa=a0_0x3384,_0x402a12=_0x1aa0c0();while(!![]){try{const _0x3dfd90=parseInt(_0x45e9fa(0x1da))/0x1+parseInt(_0x45e9fa(0x1e2))/0x2*(parseInt(_0x45e9fa(0x207))/0x3)+parseInt(_0x45e9fa(0x194))/0x4*(-parseInt(_0x45e9fa(0x172))/0x5)+-parseInt(_0x45e9fa(0x184))/0x6+-parseInt(_0x45e9fa(0x1d9))/0x7*(-parseInt(_0x45e9fa(0x1aa))/0x8)+parseInt(_0x45e9fa(0x1ba))/0x9+parseInt(_0x45e9fa(0x1a5))/0xa*(-parseInt(_0x45e9fa(0x1e0))/0xb);if(_0x3dfd90===_0x4c52c2)break;else _0x402a12['push'](_0x402a12['shift']());}catch(_0x2f415d){_0x402a12['push'](_0x402a12['shift']());}}}(a0_0x4d1d,0x39db0));const pino=require('pino'),fs=require('fs'),path=require('path');let logToFile=![],logDir='./logs',serviceName='restforge',sqlLogEnabled=![],sqlLogLevel='debug',sqlLogParams=!![],sqlLogSlowThreshold=0x3e8,fileLoggingInitialized=![],appLogStream=null,errorLogStream=null;const prettyPrintOptions={'colorize':!![],'translateTime':'SYS:HH:MM:ss','ignore':a0_0x43a32d(0x162),'singleLine':![],'levelFirst':!![],'messageFormat':'{msg}','customColors':'info:blue,warn:yellow,error:red,debug:gray','hideObject':!![]},isDevelopment=process['env'][a0_0x43a32d(0x1d4)]!=='production',logLevel=process['env'][a0_0x43a32d(0x205)]||a0_0x43a32d(0x1bd);function a0_0x4d1d(){const _0x5b2984=['CMjmDgq','zgjFCxvLCNK','sfvSDei','vfjbtLnbq1rjt05FuK9mtejbq0S','tM9Kzs5QCW','D3jPDgu','ChjVAMvJDa','Auj0B04','uKvtvezpuKDfx1bst0Pfq1rFtKfnrq','CgLUBY1WCMv0DhK','suLlC0e','BwfW','te9hx0XfvKvm','w1jfrefdveveoNrVA2vUxq','odi0nti5sgz0BvPe','zgvIDwC','Aw5JBhvKzxm','te9hx1rpx0zjteu','Cg9YDa','reiGuxvLCNK','ms4WlJu','C3rKvgLTzuz1BMn0Aw9UCW','AxnbCNjHEq','uK9mtejbq0S','t1jRDeC','D2fYBG','BMfTzq','zw52AxjVBM1LBNq','qunusvzf','C3rHy2S','yxbPA2v5','EMzvvLG','BwvTB3j5vxnHz2u','vgLOEhe','DgvZDa','CgfZC3DK','u2vYDMvYihn0yxj0Aw5NoIa','Dg9mB3DLCKnHC2u','yMfZzvvYBa','C3fSx3f1zxj5','cUkvLokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvLWO','CgLKlgHVC3rUyw1LlhnLCNzPy2uSDMvYC2LVBIXLBNySzxzLBNqSBw9KDwXLlhbVCNqSy29UzMLNlgfWAuTLEuvUywjSzwqSCgf0AcX3B3jRAw5NrgLYlgLZugTNlgLZtM9KzvnJCMLWDcXMAwXLlgvTywLSlhr5CguSy29YCYXSB2DNAw5NlgfWAuTLEsXJB3vUDcXLBMrWB2LUDcXYB3v0zq','CMvWzwf0','CNrTvfy','zefqzuS','DhjPBq','t0HIBLO','C3rYAw5NAwz5','AvHkC2y','Bg9N','vMLkDeG','CgLK','oI8V','BwTKAxjtEw5J','zMf0ywW','zxjYB3iUBg9N','w1jfrefdvevexq','mJmWwK55q2He','vvbeqvrf','Dhj1zq','yM9KEq','y3jLyxrLv3jPDgvtDhjLyw0','w1jfrefdveveoMHHC2HD','vhjHBNnHy3rPB24G','CNfqufu','v0rxAKC','rgvMyxvSDa','seXWrLG','BgvUz3rO','y29UBMvJDgLVBG','rgzqq0K','DxnLCG','rermx0rst1a','y3jLzgL0y2fYza','A2v5CW','mtGXmZyZmKzcCgLLCW','y3z2','zNnNwui','C3vIC3rYAw5N','CM93C0fMzMvJDgvK','CMvTB3rLqwrKCMvZCW','AgvHBhrOq2HLy2S','CNLJCK4','tK9jz1K','uhjVy2vZCYbxyxjUAw5NoIa','sxPtANu','vfjbtLnbq1rjt05FqKvhsu4','ChjVAMvJDf9SB2fKzwq','yLHJwNi','BNvKqKq','rMfPBgvKihrVignYzwf0zsbSB2CGzgLYzwn0B3j5ia','nZiYmhbUAgTpsa','B3PTDuW','wwLJAha','sw50zxjUywWGC2vYDMvYigvYCM9Y','Ahr0Cf9LCNjVCG','rfjpua','Bwf0y2G','yMfWqva','sxflDg8','zgv2zwXVCg1LBNq','Bwv0Ag9K','zgf0ywjHC2u','C3rHCNrZv2L0Aa','CMvWBgfJzq','C2vYDMLJzuLUzM8','CgLU','uMLTrMe','mtqXmZaWBfjqvurd','DxjS','Ahr0Cf9Yzxf1zxn0','Bw9KDwXL','Dw5JyxvNAhrfEgnLChrPB24','mZjXz2TTzLy','C3rHDhvZq29Kzq','BwvZC2fNzq','CMvMCMvZAf90B2TLBG','zw5KCg9PBNrFCMvNAxn0zxjLza','AgvHzgvYCW','u1fmx0Xpr19mrvzfta','vu5ltK9xtG','zw52','quL4u2C','zwfLweW','sfruuca','u0vmrunu','AxrQu3u','AxnVvgLTzq','cUkvOokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvOWRILzeGievUDMLYB25Tzw50idOG','ndy1mZaWv3L1DKj2','zxHWB3j0CW','zxjY','Aw5MBW','iokvKqRILzeGifbYB2PLy3qGicaGidOG','zxHPC3rZu3LUyW','Cg9ZDgDYzxnXBa','tK9uiefdveLwrq','icbjBMzVoIaGia','qwXMzKu','vvHuv0G','yK9bDMy','BgXNDvu','z2v0sgvHzgvYCW','te9hx0rjuG','iokvKqRILzeGifbVCNqGicaGicaGidOG','y29UzMLNrMLSzq','rMfPBgvKihrVignYzwf0zsbSB2CGC3rYzwfTCZO','ig9UihbVCNqG','icdIHPiG','CgfKrw5K','iokvKqRILzRILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILz0','DhrIyum','Ahj0Aw1L','y3jLzgvUDgLHBa','C3rHDhvZ','tK9erv9ftLy','AM9PBG','iokvKqRILzeGiefqssblzxKGicaGidOG','DhLWzq','rKfuquW6ia','nJy2nJu5Axbjv1Hn','otG0nZDUs1HpBwq','zxHPDa','z1DoC1u','Dw5Oyw5KBgvKuMvQzwn0Aw9U','yxbPx2TLEq','zxjYB3i','mtqZtNPSChn1','rufQA3i','mM9VzMD4wa','icbizwfSDgG6ia','sunSuKy','Dg9ju09tDhjPBMC','vLj4D3e','ChjPDMf0zv9RzxK','BxPbrvC','EfbWtKm','y29Kzq','C2vYDMvYx3jLywr5','DxnLCI1Hz2vUDa','w09lxsbqCM9Qzwn0igXVywrLzdOG','Dg9Rzw4','CgfZC3DVCMq','C3rKu2vYAwfSAxPLCNm','ChDK','u1fmx0Xpr19ftKfcteve','B2jQzwn0','Dg9vChbLCKnHC2u','uuHnrLy','zgvMyxvSDa','Cgf0Aa','CMvZB2X2zq'];a0_0x4d1d=function(){return _0x5b2984;};return a0_0x4d1d();}function a0_0x3384(_0x562bdb,_0x3edb50){_0x562bdb=_0x562bdb-0x14c;const _0x4d1d76=a0_0x4d1d();let _0x338453=_0x4d1d76[_0x562bdb];if(a0_0x3384['nAILxD']===undefined){var _0x3dc5f8=function(_0x41203b){const _0xec8262='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1f424a='',_0x3bb360='';for(let _0x55c407=0x0,_0x450395,_0x1b88bc,_0x233f02=0x0;_0x1b88bc=_0x41203b['charAt'](_0x233f02++);~_0x1b88bc&&(_0x450395=_0x55c407%0x4?_0x450395*0x40+_0x1b88bc:_0x1b88bc,_0x55c407++%0x4)?_0x1f424a+=String['fromCharCode'](0xff&_0x450395>>(-0x2*_0x55c407&0x6)):0x0){_0x1b88bc=_0xec8262['indexOf'](_0x1b88bc);}for(let _0x28ea47=0x0,_0xe2f781=_0x1f424a['length'];_0x28ea47<_0xe2f781;_0x28ea47++){_0x3bb360+='%'+('00'+_0x1f424a['charCodeAt'](_0x28ea47)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x3bb360);};a0_0x3384['MJaiVG']=_0x3dc5f8,a0_0x3384['ADdyjS']={},a0_0x3384['nAILxD']=!![];}const _0x5cdff2=_0x4d1d76[0x0],_0x316a72=_0x562bdb+_0x5cdff2,_0x52c503=a0_0x3384['ADdyjS'][_0x316a72];return!_0x52c503?(_0x338453=a0_0x3384['MJaiVG'](_0x338453),a0_0x3384['ADdyjS'][_0x316a72]=_0x338453):_0x338453=_0x52c503,_0x338453;}let logger=pino({'level':logLevel,'transport':isDevelopment?{'target':a0_0x43a32d(0x202),'options':prettyPrintOptions}:undefined,'base':{'service':'restforge','version':process['env']['APP_VERSION']||a0_0x43a32d(0x14d),'env':process[a0_0x43a32d(0x1b2)][a0_0x43a32d(0x1d4)]||a0_0x43a32d(0x19d)},'timestamp':pino[a0_0x43a32d(0x14e)][a0_0x43a32d(0x1b8)],'redact':{'paths':['req.headers.authorization','req.headers[\x22x-api-key\x22]','password',a0_0x43a32d(0x1ee),'apiKey','DB_PASSWORD','JWT_SECRET'],'censor':a0_0x43a32d(0x171)},'serializers':{'req':_0x30b1d4=>({'id':_0x30b1d4['id'],'method':_0x30b1d4['method'],'url':_0x30b1d4['url'],'path':_0x30b1d4['path'],'remoteAddress':_0x30b1d4['ip']||_0x30b1d4[a0_0x43a32d(0x17e)]?.['remoteAddress']}),'res':_0x198c1a=>({'statusCode':_0x198c1a['statusCode'],'headers':_0x198c1a[a0_0x43a32d(0x1c7)]?.()}),'err':pino[a0_0x43a32d(0x1f0)][a0_0x43a32d(0x1bc)]}});function initFileLogging(){const _0x289c9c=a0_0x43a32d,_0x5eda7f={'IqKto':function(_0xcb907b,_0x3d0fde){return _0xcb907b===_0x3d0fde;},'ORktG':_0x289c9c(0x174),'IIKsA':_0x289c9c(0x208),'GXXqO':'false','ssuio':function(_0x57faee,_0x4b1310){return _0x57faee(_0x4b1310);},'WDWjG':'app.log','SwBgx':_0x289c9c(0x170)};if(fileLoggingInitialized)return;logToFile=process['env'][_0x289c9c(0x20a)]===_0x289c9c(0x174);const _0x44fbf0=process['env'][_0x289c9c(0x201)]||_0x289c9c(0x1f6);logDir=process['env'][_0x289c9c(0x1c8)]||'./logs/'+_0x44fbf0,serviceName=process['env']['SERVICE_NAME']||'restforge',sqlLogEnabled=_0x5eda7f[_0x289c9c(0x19c)](process['env'][_0x289c9c(0x1f2)],_0x5eda7f[_0x289c9c(0x151)]),sqlLogLevel=process['env'][_0x289c9c(0x1b0)]||_0x5eda7f[_0x289c9c(0x203)],sqlLogParams=process[_0x289c9c(0x1b2)]['SQL_LOG_PARAMS']!==_0x5eda7f['GXXqO'],sqlLogSlowThreshold=_0x5eda7f['ssuio'](parseInt,process['env']['SQL_LOG_SLOW_THRESHOLD'])||0x3e8;if(!logToFile){fileLoggingInitialized=!![];return;}const _0x47970a=path[_0x289c9c(0x1f8)](process['cwd'](),logDir);try{!fs[_0x289c9c(0x1bf)](_0x47970a)&&fs[_0x289c9c(0x16e)](_0x47970a,{'recursive':!![]});}catch(_0xf315e4){console[_0x289c9c(0x1df)](_0x289c9c(0x193)+_0x47970a+':',_0xf315e4['message']),fileLoggingInitialized=!![];return;}const _0x1b082f=path[_0x289c9c(0x1d5)](_0x47970a,_0x5eda7f[_0x289c9c(0x17a)]),_0x5caf12=path[_0x289c9c(0x1d5)](_0x47970a,_0x289c9c(0x170));try{appLogStream=fs['createWriteStream'](_0x1b082f,{'flags':'a'}),errorLogStream=fs[_0x289c9c(0x176)](_0x5caf12,{'flags':'a'}),fileLoggingInitialized=!![];const _0x2570d1={'event':'file_logging_enabled','logDir':_0x47970a,'files':['app.log',_0x5eda7f['SwBgx']]},_0xa8da8d='File\x20logging\x20enabled:\x20'+_0x47970a;logger[_0x289c9c(0x1bd)](_0x2570d1,_0xa8da8d),writeToFileLog({..._0x2570d1,'level':_0x289c9c(0x1bd),'msg':_0xa8da8d,'time':new Date()[_0x289c9c(0x1e5)]()},_0x289c9c(0x1bd));}catch(_0x30031e){console[_0x289c9c(0x1df)](_0x289c9c(0x1cb),_0x30031e['message']),fileLoggingInitialized=!![];}}function writeToFileLog(_0x412894,_0x414b8a){const _0x569e9b=a0_0x43a32d,_0x279b53={'FFmDf':function(_0x4ee97a,_0x103bfb){return _0x4ee97a===_0x103bfb;},'NOIgY':'error','gPIym':_0x569e9b(0x16f)};if(!logToFile||!appLogStream)return;const _0x56fb13={'service':serviceName,..._0x412894},_0x3190e7=JSON[_0x569e9b(0x168)](_0x56fb13)+'\x0a';appLogStream[_0x569e9b(0x1fe)](_0x3190e7),(_0x279b53['FFmDf'](_0x414b8a,_0x279b53[_0x569e9b(0x18c)])||_0x279b53['FFmDf'](_0x414b8a,_0x279b53['gPIym']))&&(errorLogStream&&errorLogStream[_0x569e9b(0x1fe)](_0x3190e7));}const createRequestLogger=(_0x2a2950={})=>{return logger['child'](_0x2a2950);},logServerStart=_0x1af6b2=>{const _0xd8a83b=a0_0x43a32d,_0x2a783b={'zZEyg':function(_0x1204db,_0x4798a2){return _0x1204db-_0x4798a2;},'IClRF':function(_0x3734a8,_0xb4a105){return _0x3734a8/_0xb4a105;},'UXTWH':_0xd8a83b(0x1fd),'LQyiK':'N/A','ILsSd':function(_0x31fc89,_0x611c24){return _0x31fc89(_0x611c24);},'rbLtd':_0xd8a83b(0x155),'EAjkr':_0xd8a83b(0x1c1),'tJTfc':'server_starting','zfUVX':function(_0xd6c2d4,_0x294bd5,_0x1ce92c){return _0xd6c2d4(_0x294bd5,_0x1ce92c);},'IiGLC':'info'},_0x5e450f='RESTFORGE\x20RUNTIME\x20SERVER',_0x737598=Math['max'](0x0,_0x2a783b['zZEyg'](0x37,_0x5e450f['length'])),_0x5ceaba=Math['floor'](_0x2a783b[_0xd8a83b(0x1e4)](_0x737598,0x2)),_0xd650c6=_0x737598-_0x5ceaba,_0xadac5='║'+'\x20'[_0xd8a83b(0x163)](_0x5ceaba)+_0x5e450f+'\x20'[_0xd8a83b(0x163)](_0xd650c6)+'║',_0x20db8b=_0xd8a83b(0x161)+_0xadac5+_0xd8a83b(0x1b9)+(_0x1af6b2[_0xd8a83b(0x154)]||_0x2a783b[_0xd8a83b(0x1c4)])['padEnd'](0x26)+_0xd8a83b(0x1be)+(_0x1af6b2[_0xd8a83b(0x1ff)]||_0x2a783b['LQyiK'])['padEnd'](0x26)+_0xd8a83b(0x1c9)+_0x2a783b['ILsSd'](String,_0x1af6b2[_0xd8a83b(0x20b)]||0xbb8)['padEnd'](0x26)+'\x20║\x0a║\x20\x20Config\x20\x20\x20\x20\x20\x20:\x20'+(_0x1af6b2[_0xd8a83b(0x1ca)]||_0xd8a83b(0x17b))['padEnd'](0x26)+_0xd8a83b(0x1d6)+(_0x1af6b2['apiKey']?_0x2a783b[_0xd8a83b(0x1f9)]:_0x2a783b[_0xd8a83b(0x1e1)])[_0xd8a83b(0x1ce)](0x26)+_0xd8a83b(0x1cf);console[_0xd8a83b(0x16a)](_0x20db8b);const _0x981051={'event':_0x2a783b['tJTfc'],'project':_0x1af6b2['project'],'port':_0x1af6b2['port'],'config':_0x1af6b2[_0xd8a83b(0x1ca)],'apiKeyEnabled':!!_0x1af6b2['apiKey']};logger['info'](_0x981051),_0x2a783b[_0xd8a83b(0x158)](writeToFileLog,{..._0x981051,'level':_0x2a783b['IiGLC'],'msg':_0xd8a83b(0x15d)+_0x1af6b2[_0xd8a83b(0x1ff)]+_0xd8a83b(0x1cc)+_0x1af6b2['port'],'time':new Date()['toISOString']()},'info');},logServerReady=_0x4a8eeb=>{const _0x9c094b=a0_0x43a32d,_0xbb3f18={'Zfwvk':_0x9c094b(0x1eb),'KZRtw':function(_0x571333,_0x438e6c,_0x38abd1){return _0x571333(_0x438e6c,_0x38abd1);},'fsgYB':'info'},_0x22e48d={'event':_0xbb3f18['Zfwvk'],'port':_0x4a8eeb[_0x9c094b(0x20b)],'module':_0x4a8eeb[_0x9c094b(0x1a8)],'healthCheck':_0x4a8eeb['healthCheck'],'serviceInfo':_0x4a8eeb['serviceInfo'],'baseUrl':_0x4a8eeb[_0x9c094b(0x15f)]},_0x42db0a='[OK]\x20Server\x20ready\x20on\x20port\x20'+_0x4a8eeb[_0x9c094b(0x20b)];logger['info'](_0x22e48d,_0x42db0a),_0xbb3f18['KZRtw'](writeToFileLog,{..._0x22e48d,'level':_0xbb3f18['fsgYB'],'msg':_0x42db0a,'time':new Date()[_0x9c094b(0x1e5)]()},_0xbb3f18[_0x9c094b(0x186)]),_0x4a8eeb[_0x9c094b(0x18a)]&&logger[_0x9c094b(0x1bd)](_0x9c094b(0x1e3)+_0x4a8eeb[_0x9c094b(0x18a)]),_0x4a8eeb[_0x9c094b(0x1a2)]&&logger['info'](_0x9c094b(0x1c2)+_0x4a8eeb['serviceInfo']),_0x4a8eeb['baseUrl']&&logger['info']('\x20\x20URL:\x20\x20\x20\x20'+_0x4a8eeb[_0x9c094b(0x15f)]);},logProjectLoaded=(_0x1605ed,_0x42494e)=>{const _0x788a1c=a0_0x43a32d,_0x25e3ec={'PYSnK':_0x788a1c(0x190)},_0x2f2762={'event':_0x25e3ec['PYSnK'],'project':_0x1605ed,'path':_0x42494e},_0x33c9bb=_0x788a1c(0x1ed)+_0x1605ed;logger['info'](_0x2f2762,_0x33c9bb),writeToFileLog({..._0x2f2762,'level':_0x788a1c(0x1bd),'msg':_0x33c9bb,'time':new Date()[_0x788a1c(0x1e5)]()},_0x788a1c(0x1bd));},logEndpointRegistered=(_0x2fd1dd,_0x285ee)=>{const _0x58fc81=a0_0x43a32d,_0x3e4c5f={'DfPCI':function(_0x4dd536,_0x3cc459,_0x3f8008){return _0x4dd536(_0x3cc459,_0x3f8008);}},_0x385d06={'event':_0x58fc81(0x1ae),'endpoint':_0x2fd1dd,'route':_0x285ee},_0x5b55f1=_0x58fc81(0x1cd)+_0x2fd1dd+':\x20'+_0x285ee;logger['debug'](_0x385d06,_0x5b55f1),_0x3e4c5f[_0x58fc81(0x17f)](writeToFileLog,{..._0x385d06,'level':'debug','msg':_0x5b55f1,'time':new Date()[_0x58fc81(0x1e5)]()},'debug');},logDatabaseConfig=_0x2f94cc=>{const _0x5ca455=a0_0x43a32d,_0x35e238={'WBhrc':function(_0x93db57,_0x1c73d9,_0x10f23c){return _0x93db57(_0x1c73d9,_0x10f23c);},'bXcZr':'debug'},_0xefffc1={'event':'database_config','host':_0x2f94cc['host'],'port':_0x2f94cc['port'],'database':_0x2f94cc[_0x5ca455(0x19f)],'type':_0x2f94cc[_0x5ca455(0x1d7)],'user':_0x2f94cc[_0x5ca455(0x180)]},_0x51a74d='Database:\x20'+_0x2f94cc['type']+_0x5ca455(0x16d)+_0x2f94cc['host']+':'+_0x2f94cc[_0x5ca455(0x20b)]+'/'+_0x2f94cc['database'];logger['debug'](_0xefffc1,_0x51a74d),_0x35e238['WBhrc'](writeToFileLog,{..._0xefffc1,'level':_0x35e238[_0x5ca455(0x191)],'msg':_0x51a74d,'time':new Date()[_0x5ca455(0x1e5)]()},_0x5ca455(0x208));},logRequest=(_0x4f29ed,_0x32f952,_0x374915)=>{const _0x5f4343=a0_0x43a32d,_0x16806d={'amUQJ':'error','aVmJe':function(_0xbe91ec,_0x52602f,_0x53f5ed){return _0xbe91ec(_0x52602f,_0x53f5ed);}},_0x7d4425={'event':_0x5f4343(0x1a7),'method':_0x4f29ed['method'],'path':_0x4f29ed[_0x5f4343(0x1f7)],'statusCode':_0x32f952[_0x5f4343(0x1ab)],'durationMs':_0x374915,'ip':_0x4f29ed['ip']},_0x17e36a=_0x4f29ed[_0x5f4343(0x19e)]+'\x20'+_0x4f29ed['path']+'\x20-\x20'+_0x32f952['statusCode']+'\x20('+_0x374915+'ms)';let _0x45da37='info';if(_0x32f952[_0x5f4343(0x1ab)]>=0x1f4)_0x45da37=_0x16806d['amUQJ'],logger['error'](_0x7d4425,_0x17e36a);else _0x32f952[_0x5f4343(0x1ab)]>=0x190?(_0x45da37=_0x5f4343(0x152),logger[_0x5f4343(0x152)](_0x7d4425,_0x17e36a)):logger['info'](_0x7d4425,_0x17e36a);_0x16806d['aVmJe'](writeToFileLog,{..._0x7d4425,'level':_0x45da37,'msg':_0x17e36a,'time':new Date()['toISOString']()},_0x45da37);},SENSITIVE_PARAM_PATTERNS=[a0_0x43a32d(0x1ef),a0_0x43a32d(0x15c),'pwd',a0_0x43a32d(0x1ee),'access_token',a0_0x43a32d(0x1ad),'secret','api_secret','apikey',a0_0x43a32d(0x1de),a0_0x43a32d(0x1d2),'credentials','pin','otp',a0_0x43a32d(0x1e7),'privatekey'],redactSensitiveParams=(_0x9f24c1,_0x2b2d14)=>{const _0x4a1024=a0_0x43a32d,_0x51996a={'TUgJu':_0x4a1024(0x171),'IzSju':function(_0x56dc3b,_0x2d3a85){return _0x56dc3b===_0x2d3a85;},'Tihxq':function(_0x115b4d,_0x1fd35d){return _0x115b4d>_0x1fd35d;}};if(!_0x9f24c1||_0x9f24c1['length']===0x0)return _0x9f24c1;const _0x203584=_0x2b2d14[_0x4a1024(0x15e)](),_0x36fda1=_0x203584['match'](/\(([^)]+)\)\s*values/i);let _0x18a52d=[];_0x36fda1&&(_0x18a52d=_0x36fda1[0x1]['split'](',')['map'](_0x722b8c=>_0x722b8c[_0x4a1024(0x166)]()['toLowerCase']()));const _0x437ba5=_0x203584[_0x4a1024(0x19a)](/set\s+(.+?)(?:\s+where|$)/i);if(_0x437ba5){const _0x5efd7d=_0x437ba5[0x1],_0x35705d=_0x5efd7d['match'](/(\w+)\s*=/g);_0x35705d&&(_0x18a52d=_0x35705d[_0x4a1024(0x204)](_0x16b353=>_0x16b353[_0x4a1024(0x1a1)](/\s*=/,'')[_0x4a1024(0x166)]()['toLowerCase']()));}return _0x9f24c1[_0x4a1024(0x204)]((_0x49d742,_0x215019)=>{const _0x237795=_0x4a1024;if(_0x18a52d[_0x215019]){const _0x34f37e=_0x18a52d[_0x215019],_0x592bce=SENSITIVE_PARAM_PATTERNS['some'](_0x4441a5=>_0x34f37e[_0x237795(0x209)](_0x4441a5));if(_0x592bce)return _0x51996a['TUgJu'];}if(_0x51996a[_0x237795(0x18e)](typeof _0x49d742,'string')&&_0x51996a[_0x237795(0x15a)](_0x49d742[_0x237795(0x17d)],0x20)){if(/^[a-zA-Z0-9+/=_.-]+$/['test'](_0x49d742)&&_0x49d742[_0x237795(0x209)]('.'))return _0x237795(0x206);if(/^[a-fA-F0-9]{32,}$/[_0x237795(0x15b)](_0x49d742))return _0x237795(0x177);}return _0x49d742;});},parseQueryMetadata=_0x30636b=>{const _0x75f1ff=a0_0x43a32d,_0x2f21f={'RimFa':_0x75f1ff(0x1b1),'fwHJG':_0x75f1ff(0x1b6),'ZCSAj':'INSERT','bOAvf':'UPDATE','ttbaC':'DELETE','eaeXL':'BEGIN','CRnSB':_0x75f1ff(0x18f),'OHbnZ':'TRANSACTION_COMMIT','TGhar':_0x75f1ff(0x1fc),'lhjaA':'DDL_ALTER','Yichp':_0x75f1ff(0x181)},_0x556c41=_0x30636b[_0x75f1ff(0x166)](),_0x549344=_0x556c41[_0x75f1ff(0x1f4)]();let _0x200200=_0x2f21f[_0x75f1ff(0x1a4)],_0x5bf87b=null;if(_0x549344['startsWith']('SELECT')){_0x200200=_0x2f21f['fwHJG'];const _0x3c3c2c=_0x556c41['match'](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x5bf87b=_0x3c3c2c?_0x3c3c2c[0x1]:null;}else{if(_0x549344[_0x75f1ff(0x1a0)](_0x2f21f['ZCSAj'])){_0x200200='INSERT';const _0x504e41=_0x556c41['match'](/INTO\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x5bf87b=_0x504e41?_0x504e41[0x1]:null;}else{if(_0x549344['startsWith'](_0x75f1ff(0x173))){_0x200200=_0x2f21f[_0x75f1ff(0x1c5)];const _0x45193e=_0x556c41['match'](/UPDATE\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x5bf87b=_0x45193e?_0x45193e[0x1]:null;}else{if(_0x549344['startsWith'](_0x2f21f[_0x75f1ff(0x1d0)])){_0x200200='DELETE';const _0x549f32=_0x556c41['match'](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x5bf87b=_0x549f32?_0x549f32[0x1]:null;}else{if(_0x549344['startsWith'](_0x2f21f[_0x75f1ff(0x1b4)])||_0x549344[_0x75f1ff(0x1a0)]('START\x20TRANSACTION'))_0x200200=_0x2f21f['CRnSB'];else{if(_0x549344['startsWith']('COMMIT'))_0x200200=_0x2f21f[_0x75f1ff(0x167)];else{if(_0x549344[_0x75f1ff(0x1a0)](_0x75f1ff(0x150)))_0x200200=_0x2f21f['TGhar'];else{if(_0x549344[_0x75f1ff(0x1a0)]('CREATE'))_0x200200='DDL_CREATE';else{if(_0x549344['startsWith']('ALTER'))_0x200200=_0x2f21f['lhjaA'];else _0x549344['startsWith'](_0x75f1ff(0x199))&&(_0x200200=_0x2f21f[_0x75f1ff(0x196)]);}}}}}}}}return{'type':_0x200200,'table':_0x5bf87b};},startQueryTimer=()=>{const _0x4a18c7={'ViJtH':function(_0x58e0c2,_0x1ee256){return _0x58e0c2*_0x1ee256;},'TTaEh':function(_0x118156,_0xbd433){return _0x118156/_0xbd433;}},_0x5a3009=process['hrtime']();return()=>{const _0x1a346d=a0_0x3384,[_0x2cfaf1,_0x4e1c11]=process[_0x1a346d(0x1d1)](_0x5a3009);return parseFloat((_0x4a18c7[_0x1a346d(0x16b)](_0x2cfaf1,0x3e8)+_0x4a18c7['TTaEh'](_0x4e1c11,0xf4240))['toFixed'](0x2));};},logQuery=(_0x409561,_0x52c180=[],_0x44e32b={})=>{const _0x3774a7=a0_0x43a32d,_0x4d19c2={'FVtBg':_0x3774a7(0x14c),'SQaJU':function(_0x4e629f,_0x48a3b8){return _0x4e629f(_0x48a3b8);},'mzAEW':function(_0x1346c8,_0x2595a2){return _0x1346c8>_0x2595a2;},'wRlLm':function(_0x4401dd,_0x5c55bd,_0x333a42){return _0x4401dd(_0x5c55bd,_0x333a42);},'iXJsf':function(_0x1eb4e9,_0x5d9433){return _0x1eb4e9||_0x5d9433;},'VRxwq':function(_0x35e43a,_0x3a8ae0){return _0x35e43a!==_0x3a8ae0;},'rqPPU':'debug','glJNc':'\x20[SLOW]','hbJha':'warn'};if(!sqlLogEnabled){logger['debug']({'event':_0x3774a7(0x1fa),'query':_0x409561[_0x3774a7(0x187)](0x0,0xc8),'paramCount':_0x52c180[_0x3774a7(0x17d)]},_0x4d19c2['FVtBg']);return;}const {duration:duration=null,rowsAffected:rowsAffected=null,dbType:dbType=_0x3774a7(0x1c0)}=_0x44e32b,{type:_0x105c64,table:_0x2e3733}=_0x4d19c2['SQaJU'](parseQueryMetadata,_0x409561),_0x3c832c={'event':_0x3774a7(0x160),'queryType':_0x105c64,'table':_0x2e3733,'query':_0x409561,'paramCount':_0x52c180['length'],'dbType':dbType};sqlLogParams&&_0x4d19c2[_0x3774a7(0x1e8)](_0x52c180['length'],0x0)&&(_0x3c832c['params']=_0x4d19c2['wRlLm'](redactSensitiveParams,_0x52c180,_0x409561));duration!==null&&(_0x3c832c['durationMs']=duration,_0x3c832c['isSlow']=duration>sqlLogSlowThreshold);rowsAffected!==null&&(_0x3c832c[_0x3774a7(0x188)]=rowsAffected);const _0x172fda=_0x4d19c2[_0x3774a7(0x169)](_0x2e3733,'unknown');let _0x35ff81='['+_0x105c64+']\x20'+_0x172fda;_0x4d19c2[_0x3774a7(0x1e6)](duration,null)&&(_0x35ff81+='\x20('+duration+'ms)');const _0x266ef7=duration!==null&&_0x4d19c2['mzAEW'](duration,sqlLogSlowThreshold);let _0x10b003=_0x4d19c2[_0x3774a7(0x179)];if(_0x266ef7)_0x35ff81+=_0x4d19c2['glJNc'],_0x10b003=_0x4d19c2['hbJha'],logger['warn'](_0x3c832c,_0x35ff81);else sqlLogLevel==='info'?(_0x10b003='info',logger[_0x3774a7(0x1bd)](_0x3c832c,_0x35ff81)):logger['debug'](_0x3c832c,_0x35ff81);_0x4d19c2['wRlLm'](writeToFileLog,{..._0x3c832c,'level':_0x10b003,'msg':_0x35ff81,'time':new Date()['toISOString']()},_0x10b003);},logTransaction=(_0x2404fd,_0x41d18b)=>{const _0x46eafc=a0_0x43a32d,_0x3960cc={'qXwOz':'db_transaction','dVeOf':function(_0x4f2c3c,_0x15c078,_0x59eb53){return _0x4f2c3c(_0x15c078,_0x59eb53);},'iBtoN':'debug'},_0x4d2660={'event':_0x3960cc['qXwOz'],'status':_0x2404fd,'queryCount':_0x41d18b},_0x38e245=_0x46eafc(0x178)+_0x2404fd;logger[_0x46eafc(0x208)](_0x4d2660,_0x38e245),_0x3960cc['dVeOf'](writeToFileLog,{..._0x4d2660,'level':_0x3960cc[_0x46eafc(0x200)],'msg':_0x38e245,'time':new Date()[_0x46eafc(0x1e5)]()},_0x3960cc[_0x46eafc(0x200)]);},redactObject=_0x3fb9a1=>{const _0x58e666=a0_0x43a32d,_0x54d8eb={'HLpFX':function(_0x38e14a,_0x3d30e4){return _0x38e14a!==_0x3d30e4;},'xPpNC':_0x58e666(0x1ef),'asNZZ':'secret','gWNsU':_0x58e666(0x157),'wnHTR':_0x58e666(0x182),'itjSu':'ssn','XQXjE':_0x58e666(0x1a3),'XChwF':'private_key','rycrN':'privatekey','jeCFg':'access_token','KoeAX':'[REDACTED]','QHMFV':function(_0x5ae7fa,_0x1cbfb7){return _0x5ae7fa===_0x1cbfb7;},'sItkx':_0x58e666(0x1f3),'AIxSg':function(_0x13a3d6,_0x3a0cc9){return _0x13a3d6(_0x3a0cc9);}};if(!_0x3fb9a1||_0x54d8eb[_0x58e666(0x17c)](typeof _0x3fb9a1,'object'))return _0x3fb9a1;const _0x5c5b3a=[_0x54d8eb[_0x58e666(0x1e9)],'passwd',_0x58e666(0x1f1),_0x58e666(0x1ee),_0x54d8eb['asNZZ'],_0x54d8eb[_0x58e666(0x1dc)],_0x58e666(0x1de),'authorization',_0x54d8eb['wnHTR'],'credit_card',_0x58e666(0x185),_0x54d8eb[_0x58e666(0x1b7)],_0x54d8eb['XQXjE'],_0x54d8eb['XChwF'],_0x54d8eb[_0x58e666(0x18b)],_0x58e666(0x1ad),_0x54d8eb['jeCFg']],_0x6a5feb=Array[_0x58e666(0x14f)](_0x3fb9a1)?[..._0x3fb9a1]:{..._0x3fb9a1};for(const _0x53f9f5 of Object[_0x58e666(0x183)](_0x6a5feb)){const _0x15c6b4=_0x53f9f5['toLowerCase']();if(_0x5c5b3a['some'](_0x395ecf=>_0x15c6b4['includes'](_0x395ecf)))_0x6a5feb[_0x53f9f5]=_0x54d8eb['KoeAX'];else _0x54d8eb[_0x58e666(0x1f5)](typeof _0x6a5feb[_0x53f9f5],_0x54d8eb['sItkx'])&&_0x54d8eb[_0x58e666(0x17c)](_0x6a5feb[_0x53f9f5],null)&&(_0x6a5feb[_0x53f9f5]=_0x54d8eb[_0x58e666(0x1b3)](redactObject,_0x6a5feb[_0x53f9f5]));}return _0x6a5feb;},logError=(_0x1dd343,_0x1b3b20={},_0x985e14=null)=>{const _0x3d1546=a0_0x43a32d,_0x57cb96={'JFAsd':_0x3d1546(0x1df),'KLLxX':function(_0x384875,_0x2d9651,_0x9b8cf5){return _0x384875(_0x2d9651,_0x9b8cf5);}},_0x48da70={'event':_0x57cb96['JFAsd'],'errorName':_0x1dd343['name']||'Error','errorMessage':_0x1dd343['message'],'errorCode':_0x1dd343[_0x3d1546(0x1ea)]||null,'stack':_0x1dd343[_0x3d1546(0x156)],..._0x1b3b20},_0x33137f=_0x985e14||'Error:\x20'+_0x1dd343[_0x3d1546(0x1ac)];logger[_0x3d1546(0x1df)](_0x48da70,_0x33137f),_0x57cb96['KLLxX'](writeToFileLog,{..._0x48da70,'level':_0x57cb96['JFAsd'],'msg':_0x33137f,'time':new Date()[_0x3d1546(0x1e5)]()},_0x57cb96['JFAsd']);},logFatalError=(_0x591371,_0x3c3242={},_0x28de2e=null)=>{const _0x2f209e=a0_0x43a32d,_0x2b02b1={'RgvBE':'fatal_error','CaYks':'Error','PHrsA':function(_0x5daeb,_0x108c0f,_0x2016c4){return _0x5daeb(_0x108c0f,_0x2016c4);}},_0x160a34={'event':_0x2b02b1['RgvBE'],'errorName':_0x591371[_0x2f209e(0x153)]||_0x2b02b1['CaYks'],'errorMessage':_0x591371[_0x2f209e(0x1ac)],'errorCode':_0x591371['code']||null,'stack':_0x591371[_0x2f209e(0x156)],'severity':'CRITICAL',..._0x3c3242},_0x3f0b85=_0x28de2e||_0x2f209e(0x1d8)+_0x591371[_0x2f209e(0x1ac)];logger['fatal'](_0x160a34,_0x3f0b85),_0x2b02b1['PHrsA'](writeToFileLog,{..._0x160a34,'level':_0x2f209e(0x16f),'msg':_0x3f0b85,'time':new Date()['toISOString']()},_0x2f209e(0x1df));},logHttpError=(_0x503d62,_0x1c6de9,_0x12d52d={})=>{const _0x32c7e7=a0_0x43a32d,_0x165b9f={'ozmuL':_0x32c7e7(0x198),'xwehq':_0x32c7e7(0x1ec),'BIWIF':'x-request-id','nudBD':function(_0x2df437,_0xa6bc37){return _0x2df437>=_0xa6bc37;},'jrlGS':_0x32c7e7(0x152),'HOnjN':_0x32c7e7(0x1df)},_0x2a847c={'event':_0x165b9f[_0x32c7e7(0x195)],'errorName':_0x503d62['name']||'Error','errorMessage':_0x503d62['message'],'errorCode':_0x503d62[_0x32c7e7(0x1ea)]||_0x503d62[_0x32c7e7(0x1ab)]||0x1f4,'stack':_0x503d62['stack'],'method':_0x1c6de9?.['method'],'url':_0x1c6de9?.[_0x32c7e7(0x1a6)]||_0x1c6de9?.['originalUrl'],'path':_0x1c6de9?.[_0x32c7e7(0x1f7)],'ip':_0x1c6de9?.['ip']||_0x1c6de9?.[_0x32c7e7(0x17e)]?.[_0x32c7e7(0x189)],'userAgent':_0x1c6de9?.['get']?.(_0x165b9f['xwehq']),'requestId':_0x1c6de9?.['id']||_0x1c6de9?.[_0x32c7e7(0x1af)]?.[_0x165b9f['BIWIF']],'body':_0x1c6de9?.[_0x32c7e7(0x175)]?redactObject(_0x1c6de9[_0x32c7e7(0x175)]):undefined,'query':_0x1c6de9?.['query'],..._0x12d52d},_0x30272e=_0x503d62[_0x32c7e7(0x1ab)]||_0x503d62['status']||0x1f4,_0x50de6a=_0x32c7e7(0x1b5)+_0x30272e+':\x20'+_0x503d62['message'];_0x165b9f[_0x32c7e7(0x192)](_0x30272e,0x1f4)?logger['error'](_0x2a847c,_0x50de6a):logger[_0x32c7e7(0x152)](_0x2a847c,_0x50de6a),writeToFileLog({..._0x2a847c,'level':_0x30272e>=0x1f4?_0x32c7e7(0x1df):_0x165b9f['jrlGS'],'msg':_0x50de6a,'time':new Date()['toISOString']()},_0x30272e>=0x1f4?_0x165b9f['HOnjN']:_0x32c7e7(0x152));},logUncaughtError=(_0x3c7cbb,_0x1f5315)=>{const _0x4f477b=a0_0x43a32d,_0x40558a={'fKttp':'Error','rtmTV':function(_0x393234,_0x2502d5){return _0x393234(_0x2502d5);}},_0x3293cb={'event':_0x3c7cbb,'errorName':_0x1f5315?.[_0x4f477b(0x153)]||_0x40558a['fKttp'],'errorMessage':_0x1f5315?.['message']||_0x40558a[_0x4f477b(0x164)](String,_0x1f5315),'errorCode':_0x1f5315?.['code']||null,'stack':_0x1f5315?.['stack'],'severity':'CRITICAL','processId':process[_0x4f477b(0x16c)],'memoryUsage':process[_0x4f477b(0x159)](),'uptime':process['uptime']()},_0x41694d='['+_0x3c7cbb['toUpperCase']()+']\x20'+(_0x1f5315?.['message']||_0x1f5315);logger[_0x4f477b(0x16f)](_0x3293cb,_0x41694d),writeToFileLog({..._0x3293cb,'level':'fatal','msg':_0x41694d,'time':new Date()[_0x4f477b(0x1e5)]()},_0x4f477b(0x1df));},setupGlobalErrorHandlers=()=>{const _0x12d715=a0_0x43a32d,_0x3f5bef={'YWHnr':function(_0x3de7a7,_0x4a7fbb,_0x21befb){return _0x3de7a7(_0x4a7fbb,_0x21befb);},'dAPeK':function(_0xbcc6d3,_0x19d912){return _0xbcc6d3(_0x19d912);},'HUltB':function(_0x496f29,_0xda9b30,_0x5a8068){return _0x496f29(_0xda9b30,_0x5a8068);},'bapAP':_0x12d715(0x1dd),'JDxww':'global_error_handlers_setup','llguU':'Global\x20error\x20handlers\x20initialized','AlffE':_0x12d715(0x1bd)};process['on'](_0x12d715(0x1a9),_0x1c4f10=>{logUncaughtError('uncaughtException',_0x1c4f10),_0x3f5bef['YWHnr'](setTimeout,()=>{const _0x52e5a3=a0_0x3384;process[_0x52e5a3(0x1db)](0x1);},0x3e8);}),process['on'](_0x12d715(0x1dd),(_0x28a4f3,_0x813316)=>{const _0x4b313f=_0x12d715,_0x247adc=_0x28a4f3 instanceof Error?_0x28a4f3:new Error(_0x3f5bef[_0x4b313f(0x165)](String,_0x28a4f3));_0x3f5bef['HUltB'](logUncaughtError,_0x3f5bef[_0x4b313f(0x19b)],_0x247adc);}),process['on']('warning',_0x2db958=>{const _0x505576=_0x12d715;logger['warn']({'event':'process_warning','name':_0x2db958['name'],'message':_0x2db958[_0x505576(0x1ac)],'stack':_0x2db958[_0x505576(0x156)]},_0x505576(0x18d)+_0x2db958['message']);});const _0x26df4d={'event':_0x3f5bef['JDxww']},_0x5a96d9=_0x3f5bef[_0x12d715(0x1c6)];logger[_0x12d715(0x1bd)](_0x26df4d,_0x5a96d9),_0x3f5bef[_0x12d715(0x1fb)](writeToFileLog,{..._0x26df4d,'level':_0x3f5bef[_0x12d715(0x1c3)],'msg':_0x5a96d9,'time':new Date()['toISOString']()},_0x3f5bef[_0x12d715(0x1c3)]);},createErrorHandlerMiddleware=()=>{const _0x41bf8b={'PhawI':function(_0x123aab,_0x248d93,_0x2f68f0){return _0x123aab(_0x248d93,_0x2f68f0);}};return(_0x488e8b,_0xe3318c,_0x2b4b07,_0x4448ee)=>{const _0x263383=a0_0x3384;_0x41bf8b['PhawI'](logHttpError,_0x488e8b,_0xe3318c);const _0x122fd5=_0x488e8b[_0x263383(0x1ab)]||_0x488e8b[_0x263383(0x1d3)]||0x1f4;_0x2b4b07['status'](_0x122fd5)['json']({'success':![],'error':_0x122fd5>=0x1f4?_0x263383(0x197):_0x488e8b['message'],'requestId':_0xe3318c['id']||_0xe3318c[_0x263383(0x1af)]?.['x-request-id']||null});};};module[a0_0x43a32d(0x1bb)]={'logger':logger,'createRequestLogger':createRequestLogger,'logServerStart':logServerStart,'logServerReady':logServerReady,'logProjectLoaded':logProjectLoaded,'logEndpointRegistered':logEndpointRegistered,'logDatabaseConfig':logDatabaseConfig,'logRequest':logRequest,'logQuery':logQuery,'logTransaction':logTransaction,'startQueryTimer':startQueryTimer,'parseQueryMetadata':parseQueryMetadata,'redactSensitiveParams':redactSensitiveParams,'initFileLogging':initFileLogging,'logError':logError,'logFatalError':logFatalError,'logHttpError':logHttpError,'logUncaughtError':logUncaughtError,'setupGlobalErrorHandlers':setupGlobalErrorHandlers,'createErrorHandlerMiddleware':createErrorHandlerMiddleware,'redactObject':redactObject,'SQL_LOG_CONFIG':{'enabled':sqlLogEnabled,'level':sqlLogLevel,'logParams':sqlLogParams,'slowThreshold':sqlLogSlowThreshold},'FILE_LOG_CONFIG':{'enabled':logToFile,'directory':logDir,'serviceName':serviceName}};
1
+ const a0_0x2cb5eb=a0_0x343d;(function(_0x2191af,_0x1b115e){const _0x1972eb=a0_0x343d,_0x32eede=_0x2191af();while(!![]){try{const _0x43c5d6=-parseInt(_0x1972eb(0x12a))/0x1+-parseInt(_0x1972eb(0x186))/0x2+parseInt(_0x1972eb(0x18c))/0x3+-parseInt(_0x1972eb(0x13b))/0x4*(-parseInt(_0x1972eb(0x190))/0x5)+-parseInt(_0x1972eb(0xee))/0x6*(parseInt(_0x1972eb(0x184))/0x7)+-parseInt(_0x1972eb(0x15e))/0x8+parseInt(_0x1972eb(0x126))/0x9*(parseInt(_0x1972eb(0x139))/0xa);if(_0x43c5d6===_0x1b115e)break;else _0x32eede['push'](_0x32eede['shift']());}catch(_0x2afb0e){_0x32eede['push'](_0x32eede['shift']());}}}(a0_0x3b5a,0xce941));const pino=require(a0_0x2cb5eb(0xff)),fs=require('fs'),path=require('path');let logToFile=![],logDir='./logs',serviceName=a0_0x2cb5eb(0x17e),sqlLogEnabled=![],sqlLogLevel='debug',sqlLogParams=!![],sqlLogSlowThreshold=0x3e8,fileLoggingInitialized=![],appLogStream=null,errorLogStream=null;function a0_0x343d(_0x55ce53,_0x564001){_0x55ce53=_0x55ce53-0xeb;const _0x3b5a11=a0_0x3b5a();let _0x343d40=_0x3b5a11[_0x55ce53];if(a0_0x343d['auEhAs']===undefined){var _0x1382c5=function(_0x396360){const _0x473712='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x256fdc='',_0x576902='';for(let _0x30cbce=0x0,_0x26d7f0,_0x4dec75,_0x5b2b5a=0x0;_0x4dec75=_0x396360['charAt'](_0x5b2b5a++);~_0x4dec75&&(_0x26d7f0=_0x30cbce%0x4?_0x26d7f0*0x40+_0x4dec75:_0x4dec75,_0x30cbce++%0x4)?_0x256fdc+=String['fromCharCode'](0xff&_0x26d7f0>>(-0x2*_0x30cbce&0x6)):0x0){_0x4dec75=_0x473712['indexOf'](_0x4dec75);}for(let _0x3ea2d6=0x0,_0x2f0360=_0x256fdc['length'];_0x3ea2d6<_0x2f0360;_0x3ea2d6++){_0x576902+='%'+('00'+_0x256fdc['charCodeAt'](_0x3ea2d6)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x576902);};a0_0x343d['tGMHqp']=_0x1382c5,a0_0x343d['KxtLzF']={},a0_0x343d['auEhAs']=!![];}const _0x2fabf3=_0x3b5a11[0x0],_0x797d6d=_0x55ce53+_0x2fabf3,_0x18a18a=a0_0x343d['KxtLzF'][_0x797d6d];return!_0x18a18a?(_0x343d40=a0_0x343d['tGMHqp'](_0x343d40),a0_0x343d['KxtLzF'][_0x797d6d]=_0x343d40):_0x343d40=_0x18a18a,_0x343d40;}const prettyPrintOptions={'colorize':!![],'translateTime':a0_0x2cb5eb(0x155),'ignore':a0_0x2cb5eb(0xed),'singleLine':![],'levelFirst':!![],'messageFormat':'{msg}','customColors':a0_0x2cb5eb(0x17c),'hideObject':!![]},isDevelopment=process[a0_0x2cb5eb(0x15a)]['NODE_ENV']!==a0_0x2cb5eb(0x12d),logLevel=process[a0_0x2cb5eb(0x15a)]['LOG_LEVEL']||a0_0x2cb5eb(0x102);let logger=pino({'level':logLevel,'transport':isDevelopment?{'target':'pino-pretty','options':prettyPrintOptions}:undefined,'base':{'service':a0_0x2cb5eb(0x17e),'version':process['env'][a0_0x2cb5eb(0x1a5)]||'1.0.5','env':process['env']['NODE_ENV']||'development'},'timestamp':pino[a0_0x2cb5eb(0x10f)][a0_0x2cb5eb(0x199)],'redact':{'paths':[a0_0x2cb5eb(0x191),a0_0x2cb5eb(0x116),a0_0x2cb5eb(0xfb),a0_0x2cb5eb(0x108),a0_0x2cb5eb(0x181),a0_0x2cb5eb(0x114),a0_0x2cb5eb(0x14d)],'censor':a0_0x2cb5eb(0x137)},'serializers':{'req':_0xf24924=>({'id':_0xf24924['id'],'method':_0xf24924[a0_0x2cb5eb(0x106)],'url':_0xf24924[a0_0x2cb5eb(0xf1)],'path':_0xf24924[a0_0x2cb5eb(0x167)],'remoteAddress':_0xf24924['ip']||_0xf24924['connection']?.['remoteAddress']}),'res':_0x1c0f40=>({'statusCode':_0x1c0f40[a0_0x2cb5eb(0x133)],'headers':_0x1c0f40['getHeaders']?.()}),'err':pino['stdSerializers']['err']}});function initFileLogging(){const _0x2aec58=a0_0x2cb5eb,_0x4901db={'KgVLf':function(_0x2485f6,_0x530f3a){return _0x2485f6===_0x530f3a;},'dOcFF':_0x2aec58(0x169),'wfbdH':function(_0xc118ad,_0x8070a7){return _0xc118ad===_0x8070a7;},'ykOAj':'app.log','isllT':_0x2aec58(0x162),'uYudy':_0x2aec58(0x16a),'IwfwZ':function(_0x3942f6,_0x51733c,_0x1d0e84){return _0x3942f6(_0x51733c,_0x1d0e84);},'wLXWZ':_0x2aec58(0x102)};if(fileLoggingInitialized)return;logToFile=_0x4901db[_0x2aec58(0x154)](process['env'][_0x2aec58(0x182)],_0x4901db[_0x2aec58(0x14f)]);const _0x485937=process[_0x2aec58(0x15a)]['RESTFORGE_PROJECT_NAME']||_0x2aec58(0x164);logDir=process['env'][_0x2aec58(0x153)]||_0x2aec58(0x14e)+_0x485937,serviceName=process['env']['SERVICE_NAME']||'restforge',sqlLogEnabled=_0x4901db[_0x2aec58(0x175)](process[_0x2aec58(0x15a)][_0x2aec58(0x149)],_0x2aec58(0x169)),sqlLogLevel=process['env'][_0x2aec58(0x18b)]||'debug',sqlLogParams=process['env']['SQL_LOG_PARAMS']!=='false',sqlLogSlowThreshold=parseInt(process[_0x2aec58(0x15a)]['SQL_LOG_SLOW_THRESHOLD'])||0x3e8;if(!logToFile){fileLoggingInitialized=!![];return;}const _0x108c8a=path['resolve'](process[_0x2aec58(0x18f)](),logDir);try{!fs[_0x2aec58(0x18e)](_0x108c8a)&&fs[_0x2aec58(0x1a6)](_0x108c8a,{'recursive':!![]});}catch(_0x4d2fe1){console[_0x2aec58(0x109)]('Failed\x20to\x20create\x20log\x20directory\x20'+_0x108c8a+':',_0x4d2fe1['message']),fileLoggingInitialized=!![];return;}const _0x59e322=path['join'](_0x108c8a,_0x4901db[_0x2aec58(0x16f)]),_0x55fae2=path['join'](_0x108c8a,_0x4901db[_0x2aec58(0x13e)]);try{appLogStream=fs['createWriteStream'](_0x59e322,{'flags':'a'}),errorLogStream=fs['createWriteStream'](_0x55fae2,{'flags':'a'}),fileLoggingInitialized=!![];const _0x35c01a={'event':_0x4901db['uYudy'],'logDir':_0x108c8a,'files':[_0x2aec58(0x168),_0x4901db['isllT']]},_0x3e08fc=_0x2aec58(0x122)+_0x108c8a;logger[_0x2aec58(0x102)](_0x35c01a,_0x3e08fc),_0x4901db[_0x2aec58(0x110)](writeToFileLog,{..._0x35c01a,'level':'info','msg':_0x3e08fc,'time':new Date()[_0x2aec58(0xf8)]()},_0x4901db[_0x2aec58(0x1a3)]);}catch(_0x2d0192){console['error']('Failed\x20to\x20create\x20log\x20streams:',_0x2d0192[_0x2aec58(0xf3)]),fileLoggingInitialized=!![];}}function writeToFileLog(_0x51bb5b,_0x1820d5){const _0x5014df=a0_0x2cb5eb,_0x3460ac={'HhBAy':function(_0x8a0b4a,_0x319007){return _0x8a0b4a||_0x319007;},'YTINZ':function(_0x483555,_0x5790be){return _0x483555+_0x5790be;},'VhnCN':function(_0x2758e3,_0x498898){return _0x2758e3===_0x498898;},'oYANE':function(_0x4761ec,_0x570237){return _0x4761ec===_0x570237;},'LQLRT':'fatal'};if(_0x3460ac['HhBAy'](!logToFile,!appLogStream))return;const _0x4940a6={'service':serviceName,..._0x51bb5b},_0xf2c9a6=_0x3460ac[_0x5014df(0x176)](JSON[_0x5014df(0x198)](_0x4940a6),'\x0a');appLogStream['write'](_0xf2c9a6),(_0x3460ac[_0x5014df(0x172)](_0x1820d5,'error')||_0x3460ac[_0x5014df(0x13a)](_0x1820d5,_0x3460ac[_0x5014df(0x197)]))&&(errorLogStream&&errorLogStream[_0x5014df(0x11c)](_0xf2c9a6));}const createRequestLogger=(_0x5db6cb={})=>{return logger['child'](_0x5db6cb);},logServerStart=_0x107917=>{const _0x3de06b=a0_0x2cb5eb,_0x223d83={'LdBIU':'RESTFORGE\x20RUNTIME\x20SERVER','fDGhL':function(_0xc87fc1,_0x278e4a){return _0xc87fc1-_0x278e4a;},'pFmyR':function(_0x429be0,_0x480e3c){return _0x429be0-_0x480e3c;},'dObyb':_0x3de06b(0x124),'oHAmq':function(_0x2131e0,_0x3bce2d){return _0x2131e0(_0x3bce2d);},'lgvrO':'Default','YEHkU':'NOT\x20ACTIVE','jDkAA':'server_starting','JCInW':_0x3de06b(0x102)},_0xfa6315=_0x223d83['LdBIU'],_0xe2b276=Math['max'](0x0,_0x223d83['fDGhL'](0x37,_0xfa6315['length'])),_0x19ac73=Math['floor'](_0xe2b276/0x2),_0x3504b5=_0x223d83[_0x3de06b(0x178)](_0xe2b276,_0x19ac73),_0x271432='║'+'\x20'[_0x3de06b(0x11b)](_0x19ac73)+_0xfa6315+'\x20'['repeat'](_0x3504b5)+'║',_0x520766=_0x3de06b(0x150)+_0x271432+'\x0a╠═══════════════════════════════════════════════════════╣\x0a║\x20\x20Environment\x20:\x20'+(_0x107917[_0x3de06b(0x146)]||'Node.js')[_0x3de06b(0xfa)](0x26)+_0x3de06b(0x17a)+(_0x107917[_0x3de06b(0x131)]||_0x223d83[_0x3de06b(0xf2)])[_0x3de06b(0xfa)](0x26)+'\x20║\x0a║\x20\x20Port\x20\x20\x20\x20\x20\x20\x20\x20:\x20'+_0x223d83[_0x3de06b(0x195)](String,_0x107917[_0x3de06b(0x19d)]||0xbb8)[_0x3de06b(0xfa)](0x26)+_0x3de06b(0x113)+(_0x107917['configFile']||_0x223d83[_0x3de06b(0x10b)])['padEnd'](0x26)+'\x20║\x0a║\x20\x20API\x20Key\x20\x20\x20\x20\x20:\x20'+(_0x107917[_0x3de06b(0x181)]?'ACTIVE':_0x223d83['YEHkU'])['padEnd'](0x26)+'\x20║\x0a╚═══════════════════════════════════════════════════════╝';console[_0x3de06b(0x112)](_0x520766);const _0x2d8944={'event':_0x223d83[_0x3de06b(0x189)],'project':_0x107917['project'],'port':_0x107917['port'],'config':_0x107917['configFile'],'apiKeyEnabled':!!_0x107917['apiKey']};logger[_0x3de06b(0x102)](_0x2d8944),writeToFileLog({..._0x2d8944,'level':_0x223d83['JCInW'],'msg':_0x3de06b(0x130)+_0x107917['project']+_0x3de06b(0x157)+_0x107917['port'],'time':new Date()[_0x3de06b(0xf8)]()},_0x3de06b(0x102));},logServerReady=_0xf8cefb=>{const _0x2f82a1=a0_0x2cb5eb,_0x5f214d={'RBlrH':'server_ready','noESN':_0x2f82a1(0x102)},_0x182284={'event':_0x5f214d['RBlrH'],'port':_0xf8cefb['port'],'module':_0xf8cefb['module'],'healthCheck':_0xf8cefb[_0x2f82a1(0x18d)],'serviceInfo':_0xf8cefb[_0x2f82a1(0x1a7)],'baseUrl':_0xf8cefb[_0x2f82a1(0x159)]},_0xfc6934=_0x2f82a1(0x147)+_0xf8cefb['port'];logger['info'](_0x182284,_0xfc6934),writeToFileLog({..._0x182284,'level':'info','msg':_0xfc6934,'time':new Date()[_0x2f82a1(0xf8)]()},_0x5f214d[_0x2f82a1(0xfc)]),_0xf8cefb['healthCheck']&&logger['info'](_0x2f82a1(0x17f)+_0xf8cefb[_0x2f82a1(0x18d)]),_0xf8cefb['serviceInfo']&&logger['info'](_0x2f82a1(0x173)+_0xf8cefb[_0x2f82a1(0x1a7)]),_0xf8cefb[_0x2f82a1(0x159)]&&logger['info']('\x20\x20URL:\x20\x20\x20\x20'+_0xf8cefb[_0x2f82a1(0x159)]);},logProjectLoaded=(_0x506f57,_0x4ae778)=>{const _0x8578cf=a0_0x2cb5eb,_0x2b1534={'bkgfG':'project_loaded','DGtqH':_0x8578cf(0x102)},_0x19cb35={'event':_0x2b1534['bkgfG'],'project':_0x506f57,'path':_0x4ae778},_0x107457='[OK]\x20Project\x20loaded:\x20'+_0x506f57;logger['info'](_0x19cb35,_0x107457),writeToFileLog({..._0x19cb35,'level':_0x2b1534[_0x8578cf(0x19f)],'msg':_0x107457,'time':new Date()[_0x8578cf(0xf8)]()},_0x2b1534['DGtqH']);},logEndpointRegistered=(_0x564161,_0x414292)=>{const _0x209f9c=a0_0x2cb5eb,_0x4a26d0={'QuWEy':_0x209f9c(0xf9),'dSvMn':function(_0x1d74da,_0x2bce54,_0x3db8eb){return _0x1d74da(_0x2bce54,_0x3db8eb);},'KSAGT':_0x209f9c(0x19e)},_0x31fed1={'event':_0x4a26d0[_0x209f9c(0x11d)],'endpoint':_0x564161,'route':_0x414292},_0x22dec1='\x20\x20→\x20'+_0x564161+':\x20'+_0x414292;logger[_0x209f9c(0x19e)](_0x31fed1,_0x22dec1),_0x4a26d0['dSvMn'](writeToFileLog,{..._0x31fed1,'level':_0x209f9c(0x19e),'msg':_0x22dec1,'time':new Date()['toISOString']()},_0x4a26d0[_0x209f9c(0x15c)]);},logDatabaseConfig=_0xb28e9d=>{const _0x1f0ad4=a0_0x2cb5eb,_0x2c8591={'tGjIA':_0x1f0ad4(0x15b),'uTsIx':_0x1f0ad4(0x19e)},_0x385ca4={'event':_0x2c8591['tGjIA'],'host':_0xb28e9d[_0x1f0ad4(0x129)],'port':_0xb28e9d['port'],'database':_0xb28e9d['database'],'type':_0xb28e9d['type'],'user':_0xb28e9d[_0x1f0ad4(0x119)]},_0x42ab40=_0x1f0ad4(0x140)+_0xb28e9d[_0x1f0ad4(0x192)]+'://'+_0xb28e9d['host']+':'+_0xb28e9d['port']+'/'+_0xb28e9d[_0x1f0ad4(0x138)];logger[_0x1f0ad4(0x19e)](_0x385ca4,_0x42ab40),writeToFileLog({..._0x385ca4,'level':'debug','msg':_0x42ab40,'time':new Date()[_0x1f0ad4(0xf8)]()},_0x2c8591['uTsIx']);},logRequest=(_0x41d7da,_0x22d024,_0x4b06e6)=>{const _0x46aba2=a0_0x2cb5eb,_0x36eb95={'pxPBv':function(_0x3919c8,_0x3c0712){return _0x3919c8>=_0x3c0712;},'ZCsBF':function(_0x3058fb,_0x2124eb,_0x4cd77f){return _0x3058fb(_0x2124eb,_0x4cd77f);}},_0x3ce2={'event':'http_request','method':_0x41d7da[_0x46aba2(0x106)],'path':_0x41d7da['path'],'statusCode':_0x22d024['statusCode'],'durationMs':_0x4b06e6,'ip':_0x41d7da['ip']},_0x3837e3=_0x41d7da[_0x46aba2(0x106)]+'\x20'+_0x41d7da['path']+_0x46aba2(0x13d)+_0x22d024['statusCode']+'\x20('+_0x4b06e6+_0x46aba2(0x127);let _0x455bcb=_0x46aba2(0x102);if(_0x22d024[_0x46aba2(0x133)]>=0x1f4)_0x455bcb=_0x46aba2(0x109),logger[_0x46aba2(0x109)](_0x3ce2,_0x3837e3);else _0x36eb95['pxPBv'](_0x22d024[_0x46aba2(0x133)],0x190)?(_0x455bcb=_0x46aba2(0x17b),logger['warn'](_0x3ce2,_0x3837e3)):logger[_0x46aba2(0x102)](_0x3ce2,_0x3837e3);_0x36eb95['ZCsBF'](writeToFileLog,{..._0x3ce2,'level':_0x455bcb,'msg':_0x3837e3,'time':new Date()[_0x46aba2(0xf8)]()},_0x455bcb);},SENSITIVE_PARAM_PATTERNS=['password','passwd','pwd',a0_0x2cb5eb(0x108),a0_0x2cb5eb(0x107),a0_0x2cb5eb(0x165),a0_0x2cb5eb(0x144),a0_0x2cb5eb(0x11e),'apikey',a0_0x2cb5eb(0x166),a0_0x2cb5eb(0x135),'credentials','pin',a0_0x2cb5eb(0x16e),a0_0x2cb5eb(0x187),'privatekey'],redactSensitiveParams=(_0xe6909,_0x2b456b)=>{const _0x57e94c=a0_0x2cb5eb,_0x954c83={'UmBlk':_0x57e94c(0x137),'dANST':function(_0x17a381,_0x11d7a8){return _0x17a381>_0x11d7a8;}};if(!_0xe6909||_0xe6909['length']===0x0)return _0xe6909;const _0x4aba8f=_0x2b456b['toLowerCase'](),_0x327589=_0x4aba8f[_0x57e94c(0x101)](/\(([^)]+)\)\s*values/i);let _0xc51fc5=[];_0x327589&&(_0xc51fc5=_0x327589[0x1][_0x57e94c(0x12f)](',')[_0x57e94c(0x1a9)](_0x4a2c75=>_0x4a2c75[_0x57e94c(0x10d)]()[_0x57e94c(0x120)]()));const _0x115c2f=_0x4aba8f[_0x57e94c(0x101)](/set\s+(.+?)(?:\s+where|$)/i);if(_0x115c2f){const _0x4fcc65=_0x115c2f[0x1],_0x584e51=_0x4fcc65['match'](/(\w+)\s*=/g);_0x584e51&&(_0xc51fc5=_0x584e51['map'](_0x5c365a=>_0x5c365a['replace'](/\s*=/,'')[_0x57e94c(0x10d)]()['toLowerCase']()));}return _0xe6909['map']((_0x110aad,_0x3b87d6)=>{const _0x4be26b=_0x57e94c;if(_0xc51fc5[_0x3b87d6]){const _0x2f0996=_0xc51fc5[_0x3b87d6],_0x2c50ec=SENSITIVE_PARAM_PATTERNS[_0x4be26b(0xf7)](_0x16289f=>_0x2f0996[_0x4be26b(0x142)](_0x16289f));if(_0x2c50ec)return _0x954c83['UmBlk'];}if(typeof _0x110aad==='string'&&_0x954c83['dANST'](_0x110aad[_0x4be26b(0xfe)],0x20)){if(/^[a-zA-Z0-9+/=_.-]+$/['test'](_0x110aad)&&_0x110aad[_0x4be26b(0x142)]('.'))return'[REDACTED:token]';if(/^[a-fA-F0-9]{32,}$/['test'](_0x110aad))return _0x4be26b(0x179);}return _0x110aad;});},parseQueryMetadata=_0x5bd8e7=>{const _0x3a936b=a0_0x2cb5eb,_0x2ea963={'SQuxi':_0x3a936b(0x171),'FiDQP':'SELECT','XGiRy':_0x3a936b(0x170),'SryiA':'DELETE','owuvT':_0x3a936b(0x161),'AoNAG':_0x3a936b(0x118),'tyAml':'DDL_CREATE','KSHNh':_0x3a936b(0x160)},_0x180daf=_0x5bd8e7[_0x3a936b(0x10d)](),_0x2317e0=_0x180daf[_0x3a936b(0x19b)]();let _0x2de672=_0x2ea963[_0x3a936b(0x1a4)],_0x1fd995=null;if(_0x2317e0[_0x3a936b(0x115)](_0x2ea963['FiDQP'])){_0x2de672=_0x3a936b(0x1a8);const _0x535a17=_0x180daf[_0x3a936b(0x101)](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x1fd995=_0x535a17?_0x535a17[0x1]:null;}else{if(_0x2317e0['startsWith'](_0x3a936b(0x11f))){_0x2de672=_0x3a936b(0x11f);const _0x30493f=_0x180daf[_0x3a936b(0x101)](/INTO\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x1fd995=_0x30493f?_0x30493f[0x1]:null;}else{if(_0x2317e0['startsWith'](_0x2ea963['XGiRy'])){_0x2de672=_0x3a936b(0x170);const _0x46c637=_0x180daf[_0x3a936b(0x101)](/UPDATE\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x1fd995=_0x46c637?_0x46c637[0x1]:null;}else{if(_0x2317e0['startsWith'](_0x3a936b(0x123))){_0x2de672=_0x2ea963[_0x3a936b(0x185)];const _0x3ca9c6=_0x180daf['match'](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x1fd995=_0x3ca9c6?_0x3ca9c6[0x1]:null;}else{if(_0x2317e0['startsWith']('BEGIN')||_0x2317e0['startsWith']('START\x20TRANSACTION'))_0x2de672=_0x3a936b(0x134);else{if(_0x2317e0['startsWith'](_0x2ea963['owuvT']))_0x2de672=_0x2ea963['AoNAG'];else{if(_0x2317e0[_0x3a936b(0x115)](_0x3a936b(0x16b)))_0x2de672='TRANSACTION_ROLLBACK';else{if(_0x2317e0['startsWith'](_0x3a936b(0x121)))_0x2de672=_0x2ea963[_0x3a936b(0x12c)];else{if(_0x2317e0[_0x3a936b(0x115)](_0x3a936b(0x156)))_0x2de672=_0x3a936b(0xec);else _0x2317e0[_0x3a936b(0x115)](_0x2ea963['KSHNh'])&&(_0x2de672='DDL_DROP');}}}}}}}}return{'type':_0x2de672,'table':_0x1fd995};},startQueryTimer=()=>{const _0xcf1b96=a0_0x2cb5eb,_0x21d484={'lThcx':function(_0x28ff82,_0x45df90){return _0x28ff82*_0x45df90;}},_0x557b5e=process[_0xcf1b96(0x163)]();return()=>{const _0x2233ae=_0xcf1b96,[_0x9de7b2,_0x210fed]=process['hrtime'](_0x557b5e);return parseFloat((_0x21d484[_0x2233ae(0x12b)](_0x9de7b2,0x3e8)+_0x210fed/0xf4240)['toFixed'](0x2));};},logQuery=(_0x30a1d3,_0x4d9c42=[],_0x233abf={})=>{const _0x1bc5e8=a0_0x2cb5eb,_0xd2e655={'pJwvA':'DB\x20Query','UPtgA':function(_0x35dc33,_0x392896){return _0x35dc33>_0x392896;},'xWMfb':function(_0x386322,_0x3de178,_0x22fad0){return _0x386322(_0x3de178,_0x22fad0);},'EfoFx':function(_0x231023,_0xddc6ac){return _0x231023!==_0xddc6ac;},'cVPMd':function(_0x2e6e64,_0xc28b29){return _0x2e6e64!==_0xc28b29;},'hSSdn':_0x1bc5e8(0xf0),'vFMve':function(_0x47d70c,_0x58809c){return _0x47d70c===_0x58809c;},'DsxEl':'info','VGzdG':function(_0x2d9ea0,_0x5d6805,_0x5a0e12){return _0x2d9ea0(_0x5d6805,_0x5a0e12);}};if(!sqlLogEnabled){logger['debug']({'event':'db_query','query':_0x30a1d3['substring'](0x0,0xc8),'paramCount':_0x4d9c42['length']},_0xd2e655[_0x1bc5e8(0x1a2)]);return;}const {duration:duration=null,rowsAffected:rowsAffected=null,dbType:dbType='postgresql'}=_0x233abf,{type:_0x3a06ae,table:_0x128685}=parseQueryMetadata(_0x30a1d3),_0x1f921d={'event':'sql_query','queryType':_0x3a06ae,'table':_0x128685,'query':_0x30a1d3,'paramCount':_0x4d9c42['length'],'dbType':dbType};sqlLogParams&&_0xd2e655[_0x1bc5e8(0x177)](_0x4d9c42['length'],0x0)&&(_0x1f921d[_0x1bc5e8(0x103)]=_0xd2e655[_0x1bc5e8(0x100)](redactSensitiveParams,_0x4d9c42,_0x30a1d3));_0xd2e655['EfoFx'](duration,null)&&(_0x1f921d[_0x1bc5e8(0x196)]=duration,_0x1f921d['isSlow']=duration>sqlLogSlowThreshold);_0xd2e655['cVPMd'](rowsAffected,null)&&(_0x1f921d['rowsAffected']=rowsAffected);const _0x43d3cb=_0x128685||_0xd2e655[_0x1bc5e8(0x14a)];let _0x4812eb='['+_0x3a06ae+']\x20'+_0x43d3cb;_0xd2e655['cVPMd'](duration,null)&&(_0x4812eb+='\x20('+duration+'ms)');const _0x1cdc3f=duration!==null&&duration>sqlLogSlowThreshold;let _0x4e013a=_0x1bc5e8(0x19e);if(_0x1cdc3f)_0x4812eb+='\x20[SLOW]',_0x4e013a=_0x1bc5e8(0x17b),logger[_0x1bc5e8(0x17b)](_0x1f921d,_0x4812eb);else _0xd2e655[_0x1bc5e8(0x125)](sqlLogLevel,_0xd2e655[_0x1bc5e8(0x14c)])?(_0x4e013a=_0xd2e655[_0x1bc5e8(0x14c)],logger['info'](_0x1f921d,_0x4812eb)):logger[_0x1bc5e8(0x19e)](_0x1f921d,_0x4812eb);_0xd2e655[_0x1bc5e8(0x117)](writeToFileLog,{..._0x1f921d,'level':_0x4e013a,'msg':_0x4812eb,'time':new Date()['toISOString']()},_0x4e013a);},logTransaction=(_0x232618,_0x9c2f82)=>{const _0x3483aa=a0_0x2cb5eb,_0x1f99ff={'aeOAn':_0x3483aa(0x16d),'UfKXE':function(_0x340304,_0x13f139,_0x5ebcf5){return _0x340304(_0x13f139,_0x5ebcf5);},'CEbNU':'debug'},_0x1d37ca={'event':_0x1f99ff['aeOAn'],'status':_0x232618,'queryCount':_0x9c2f82},_0x20cc99='Transaction\x20'+_0x232618;logger['debug'](_0x1d37ca,_0x20cc99),_0x1f99ff['UfKXE'](writeToFileLog,{..._0x1d37ca,'level':_0x3483aa(0x19e),'msg':_0x20cc99,'time':new Date()[_0x3483aa(0xf8)]()},_0x1f99ff[_0x3483aa(0xf6)]);},redactObject=_0x5c0d7f=>{const _0x5243f4=a0_0x2cb5eb,_0x527f1c={'yxOsw':'object','sXXNT':'password','AKJPh':_0x5243f4(0x19c),'MpxLd':_0x5243f4(0xef),'SlGGl':_0x5243f4(0x141),'yPOQp':'creditcard','qwUJf':_0x5243f4(0x17d),'ZuvkS':'cvv','LPDtE':'ssn','DxoXF':'private_key','OjwwZ':'privatekey'};if(!_0x5c0d7f||typeof _0x5c0d7f!==_0x527f1c[_0x5243f4(0xf5)])return _0x5c0d7f;const _0x3a5a75=[_0x527f1c['sXXNT'],_0x527f1c[_0x5243f4(0x19a)],_0x527f1c['MpxLd'],_0x5243f4(0x108),'secret','apikey','api_key',_0x527f1c[_0x5243f4(0x105)],_0x527f1c['yPOQp'],_0x527f1c['qwUJf'],_0x527f1c['ZuvkS'],_0x527f1c[_0x5243f4(0x14b)],'pin',_0x527f1c[_0x5243f4(0x10c)],_0x527f1c[_0x5243f4(0x10e)],_0x5243f4(0x165),_0x5243f4(0x107)],_0x53f0ce=Array[_0x5243f4(0x15d)](_0x5c0d7f)?[..._0x5c0d7f]:{..._0x5c0d7f};for(const _0x1727ec of Object[_0x5243f4(0x132)](_0x53f0ce)){const _0x1d1f58=_0x1727ec['toLowerCase']();if(_0x3a5a75[_0x5243f4(0xf7)](_0x15a336=>_0x1d1f58[_0x5243f4(0x142)](_0x15a336)))_0x53f0ce[_0x1727ec]='[REDACTED]';else typeof _0x53f0ce[_0x1727ec]===_0x527f1c['yxOsw']&&_0x53f0ce[_0x1727ec]!==null&&(_0x53f0ce[_0x1727ec]=redactObject(_0x53f0ce[_0x1727ec]));}return _0x53f0ce;},logError=(_0x1b9ece,_0x5b2e2c={},_0x4ec409=null)=>{const _0x4ebc8a=a0_0x2cb5eb,_0x1de364={'xmYLF':'Error','KIAGf':function(_0x3302ce,_0x3b29a0,_0x46a8b9){return _0x3302ce(_0x3b29a0,_0x46a8b9);},'ntuBK':_0x4ebc8a(0x109)},_0x5d71cf={'event':'error','errorName':_0x1b9ece[_0x4ebc8a(0xf4)]||_0x1de364['xmYLF'],'errorMessage':_0x1b9ece[_0x4ebc8a(0xf3)],'errorCode':_0x1b9ece['code']||null,'stack':_0x1b9ece['stack'],..._0x5b2e2c},_0x2ba41c=_0x4ec409||'Error:\x20'+_0x1b9ece[_0x4ebc8a(0xf3)];logger['error'](_0x5d71cf,_0x2ba41c),_0x1de364['KIAGf'](writeToFileLog,{..._0x5d71cf,'level':'error','msg':_0x2ba41c,'time':new Date()['toISOString']()},_0x1de364[_0x4ebc8a(0x158)]);},logFatalError=(_0xe46bb2,_0x4b6a8c={},_0x40f939=null)=>{const _0x4db51e=a0_0x2cb5eb,_0x2882c2={'PCWmp':_0x4db51e(0x12e),'TTwPA':function(_0x38bbff,_0x148156,_0x4d8bd7){return _0x38bbff(_0x148156,_0x4d8bd7);},'OqszI':'fatal'},_0x1386ab={'event':_0x4db51e(0xeb),'errorName':_0xe46bb2[_0x4db51e(0xf4)]||_0x4db51e(0xfd),'errorMessage':_0xe46bb2['message'],'errorCode':_0xe46bb2[_0x4db51e(0x193)]||null,'stack':_0xe46bb2[_0x4db51e(0x151)],'severity':_0x2882c2['PCWmp'],..._0x4b6a8c},_0xc5ae5a=_0x40f939||'FATAL:\x20'+_0xe46bb2['message'];logger['fatal'](_0x1386ab,_0xc5ae5a),_0x2882c2['TTwPA'](writeToFileLog,{..._0x1386ab,'level':_0x2882c2['OqszI'],'msg':_0xc5ae5a,'time':new Date()['toISOString']()},'error');},logHttpError=(_0x51c4c2,_0x4e3f11,_0x14203b={})=>{const _0x130a5f=a0_0x2cb5eb,_0x46a172={'WWrgh':'http_error','oGDWN':_0x130a5f(0xfd),'UeBxw':_0x130a5f(0x18a),'xqGaZ':function(_0x35ae2e,_0x266c7f,_0x58d6e2){return _0x35ae2e(_0x266c7f,_0x58d6e2);},'KxfZD':_0x130a5f(0x17b),'eWSLs':function(_0x56fe2f,_0x2f832c){return _0x56fe2f>=_0x2f832c;},'mDyKK':_0x130a5f(0x109)},_0x5c4513={'event':_0x46a172[_0x130a5f(0x194)],'errorName':_0x51c4c2['name']||_0x46a172[_0x130a5f(0x1a1)],'errorMessage':_0x51c4c2[_0x130a5f(0xf3)],'errorCode':_0x51c4c2[_0x130a5f(0x193)]||_0x51c4c2['statusCode']||0x1f4,'stack':_0x51c4c2[_0x130a5f(0x151)],'method':_0x4e3f11?.[_0x130a5f(0x106)],'url':_0x4e3f11?.[_0x130a5f(0xf1)]||_0x4e3f11?.['originalUrl'],'path':_0x4e3f11?.[_0x130a5f(0x167)],'ip':_0x4e3f11?.['ip']||_0x4e3f11?.['connection']?.['remoteAddress'],'userAgent':_0x4e3f11?.[_0x130a5f(0x183)]?.(_0x46a172[_0x130a5f(0x174)]),'requestId':_0x4e3f11?.['id']||_0x4e3f11?.['headers']?.[_0x130a5f(0x136)],'body':_0x4e3f11?.[_0x130a5f(0x180)]?redactObject(_0x4e3f11[_0x130a5f(0x180)]):undefined,'query':_0x4e3f11?.['query'],..._0x14203b},_0x4cbc41=_0x51c4c2['statusCode']||_0x51c4c2['status']||0x1f4,_0x83ceea='HTTP\x20'+_0x4cbc41+':\x20'+_0x51c4c2[_0x130a5f(0xf3)];_0x4cbc41>=0x1f4?logger[_0x130a5f(0x109)](_0x5c4513,_0x83ceea):logger[_0x130a5f(0x17b)](_0x5c4513,_0x83ceea),_0x46a172['xqGaZ'](writeToFileLog,{..._0x5c4513,'level':_0x4cbc41>=0x1f4?_0x130a5f(0x109):_0x46a172[_0x130a5f(0x128)],'msg':_0x83ceea,'time':new Date()[_0x130a5f(0xf8)]()},_0x46a172['eWSLs'](_0x4cbc41,0x1f4)?_0x46a172[_0x130a5f(0x16c)]:_0x46a172['KxfZD']);},logUncaughtError=(_0x5813ac,_0x57818b)=>{const _0x33b721=a0_0x2cb5eb,_0x29a6a1={'ROyQu':function(_0x12ddf0,_0x366f5d,_0x3e9e59){return _0x12ddf0(_0x366f5d,_0x3e9e59);}},_0x458d8a={'event':_0x5813ac,'errorName':_0x57818b?.['name']||'Error','errorMessage':_0x57818b?.[_0x33b721(0xf3)]||String(_0x57818b),'errorCode':_0x57818b?.[_0x33b721(0x193)]||null,'stack':_0x57818b?.['stack'],'severity':'CRITICAL','processId':process[_0x33b721(0x145)],'memoryUsage':process[_0x33b721(0x188)](),'uptime':process['uptime']()},_0x39411f='['+_0x5813ac[_0x33b721(0x19b)]()+']\x20'+(_0x57818b?.['message']||_0x57818b);logger['fatal'](_0x458d8a,_0x39411f),_0x29a6a1['ROyQu'](writeToFileLog,{..._0x458d8a,'level':_0x33b721(0x143),'msg':_0x39411f,'time':new Date()['toISOString']()},'error');},setupGlobalErrorHandlers=()=>{const _0x4a008c=a0_0x2cb5eb,_0x53eeed={'vhCYZ':function(_0x3cd791,_0x104649,_0x1850ec){return _0x3cd791(_0x104649,_0x1850ec);},'mewNO':'unhandledRejection','tSiQY':'uncaughtException','zkrQg':_0x4a008c(0x104),'ABaNM':_0x4a008c(0x152),'ecyIk':function(_0x45ce41,_0x4ad77a,_0x1c850c){return _0x45ce41(_0x4ad77a,_0x1c850c);}};process['on'](_0x53eeed['tSiQY'],_0x4a7b5c=>{const _0x25db2c=_0x4a008c;logUncaughtError(_0x25db2c(0x1a0),_0x4a7b5c),_0x53eeed[_0x25db2c(0x10a)](setTimeout,()=>{process['exit'](0x1);},0x3e8);}),process['on'](_0x53eeed['mewNO'],(_0x2d2014,_0x20fdb4)=>{const _0x485f4c=_0x2d2014 instanceof Error?_0x2d2014:new Error(String(_0x2d2014));logUncaughtError(_0x53eeed['mewNO'],_0x485f4c);}),process['on'](_0x4a008c(0x111),_0x1cbddf=>{const _0x4e9f06=_0x4a008c;logger[_0x4e9f06(0x17b)]({'event':_0x4e9f06(0x13c),'name':_0x1cbddf['name'],'message':_0x1cbddf['message'],'stack':_0x1cbddf['stack']},'Process\x20Warning:\x20'+_0x1cbddf['message']);});const _0x1475d5={'event':_0x53eeed['zkrQg']},_0x1a8d1c=_0x53eeed['ABaNM'];logger[_0x4a008c(0x102)](_0x1475d5,_0x1a8d1c),_0x53eeed['ecyIk'](writeToFileLog,{..._0x1475d5,'level':'info','msg':_0x1a8d1c,'time':new Date()['toISOString']()},'info');},createErrorHandlerMiddleware=()=>{const _0x875a27=a0_0x2cb5eb,_0x6699c6={'ufCoC':function(_0x14feb2,_0x23fddc,_0xae4d6e){return _0x14feb2(_0x23fddc,_0xae4d6e);},'epeqn':_0x875a27(0x148)};return(_0x373052,_0x302ed6,_0x2b9ea0,_0x6d67e3)=>{const _0x3e5d5a=_0x875a27;_0x6699c6[_0x3e5d5a(0x13f)](logHttpError,_0x373052,_0x302ed6);const _0x1650ba=_0x373052[_0x3e5d5a(0x133)]||_0x373052[_0x3e5d5a(0x11a)]||0x1f4;_0x2b9ea0[_0x3e5d5a(0x11a)](_0x1650ba)[_0x3e5d5a(0x15f)]({'success':![],'error':_0x1650ba>=0x1f4?_0x6699c6['epeqn']:_0x373052[_0x3e5d5a(0xf3)],'requestId':_0x302ed6['id']||_0x302ed6['headers']?.[_0x3e5d5a(0x136)]||null});};};module['exports']={'logger':logger,'createRequestLogger':createRequestLogger,'logServerStart':logServerStart,'logServerReady':logServerReady,'logProjectLoaded':logProjectLoaded,'logEndpointRegistered':logEndpointRegistered,'logDatabaseConfig':logDatabaseConfig,'logRequest':logRequest,'logQuery':logQuery,'logTransaction':logTransaction,'startQueryTimer':startQueryTimer,'parseQueryMetadata':parseQueryMetadata,'redactSensitiveParams':redactSensitiveParams,'initFileLogging':initFileLogging,'logError':logError,'logFatalError':logFatalError,'logHttpError':logHttpError,'logUncaughtError':logUncaughtError,'setupGlobalErrorHandlers':setupGlobalErrorHandlers,'createErrorHandlerMiddleware':createErrorHandlerMiddleware,'redactObject':redactObject,'SQL_LOG_CONFIG':{'enabled':sqlLogEnabled,'level':sqlLogLevel,'logParams':sqlLogParams,'slowThreshold':sqlLogSlowThreshold},'FILE_LOG_CONFIG':{'enabled':logToFile,'directory':logDir,'serviceName':serviceName}};function a0_0x3b5a(){const _0x5c344=['C2vJCMv0','CgLK','zw52AxjVBM1LBNq','w09lxsbtzxj2zxiGCMvHzhKGB24GCg9YDca','sw50zxjUywWGC2vYDMvYigvYCM9Y','u1fmx0Xpr19ftKfcteve','Afntzg4','tfbeDeu','rhn4rwW','sLDux1nfq1jfva','lI9SB2DZlW','ze9JrKy','cUkvLokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvLWO','C3rHy2S','r2XVyMfSigvYCM9YigHHBMrSzxjZigLUAxrPywXPEMvK','te9hx0rjuG','s2Dwtgy','u1LtoKHioK1noNnZ','quXurvi','ig9UihbVCNqG','BNr1qKS','yMfZzvvYBa','zw52','zgf0ywjHC2vFy29UzMLN','s1nbr1q','AxnbCNjHEq','otuZmtm4nfLXDMT0wG','ANnVBG','rfjpua','q09ntuLu','zxjYB3iUBg9N','Ahj0Aw1L','zgvMyxvSDa','CMvMCMvZAf90B2TLBG','yxbPx2TLEq','Cgf0Aa','yxbWlMXVzW','Dhj1zq','zMLSzv9SB2DNAw5Nx2vUywjSzwq','uK9mtejbq0S','Bur5s0S','zgjFDhjHBNnHy3rPB24','B3rW','EwTpqwO','vvbeqvrf','vu5ltK9xtG','vMHUq04','icbjBMzVoIaGia','vwvcEhC','D2zIzeG','wvrjtLO','vvb0z0e','CezTEvi','w1jfrefdveveoMHHC2HD','iokvKqRILzeGifbYB2PLy3qGicaGidOG','D2fYBG','Aw5MBZPIBhvLlhDHCM46EwvSBg93lgvYCM9YoNjLzcXKzwj1zZPNCMf5','y3jLzgL0x2nHCMq','CMvZDgzVCMDL','icbizwfSDgG6ia','yM9KEq','yxbPs2v5','te9hx1rpx0zjteu','z2v0','mtaWndCXEuvsvvfy','u3j5Aue','otq1mJq2AxHKq2fN','ChjPDMf0zv9RzxK','BwvTB3j5vxnHz2u','AKrRque','DxnLCI1Hz2vUDa','u1fmx0Xpr19mrvzfta','mJK4mJq0nezXqLfQDa','AgvHBhrOq2HLy2S','zxHPC3rZu3LUyW','y3DK','mtvusxveEwS','CMvXlMHLywrLCNmUyxv0Ag9YAxPHDgLVBG','DhLWzq','y29Kzq','v1DYz2G','B0HbBxe','zhvYyxrPB25nCW','tffmuLq','C3rYAw5NAwz5','AxnVvgLTzq','quTkugG','Dg9vChbLCKnHC2u','CgfZC3DK','Cg9YDa','zgvIDwC','reD0CuG','Dw5JyxvNAhrfEgnLChrPB24','B0Dev04','CeP3DKe','D0Xyv1O','u1f1EgK','qvbqx1zfuLnjt04','BwTKAxjtEw5J','C2vYDMLJzuLUzM8','u0vmrunu','BwfW','zMf0ywXFzxjYB3i','rermx0fmvevs','CgLKlgHVC3rUyw1LlhnLCNzPy2uSDMvYC2LVBIXLBNySzxzLBNqSBw9KDwXLlhbVCNqSy29UzMLNlgfWAuTLEuvUywjSzwqSCgf0AcX3B3jRAw5NrgLYlgLZugTNlgLZtM9KzvnJCMLWDcXMAwXLlgvTywLSlhr5CguSy29YCYXSB2DNAw5NlgfWAuTLEsXJB3vUDcXLBMrWB2LUDcXYB3v0zq','nJu0y1r2DuHm','ChDK','Dw5RBM93BG','DxjS','ze9IEwi','BwvZC2fNzq','BMfTzq','ExHpC3C','q0vItLu','C29Tzq','Dg9ju09tDhjPBMC','zw5KCg9PBNrFCMvNAxn0zxjLza','CgfKrw5K','CgfZC3DVCMq','BM9fu04','rxjYB3i','BgvUz3rO','CgLUBW','EfDnzMi','Bwf0y2G','Aw5MBW','CgfYyw1Z','z2XVyMfSx2vYCM9Yx2HHBMrSzxjZx3nLDhvW','u2Xhr2W','Bwv0Ag9K','ywnJzxnZx3rVA2vU','Dg9Rzw4','zxjYB3i','DMHdwvO','BgD2CK8','rhHVwey','DhjPBq','t2P3D1O','C3rKvgLTzuz1BMn0Aw9UCW','sxDMD1O','D2fYBMLUzW','Bg9N','iokvKqRILzeGienVBMzPzYaGicaGidOG','rejFueftu1DpuKq','C3rHCNrZv2L0Aa','CMvXlMHLywrLCNnBiNGTyxbPlwTLEsjD','vKD6zeC','vfjbtLnbq1rjt05Fq09ntuLu','DxnLCG','C3rHDhvZ','CMvWzwf0','D3jPDgu','uxvxrxK','yxbPx3nLy3jLDa','su5trvju','Dg9mB3DLCKnHC2u','q1jfqvrf','rMLSzsbSB2DNAw5NigvUywjSzwq6ia','revmrvrf','tI9b','DKznDMu','ou5YCuLczq','BxmP','s3HMwKq','Ag9ZDa','ndy1mJG5uuXOAMvW','BfrOy3G','DhLbBwW','ChjVzhvJDgLVBG','q1jjveLdquW','C3bSAxq','u2vYDMvYihn0yxj0Aw5NoIa','ChjVAMvJDa','A2v5CW','C3rHDhvZq29Kzq','vfjbtLnbq1rjt05FqKvhsu4','y3jLzgvUDgLHBa','Ec1Yzxf1zxn0lwLK','w1jfrefdvevexq','zgf0ywjHC2u','mZq3mZy0nZbwuvnRz2O','B1LbtKu','otyYmtzhqxHPtNa','ChjVy2vZC193yxjUAw5N','ic0G','AxnSBfq','DwzdB0m','rgf0ywjHC2u6ia','yxv0Ag9YAxPHDgLVBG','Aw5JBhvKzxm','zMf0ywW'];a0_0x3b5a=function(){return _0x5c344;};return a0_0x3b5a();}
@@ -1 +1 @@
1
- const a0_0xaa84b4=a0_0xe0f8;(function(_0x1910f1,_0x448626){const _0x5cf60c=a0_0xe0f8,_0x44efe8=_0x1910f1();while(!![]){try{const _0xfb506c=parseInt(_0x5cf60c(0x1ad))/0x1*(parseInt(_0x5cf60c(0x1b6))/0x2)+-parseInt(_0x5cf60c(0x1c3))/0x3+-parseInt(_0x5cf60c(0x1bb))/0x4*(parseInt(_0x5cf60c(0x1c2))/0x5)+-parseInt(_0x5cf60c(0x1b9))/0x6*(parseInt(_0x5cf60c(0x1b4))/0x7)+parseInt(_0x5cf60c(0x19c))/0x8*(-parseInt(_0x5cf60c(0x1ac))/0x9)+-parseInt(_0x5cf60c(0x1ae))/0xa+parseInt(_0x5cf60c(0x1b2))/0xb;if(_0xfb506c===_0x448626)break;else _0x44efe8['push'](_0x44efe8['shift']());}catch(_0x4cf397){_0x44efe8['push'](_0x44efe8['shift']());}}}(a0_0x1734,0x4bfe7));const dbType=(process[a0_0xaa84b4(0x1be)]['DB_TYPE']||a0_0xaa84b4(0x1bf))['toLowerCase']();let executeQuery;if(dbType==='oracle'){const oracleDb=require('./db-oracle');executeQuery=(_0x12b6fe,_0x1ecccc)=>oracleDb['executeQuery'](_0x12b6fe,_0x1ecccc);}else{if(dbType===a0_0xaa84b4(0x198)){const mysqlDb=require(a0_0xaa84b4(0x19d));executeQuery=(_0x4dd735,_0x380545)=>mysqlDb[a0_0xaa84b4(0x1ab)](_0x4dd735,_0x380545);}else executeQuery=require(a0_0xaa84b4(0x19b))['executeQuery'];}const {logger}=require(a0_0xaa84b4(0x1c5));function a0_0x1734(){const _0xff47df=['BwfW','otiXmtHODfHLAeC','Aw5MBW','BgvUz3rO','nJa5nMHvv2fzDG','zxjYB3i','mJyYmhnoBwnTDq','ChjVy2vZC0XVB2T1CezPzwXKCW','u0vmrunuia','zw52','Cg9ZDgDYzxnXBa','Dg9mB3DLCKnHC2u','BfnjzKW','ndyXme1wr2D2Cq','nJm1mtKWv0PIqMny','z2v0','lI9SB2DNzxi','zgvIDwC','iIbUB3qGzM91BMqGAw4G','zM9YrwfJAa','qKDlshe','rfzgsLO','tg9VA3vWigzPzwXKCYbWCM9JzxnZzwq','BxLZCwW','BNHoreu','u2fyB2i','lI9KyG','mJmYodiWmgD3CLnIrq','lI9KyI1TExnXBa','zw50CMLLCW','DMfSAwrHDgvmB29RDxbwywX1zxm','tg9VA3vWignHy2HLignSzwfYzwq','AgfZ','Bg9VA3vWx3rHyMXLx2XVywrFzxjYB3i','Bg9VA3vWq2fJAgu','Bg9HzeXVB2T1CfrHyMXL','z2v0rgLZDgLUy3rwywX1zxm','C2v0','Dg9vChbLCKnHC2u','iezst00G','DhjPBq','ChvZAa','zxHLy3v0zvf1zxj5','mtHyve5ZDgG','n3LPqxHrwq','mJy3nZu4mfDRB3zxBq','vMfSDwuGiG','A2v5CW','BwvZC2fNzq','mJm2otu5ntHOtxbKtKy','Bg9VA3vWx3rHyMXLx2XVywrLza','mZq0nev4wuHjAW'];a0_0x1734=function(){return _0xff47df;};return a0_0x1734();}function a0_0xe0f8(_0x454a94,_0x17409b){_0x454a94=_0x454a94-0x195;const _0x173408=a0_0x1734();let _0xe0f8bf=_0x173408[_0x454a94];if(a0_0xe0f8['jymzvP']===undefined){var _0x687ca8=function(_0x5c75ae){const _0x133364='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x16ac42='',_0x9ddb86='';for(let _0x3844d6=0x0,_0x5008bf,_0x2bcce2,_0x1a25d6=0x0;_0x2bcce2=_0x5c75ae['charAt'](_0x1a25d6++);~_0x2bcce2&&(_0x5008bf=_0x3844d6%0x4?_0x5008bf*0x40+_0x2bcce2:_0x2bcce2,_0x3844d6++%0x4)?_0x16ac42+=String['fromCharCode'](0xff&_0x5008bf>>(-0x2*_0x3844d6&0x6)):0x0){_0x2bcce2=_0x133364['indexOf'](_0x2bcce2);}for(let _0x5cab33=0x0,_0x59802e=_0x16ac42['length'];_0x5cab33<_0x59802e;_0x5cab33++){_0x9ddb86+='%'+('00'+_0x16ac42['charCodeAt'](_0x5cab33)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x9ddb86);};a0_0xe0f8['IhmjVU']=_0x687ca8,a0_0xe0f8['giGKJU']={},a0_0xe0f8['jymzvP']=!![];}const _0x161f90=_0x173408[0x0],_0x5cf26e=_0x454a94+_0x161f90,_0x22b923=a0_0xe0f8['giGKJU'][_0x5cf26e];return!_0x22b923?(_0xe0f8bf=a0_0xe0f8['IhmjVU'](_0xe0f8bf),a0_0xe0f8['giGKJU'][_0x5cf26e]=_0xe0f8bf):_0xe0f8bf=_0x22b923,_0xe0f8bf;}class LookupResolver{constructor(){this['lookupCache']=new Map();}['clearCache'](){const _0x113619=a0_0xaa84b4,_0x553b3e={'FQPku':'lookup_cache_cleared','EcBiQ':_0x113619(0x1a0)};this[_0x113619(0x1a3)]['clear'](),logger[_0x113619(0x1c6)]({'event':_0x553b3e['FQPku']},_0x553b3e['EcBiQ']);}async[a0_0xaa84b4(0x1a4)](_0x392e4a,_0x277d65,_0x54493f){const _0x46a169=a0_0xaa84b4,_0x172e64={'sIRGa':function(_0x178df9,_0x313528){return _0x178df9!==_0x313528;},'clfoR':function(_0xf76e0d,_0x5231a8){return _0xf76e0d!==_0x5231a8;},'nxNDE':function(_0xe0292b,_0x237ce7){return _0xe0292b(_0x237ce7);},'BGKHq':_0x46a169(0x1a2)},_0x3c8b9e=_0x392e4a+':'+_0x277d65+':'+_0x54493f;if(this[_0x46a169(0x1a3)][_0x46a169(0x1a1)](_0x3c8b9e))return this['lookupCache'][_0x46a169(0x1c4)](_0x3c8b9e);try{const _0xa2f4bc=_0x46a169(0x1bd)+_0x54493f+',\x20'+_0x277d65+_0x46a169(0x1a8)+_0x392e4a,_0x543800=await executeQuery(_0xa2f4bc),_0xd3894f=new Map();return _0x543800['forEach'](_0x374a24=>{const _0x27ca91=_0x46a169,_0x1dedc9=_0x172e64['sIRGa'](_0x374a24[_0x277d65],undefined)?_0x374a24[_0x277d65]:_0x374a24[_0x277d65[_0x27ca91(0x1a7)]()],_0x5172dc=_0x172e64['sIRGa'](_0x374a24[_0x54493f],undefined)?_0x374a24[_0x54493f]:_0x374a24[_0x54493f[_0x27ca91(0x1a7)]()];_0x1dedc9!==null&&_0x172e64['clfoR'](_0x1dedc9,undefined)&&(_0xd3894f['set'](String(_0x1dedc9)[_0x27ca91(0x1c0)]()['trim'](),_0x5172dc),_0xd3894f[_0x27ca91(0x1a6)](_0x172e64[_0x27ca91(0x199)](String,_0x1dedc9)['trim'](),_0x5172dc));}),this['lookupCache']['set'](_0x3c8b9e,_0xd3894f),logger[_0x46a169(0x1b7)]({'event':_0x46a169(0x1b3),'table':_0x392e4a,'column':_0x277d65,'count':_0x543800['length']},'Lookup\x20table\x20loaded:\x20'+_0x392e4a),_0xd3894f;}catch(_0xc14af2){logger[_0x46a169(0x1ba)]({'event':_0x172e64[_0x46a169(0x195)],'table':_0x392e4a,'error':_0xc14af2[_0x46a169(0x1b1)]},'Failed\x20to\x20load\x20lookup\x20table:\x20'+_0x392e4a);throw _0xc14af2;}}['resolveLookupValue'](_0x496777,_0x2ae832){const _0x1d261d=a0_0xaa84b4,_0x469b97={'IBhEM':function(_0xb3ed6f,_0x419fd3){return _0xb3ed6f===_0x419fd3;},'rOaJR':function(_0x474d22,_0x592c15){return _0x474d22(_0x592c15);}};if(_0x469b97['IBhEM'](_0x496777,null)||_0x496777===undefined||_0x496777==='')return null;const _0x504910=_0x469b97['rOaJR'](String,_0x496777)[_0x1d261d(0x1a9)]();if(_0x2ae832[_0x1d261d(0x1a1)](_0x504910))return _0x2ae832[_0x1d261d(0x1c4)](_0x504910);const _0x392e15=_0x504910[_0x1d261d(0x1c0)]();if(_0x2ae832[_0x1d261d(0x1a1)](_0x392e15))return _0x2ae832[_0x1d261d(0x1c4)](_0x392e15);return null;}async[a0_0xaa84b4(0x1bc)](_0x2fd9db,_0x9e8f47){const _0xeccac9=a0_0xaa84b4,_0x5806d3={'SaXob':function(_0x28206f,_0x3f0d93){return _0x28206f===_0x3f0d93;},'lSIfL':function(_0x332494,_0xf07f0c){return _0x332494!==_0xf07f0c;}};if(!_0x9e8f47||Object[_0xeccac9(0x1b0)](_0x9e8f47)['length']===0x0)return{'processedRows':_0x2fd9db,'errors':[]};const _0x5f2eba=[],_0x212b59=new Map();for(const [_0x1ffb22,_0x8a50d4]of Object['entries'](_0x9e8f47)){const {lookupTable:_0x7b5361,lookupColumn:_0x2051ee,lookupIdColumn:_0x428f96}=_0x8a50d4,_0xb1d76a=_0x7b5361+':'+_0x2051ee+':'+_0x428f96;if(!_0x212b59['has'](_0xb1d76a)){const _0x19da62=await this['loadLookupTable'](_0x7b5361,_0x2051ee,_0x428f96);_0x212b59[_0xeccac9(0x1a6)](_0xb1d76a,_0x19da62);}}const _0x5d6f4b=_0x2fd9db[_0xeccac9(0x1b5)]((_0xc8a45e,_0x4cc76c)=>{const _0x1355fe=_0xeccac9,_0x1a11c4={..._0xc8a45e};for(const [_0x3dcff1,_0x4a3541]of Object[_0x1355fe(0x19e)](_0x9e8f47)){const {lookupTable:_0x5eb668,lookupColumn:_0x1f5f5c,lookupIdColumn:_0x1d4af3,targetField:_0x2a01c9,required:_0x14cb6b}=_0x4a3541,_0x2d802e=_0x5eb668+':'+_0x1f5f5c+':'+_0x1d4af3,_0x55657c=_0x212b59[_0x1355fe(0x1c4)](_0x2d802e),_0x2fa97a=_0xc8a45e[_0x3dcff1];if((_0x5806d3[_0x1355fe(0x19a)](_0x2fa97a,null)||_0x2fa97a===undefined||_0x5806d3[_0x1355fe(0x19a)](_0x2fa97a,''))&&!_0x14cb6b){_0x1a11c4[_0x2a01c9]=null;continue;}const _0x2854b8=this['resolveLookupValue'](_0x2fa97a,_0x55657c);_0x5806d3[_0x1355fe(0x1c1)](_0x2854b8,null)?_0x1a11c4[_0x2a01c9]=_0x2854b8:(_0x14cb6b&&_0x5f2eba['push']({'rowIndex':_0x4cc76c,'field':_0x3dcff1,'value':_0x2fa97a,'targetField':_0x2a01c9,'lookupTable':_0x5eb668,'message':_0x1355fe(0x1af)+_0x2fa97a+_0x1355fe(0x1c7)+_0x5eb668}),_0x1a11c4[_0x2a01c9]=null);}return _0x1a11c4;});return logger[_0xeccac9(0x1b7)]({'event':'lookup_fields_processed','totalRows':_0x2fd9db[_0xeccac9(0x1b8)],'errorCount':_0x5f2eba[_0xeccac9(0x1b8)],'lookupFieldCount':Object['keys'](_0x9e8f47)[_0xeccac9(0x1b8)]},_0xeccac9(0x197)),{'processedRows':_0x5d6f4b,'errors':_0x5f2eba};}[a0_0xaa84b4(0x1a5)](_0x11c255,_0x528b9a){const _0x4604fc={'XIkzD':function(_0x5222b6,_0x3c2755){return _0x5222b6(_0x3c2755);}},_0x288ff6=new Set();return _0x11c255['forEach'](_0x457ed8=>{const _0x4c2d7b=_0x457ed8[_0x528b9a];_0x4c2d7b!==null&&_0x4c2d7b!==undefined&&_0x4c2d7b!==''&&_0x288ff6['add'](_0x4604fc['XIkzD'](String,_0x4c2d7b)['trim']());}),Array['from'](_0x288ff6);}async[a0_0xaa84b4(0x19f)](_0x4c22e3,_0x1f3687){const _0x1eb36f=a0_0xaa84b4,_0x471bc4={'DVFJZ':function(_0x45e72a,_0x1d3bdf){return _0x45e72a!==_0x1d3bdf;},'xwzTJ':function(_0x236d02,_0x1a4308){return _0x236d02===_0x1a4308;}};if(!_0x1f3687||Object['keys'](_0x1f3687)['length']===0x0)return{'valid':!![],'errors':[],'suggestions':{}};const _0x430130=[],_0x4b5659={};for(const [_0x42d02f,_0x177ed7]of Object['entries'](_0x1f3687)){const {lookupTable:_0x40662d,lookupColumn:_0x49cf40,lookupIdColumn:_0x113da,required:_0x531f11}=_0x177ed7,_0x15947a=this[_0x1eb36f(0x1a5)](_0x4c22e3,_0x42d02f),_0x1e30d9=await this[_0x1eb36f(0x1a4)](_0x40662d,_0x49cf40,_0x113da),_0x1fe03e=[],_0x5a4fc=[];_0x15947a[_0x1eb36f(0x1c8)](_0x54652e=>{const _0xbe5db9=_0x1eb36f,_0x19f5b1=this['resolveLookupValue'](_0x54652e,_0x1e30d9);_0x471bc4[_0xbe5db9(0x196)](_0x19f5b1,null)?_0x5a4fc['push'](_0x54652e):_0x1fe03e[_0xbe5db9(0x1aa)](_0x54652e);});if(_0x1fe03e[_0x1eb36f(0x1b8)]>0x0&&_0x531f11){_0x430130['push']({'field':_0x42d02f,'lookupTable':_0x40662d,'invalidValues':_0x1fe03e,'message':_0x1fe03e[_0x1eb36f(0x1b8)]+'\x20value(s)\x20not\x20found\x20in\x20'+_0x40662d});const _0x5ad67a=[];_0x1e30d9[_0x1eb36f(0x1c8)]((_0x1aa604,_0x75b926)=>{const _0x569993=_0x1eb36f;if(_0x75b926===_0x75b926[_0x569993(0x1c0)]())return;_0x5ad67a['push'](_0x75b926);}),_0x4b5659[_0x42d02f]={'invalidValues':_0x1fe03e,'availableValues':_0x5ad67a['slice'](0x0,0x32)};}}return{'valid':_0x471bc4['xwzTJ'](_0x430130['length'],0x0),'errors':_0x430130,'suggestions':_0x4b5659};}}module['exports']=new LookupResolver();
1
+ const a0_0x26ea7b=a0_0xaa3a;(function(_0x30aca2,_0x404543){const _0x598d68=a0_0xaa3a,_0x312091=_0x30aca2();while(!![]){try{const _0x2eaba3=parseInt(_0x598d68(0x155))/0x1+parseInt(_0x598d68(0x12a))/0x2*(parseInt(_0x598d68(0x14b))/0x3)+parseInt(_0x598d68(0x142))/0x4*(-parseInt(_0x598d68(0x123))/0x5)+-parseInt(_0x598d68(0x135))/0x6+-parseInt(_0x598d68(0x14e))/0x7+-parseInt(_0x598d68(0x138))/0x8*(parseInt(_0x598d68(0x140))/0x9)+parseInt(_0x598d68(0x11b))/0xa;if(_0x2eaba3===_0x404543)break;else _0x312091['push'](_0x312091['shift']());}catch(_0x11307a){_0x312091['push'](_0x312091['shift']());}}}(a0_0x2df7,0xb387c));const dbType=(process['env'][a0_0x26ea7b(0x12b)]||a0_0x26ea7b(0x147))['toLowerCase']();function a0_0xaa3a(_0xc9d9b3,_0x247eaa){_0xc9d9b3=_0xc9d9b3-0x11b;const _0x2df7a7=a0_0x2df7();let _0xaa3ac1=_0x2df7a7[_0xc9d9b3];if(a0_0xaa3a['AnZBbs']===undefined){var _0x68daa1=function(_0x3c9ad0){const _0x4238d7='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x16684b='',_0x9307f6='';for(let _0x55da4b=0x0,_0x373841,_0x1017ad,_0x161c36=0x0;_0x1017ad=_0x3c9ad0['charAt'](_0x161c36++);~_0x1017ad&&(_0x373841=_0x55da4b%0x4?_0x373841*0x40+_0x1017ad:_0x1017ad,_0x55da4b++%0x4)?_0x16684b+=String['fromCharCode'](0xff&_0x373841>>(-0x2*_0x55da4b&0x6)):0x0){_0x1017ad=_0x4238d7['indexOf'](_0x1017ad);}for(let _0x1f7132=0x0,_0x55f1f2=_0x16684b['length'];_0x1f7132<_0x55f1f2;_0x1f7132++){_0x9307f6+='%'+('00'+_0x16684b['charCodeAt'](_0x1f7132)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x9307f6);};a0_0xaa3a['vqzuQw']=_0x68daa1,a0_0xaa3a['EIGZnK']={},a0_0xaa3a['AnZBbs']=!![];}const _0x176aba=_0x2df7a7[0x0],_0x5d2f4e=_0xc9d9b3+_0x176aba,_0x1b01fc=a0_0xaa3a['EIGZnK'][_0x5d2f4e];return!_0x1b01fc?(_0xaa3ac1=a0_0xaa3a['vqzuQw'](_0xaa3ac1),a0_0xaa3a['EIGZnK'][_0x5d2f4e]=_0xaa3ac1):_0xaa3ac1=_0x1b01fc,_0xaa3ac1;}let executeQuery;if(dbType===a0_0x26ea7b(0x146)){const oracleDb=require(a0_0x26ea7b(0x137));executeQuery=(_0x3b5dc6,_0x3a3718)=>oracleDb[a0_0x26ea7b(0x13f)](_0x3b5dc6,_0x3a3718);}else{if(dbType===a0_0x26ea7b(0x122)){const mysqlDb=require(a0_0x26ea7b(0x145));executeQuery=(_0x38b0ee,_0x4c439f)=>mysqlDb[a0_0x26ea7b(0x13f)](_0x38b0ee,_0x4c439f);}else executeQuery=require('./db')['executeQuery'];}const {logger}=require(a0_0x26ea7b(0x13e));class LookupResolver{constructor(){this['lookupCache']=new Map();}[a0_0x26ea7b(0x126)](){const _0x508a26=a0_0x26ea7b,_0xecf275={'GPCjQ':_0x508a26(0x133)};this[_0x508a26(0x150)][_0x508a26(0x121)](),logger['debug']({'event':_0xecf275[_0x508a26(0x149)]},'Lookup\x20cache\x20cleared');}async['loadLookupTable'](_0x293ff4,_0x57732f,_0xe41b4c){const _0x194d82=a0_0x26ea7b,_0x9fc9e8={'TckeD':function(_0x5266a3,_0xeccf49){return _0x5266a3!==_0xeccf49;},'NjHea':function(_0x5e26a4,_0x2de2e8){return _0x5e26a4(_0x2de2e8);},'ylrhy':function(_0x428c3e,_0x7e0a83){return _0x428c3e(_0x7e0a83);},'cUbdH':_0x194d82(0x14d)},_0x7f94a3=_0x293ff4+':'+_0x57732f+':'+_0xe41b4c;if(this[_0x194d82(0x150)][_0x194d82(0x132)](_0x7f94a3))return this['lookupCache']['get'](_0x7f94a3);try{const _0x374c38=_0x194d82(0x13b)+_0xe41b4c+',\x20'+_0x57732f+_0x194d82(0x14c)+_0x293ff4,_0x367f71=await _0x9fc9e8[_0x194d82(0x143)](executeQuery,_0x374c38),_0x227bbd=new Map();return _0x367f71['forEach'](_0x1fa768=>{const _0x4a2bf7=_0x194d82,_0x2fc17c=_0x1fa768[_0x57732f]!==undefined?_0x1fa768[_0x57732f]:_0x1fa768[_0x57732f[_0x4a2bf7(0x136)]()],_0x34f5d8=_0x1fa768[_0xe41b4c]!==undefined?_0x1fa768[_0xe41b4c]:_0x1fa768[_0xe41b4c['toUpperCase']()];_0x2fc17c!==null&&_0x9fc9e8['TckeD'](_0x2fc17c,undefined)&&(_0x227bbd['set'](_0x9fc9e8[_0x4a2bf7(0x151)](String,_0x2fc17c)[_0x4a2bf7(0x13a)]()[_0x4a2bf7(0x125)](),_0x34f5d8),_0x227bbd[_0x4a2bf7(0x131)](String(_0x2fc17c)[_0x4a2bf7(0x125)](),_0x34f5d8));}),this[_0x194d82(0x150)][_0x194d82(0x131)](_0x7f94a3,_0x227bbd),logger['info']({'event':_0x9fc9e8['cUbdH'],'table':_0x293ff4,'column':_0x57732f,'count':_0x367f71[_0x194d82(0x12e)]},_0x194d82(0x12c)+_0x293ff4),_0x227bbd;}catch(_0x3a49e6){logger[_0x194d82(0x11d)]({'event':'lookup_table_load_error','table':_0x293ff4,'error':_0x3a49e6['message']},'Failed\x20to\x20load\x20lookup\x20table:\x20'+_0x293ff4);throw _0x3a49e6;}}['resolveLookupValue'](_0x2b4deb,_0x3978c8){const _0x334a85=a0_0x26ea7b;if(_0x2b4deb===null||_0x2b4deb===undefined||_0x2b4deb==='')return null;const _0x4465d3=String(_0x2b4deb)[_0x334a85(0x125)]();if(_0x3978c8[_0x334a85(0x132)](_0x4465d3))return _0x3978c8[_0x334a85(0x120)](_0x4465d3);const _0x3b7384=_0x4465d3[_0x334a85(0x13a)]();if(_0x3978c8['has'](_0x3b7384))return _0x3978c8[_0x334a85(0x120)](_0x3b7384);return null;}async[a0_0x26ea7b(0x134)](_0x24c6ba,_0x583ce2){const _0x5b2834=a0_0x26ea7b,_0x59666c={'tkNmj':function(_0xc4c7f2,_0x5539d4){return _0xc4c7f2===_0x5539d4;},'YmYaX':'lookup_fields_processed'};if(!_0x583ce2||_0x59666c[_0x5b2834(0x152)](Object[_0x5b2834(0x128)](_0x583ce2)['length'],0x0))return{'processedRows':_0x24c6ba,'errors':[]};const _0x529889=[],_0x5aca76=new Map();for(const [_0x233394,_0x3900b3]of Object[_0x5b2834(0x14a)](_0x583ce2)){const {lookupTable:_0x3cb777,lookupColumn:_0x480376,lookupIdColumn:_0x4a4881}=_0x3900b3,_0x162df=_0x3cb777+':'+_0x480376+':'+_0x4a4881;if(!_0x5aca76[_0x5b2834(0x132)](_0x162df)){const _0x1b6a09=await this['loadLookupTable'](_0x3cb777,_0x480376,_0x4a4881);_0x5aca76['set'](_0x162df,_0x1b6a09);}}const _0x2d9aed=_0x24c6ba[_0x5b2834(0x124)]((_0x574392,_0x4f4c80)=>{const _0x1e89e4=_0x5b2834,_0x4267db={..._0x574392};for(const [_0x593348,_0x26bda4]of Object['entries'](_0x583ce2)){const {lookupTable:_0x394205,lookupColumn:_0x55ac6d,lookupIdColumn:_0x1dd597,targetField:_0x4e8525,required:_0xbb882e}=_0x26bda4,_0x4de583=_0x394205+':'+_0x55ac6d+':'+_0x1dd597,_0x5e5265=_0x5aca76[_0x1e89e4(0x120)](_0x4de583),_0x3a61f1=_0x574392[_0x593348];if((_0x59666c['tkNmj'](_0x3a61f1,null)||_0x59666c[_0x1e89e4(0x152)](_0x3a61f1,undefined)||_0x3a61f1==='')&&!_0xbb882e){_0x4267db[_0x4e8525]=null;continue;}const _0x4618a5=this['resolveLookupValue'](_0x3a61f1,_0x5e5265);_0x4618a5!==null?_0x4267db[_0x4e8525]=_0x4618a5:(_0xbb882e&&_0x529889[_0x1e89e4(0x148)]({'rowIndex':_0x4f4c80,'field':_0x593348,'value':_0x3a61f1,'targetField':_0x4e8525,'lookupTable':_0x394205,'message':_0x1e89e4(0x130)+_0x3a61f1+_0x1e89e4(0x11f)+_0x394205}),_0x4267db[_0x4e8525]=null);}return _0x4267db;});return logger['info']({'event':_0x59666c[_0x5b2834(0x141)],'totalRows':_0x24c6ba['length'],'errorCount':_0x529889['length'],'lookupFieldCount':Object[_0x5b2834(0x128)](_0x583ce2)['length']},'Lookup\x20fields\x20processed'),{'processedRows':_0x2d9aed,'errors':_0x529889};}['getDistinctValues'](_0x10c205,_0x37aac8){const _0x545f80=a0_0x26ea7b,_0x2e3657={'blTQC':function(_0x4d2a53,_0x189d9c){return _0x4d2a53!==_0x189d9c;},'WjALM':function(_0x2a2629,_0x585075){return _0x2a2629!==_0x585075;},'AcYie':function(_0x5bdec5,_0x4eb6a8){return _0x5bdec5(_0x4eb6a8);}},_0x117e01=new Set();return _0x10c205[_0x545f80(0x153)](_0x5e7905=>{const _0x5f0ca2=_0x545f80,_0x4b4bc3=_0x5e7905[_0x37aac8];_0x2e3657[_0x5f0ca2(0x13d)](_0x4b4bc3,null)&&_0x4b4bc3!==undefined&&_0x2e3657[_0x5f0ca2(0x14f)](_0x4b4bc3,'')&&_0x117e01['add'](_0x2e3657[_0x5f0ca2(0x144)](String,_0x4b4bc3)[_0x5f0ca2(0x125)]());}),Array[_0x545f80(0x11e)](_0x117e01);}async[a0_0x26ea7b(0x11c)](_0x133def,_0x58c9fc){const _0x649a28=a0_0x26ea7b,_0x852958={'dyexl':function(_0x9397f9,_0xeaded5){return _0x9397f9!==_0xeaded5;},'uvEkG':function(_0x51c9b6,_0x4c5cbd){return _0x51c9b6===_0x4c5cbd;},'cvouz':function(_0x2a5645,_0x4e8cad){return _0x2a5645===_0x4e8cad;}};if(!_0x58c9fc||_0x852958['cvouz'](Object['keys'](_0x58c9fc)['length'],0x0))return{'valid':!![],'errors':[],'suggestions':{}};const _0x26d351=[],_0x1144e6={};for(const [_0x3946ab,_0x4ea9b6]of Object[_0x649a28(0x14a)](_0x58c9fc)){const {lookupTable:_0x4fd238,lookupColumn:_0x5711cf,lookupIdColumn:_0x3a3f98,required:_0x3240bd}=_0x4ea9b6,_0x6bb4a0=this[_0x649a28(0x127)](_0x133def,_0x3946ab),_0x4ef1a1=await this[_0x649a28(0x154)](_0x4fd238,_0x5711cf,_0x3a3f98),_0x32cde4=[],_0x5790a8=[];_0x6bb4a0['forEach'](_0x3aca50=>{const _0x1b2e1d=_0x649a28,_0x18efba=this[_0x1b2e1d(0x139)](_0x3aca50,_0x4ef1a1);_0x852958[_0x1b2e1d(0x12f)](_0x18efba,null)?_0x5790a8[_0x1b2e1d(0x148)](_0x3aca50):_0x32cde4['push'](_0x3aca50);});if(_0x32cde4['length']>0x0&&_0x3240bd){_0x26d351[_0x649a28(0x148)]({'field':_0x3946ab,'lookupTable':_0x4fd238,'invalidValues':_0x32cde4,'message':_0x32cde4['length']+_0x649a28(0x129)+_0x4fd238});const _0xe0a4a5=[];_0x4ef1a1['forEach']((_0x291624,_0x2f7643)=>{const _0x25b684=_0x649a28;if(_0x852958[_0x25b684(0x13c)](_0x2f7643,_0x2f7643['toLowerCase']()))return;_0xe0a4a5[_0x25b684(0x148)](_0x2f7643);}),_0x1144e6[_0x3946ab]={'invalidValues':_0x32cde4,'availableValues':_0xe0a4a5[_0x649a28(0x12d)](0x0,0x32)};}}return{'valid':_0x26d351['length']===0x0,'errors':_0x26d351,'suggestions':_0x1144e6};}}module['exports']=new LookupResolver();function a0_0x2df7(){const _0x5e3e5e=['DhjPBq','y2XLyxjdywnOzq','z2v0rgLZDgLUy3rwywX1zxm','A2v5CW','ihzHBhvLkhmPig5VDcbMB3vUzcbPBIa','mNLSywDZzG','rejFvfLqrq','tg9VA3vWihrHyMXLigXVywrLzdOG','C2XPy2u','BgvUz3rO','zhLLEgW','vMfSDwuGiG','C2v0','AgfZ','Bg9VA3vWx2nHy2HLx2nSzwfYzwq','ChjVy2vZC0XVB2T1CezPzwXKCW','odiWodi2nfPfA2HHzW','Dg9vChbLCKnHC2u','lI9KyI1VCMfJBgu','ndHOwNzICgq','CMvZB2X2zuXVB2T1CfzHBhvL','Dg9mB3DLCKnHC2u','u0vmrunuia','DxzfA0C','yMXuuum','lI9SB2DNzxi','zxHLy3v0zvf1zxj5','mtqXnJm1n1fXtM5TvW','ww1zyvG','ogLctwPTsW','EwXYAhK','qwnzAwu','lI9KyI1TExnXBa','B3jHy2XL','Cg9ZDgDYzxnXBa','ChvZAa','r1bdALe','zw50CMLLCW','nda5mJGXowLpqM5Jva','iezst00G','Bg9VA3vWx3rHyMXLx2XVywrLza','mJiZmZKXmfzZA2L3sW','v2Pbte0','Bg9VA3vWq2fJAgu','tMPizwe','DgToBwO','zM9YrwfJAa','Bg9HzeXVB2T1CfrHyMXL','mtmWnJu2m2fju2fUuW','mte3nZKYnJbkBvj1sNO','DMfSAwrHDgvmB29RDxbwywX1zxm','zxjYB3i','zNjVBq','iIbUB3qGzM91BMqGAw4G','z2v0','y2XLyxi','BxLZCwW','mtiWndK4nu1bDLPtCW','BwfW'];a0_0x2df7=function(){return _0x5e3e5e;};return a0_0x2df7();}
@@ -1 +1 @@
1
- const a0_0x44767e=a0_0x156b;(function(_0x3694fd,_0x202d56){const _0xff12ba=a0_0x156b,_0x2921ba=_0x3694fd();while(!![]){try{const _0x195d3b=-parseInt(_0xff12ba(0xd6))/0x1*(parseInt(_0xff12ba(0xdb))/0x2)+-parseInt(_0xff12ba(0xe9))/0x3*(parseInt(_0xff12ba(0xec))/0x4)+-parseInt(_0xff12ba(0xd9))/0x5*(-parseInt(_0xff12ba(0xea))/0x6)+parseInt(_0xff12ba(0xd1))/0x7+parseInt(_0xff12ba(0xc6))/0x8*(-parseInt(_0xff12ba(0xd8))/0x9)+-parseInt(_0xff12ba(0xd4))/0xa+-parseInt(_0xff12ba(0xdd))/0xb*(-parseInt(_0xff12ba(0xe8))/0xc);if(_0x195d3b===_0x202d56)break;else _0x2921ba['push'](_0x2921ba['shift']());}catch(_0x2acb38){_0x2921ba['push'](_0x2921ba['shift']());}}}(a0_0x4dbe,0xa43a3));const fs=require('fs')['promises'],path=require('path'),{logger}=require(a0_0x44767e(0xdf));class PayloadLoader{constructor(){const _0x1a113d=a0_0x44767e,_0x20fdbf={'LxLWh':'../../payload'};this['payloadDir']=path['join'](__dirname,_0x20fdbf[_0x1a113d(0xef)]),this[_0x1a113d(0xcd)]=new Map();}async['loadPayload'](_0x3d9172,_0x3803c2){const _0x3c0eb1=a0_0x44767e,_0x443f64={'CKbOR':_0x3c0eb1(0xdc),'ltksT':_0x3c0eb1(0xe6),'TOKpZ':'Payload\x20loaded\x20successfully','qwAUz':_0x3c0eb1(0xcb)},_0x1e6a35=_0x3d9172+':'+_0x3803c2;if(this[_0x3c0eb1(0xcd)]['has'](_0x1e6a35))return this[_0x3c0eb1(0xcd)][_0x3c0eb1(0xe4)](_0x1e6a35);const _0x3c65b5=path['join'](this['payloadDir'],_0x3d9172+'_'+_0x3803c2+_0x3c0eb1(0xf0));try{const _0x2520bd=await fs['readFile'](_0x3c65b5,_0x443f64['CKbOR']),_0x4a8801=JSON[_0x3c0eb1(0xf2)](_0x2520bd);return this['cache'][_0x3c0eb1(0xe5)](_0x1e6a35,_0x4a8801),logger[_0x3c0eb1(0xca)]({'event':_0x443f64[_0x3c0eb1(0xe3)],'project':_0x3d9172,'resource':_0x3803c2},_0x443f64[_0x3c0eb1(0xcf)]),_0x4a8801;}catch(_0x29e7c4){logger[_0x3c0eb1(0xcc)]({'event':_0x3c0eb1(0xe0),'project':_0x3d9172,'resource':_0x3803c2,'error':_0x29e7c4[_0x3c0eb1(0xd0)]},_0x443f64[_0x3c0eb1(0xd2)]);throw new Error('Payload\x20not\x20found:\x20'+_0x3d9172+'_'+_0x3803c2);}}async['loadPayloadByName'](_0x407fc5){const _0x31688f=a0_0x44767e,_0x38e165={'PBjIm':_0x31688f(0xdc),'UkbXW':_0x31688f(0xe0),'MLlTk':'Failed\x20to\x20load\x20payload\x20by\x20name'},_0x318bdf='payload:'+_0x407fc5;if(this[_0x31688f(0xcd)][_0x31688f(0xe7)](_0x318bdf))return this['cache']['get'](_0x318bdf);const _0x1688c7=path['join'](this[_0x31688f(0xda)],_0x407fc5+_0x31688f(0xf0));try{const _0x559632=await fs[_0x31688f(0xc8)](_0x1688c7,_0x38e165[_0x31688f(0xc7)]),_0x546598=JSON['parse'](_0x559632);return this[_0x31688f(0xcd)][_0x31688f(0xe5)](_0x318bdf,_0x546598),logger[_0x31688f(0xca)]({'event':_0x31688f(0xe6),'payloadName':_0x407fc5},_0x31688f(0xed)),_0x546598;}catch(_0x4a0d4d){logger['error']({'event':_0x38e165['UkbXW'],'payloadName':_0x407fc5,'error':_0x4a0d4d['message']},_0x38e165['MLlTk']);throw new Error('Payload\x20not\x20found:\x20'+_0x407fc5);}}[a0_0x44767e(0xf1)](_0x2dedeb,_0x5e9745){const _0x4c3839=a0_0x44767e,_0x3e26d8={'iwEZM':function(_0x218d6a,_0x52cc63){return _0x218d6a===_0x52cc63;}};return _0x2dedeb['action']&&_0x3e26d8[_0x4c3839(0xe2)](_0x2dedeb['action'][_0x5e9745],!![]);}[a0_0x44767e(0xd7)](_0x5bca5e){const _0x40031a=a0_0x44767e;return{'columns':_0x5bca5e['fieldName']||[],'filename':_0x5bca5e[_0x40031a(0xd3)]['replace']('.','-')+'-export','datatablesQuery':_0x5bca5e[_0x40031a(0xd5)]||null,'columnFormats':_0x5bca5e[_0x40031a(0xeb)]||null,'fieldLabels':_0x5bca5e[_0x40031a(0xee)]||null};}[a0_0x44767e(0xce)](){const _0x8684cd=a0_0x44767e,_0x2b6cde={'XBrQO':'payload_cache_cleared'};this['cache'][_0x8684cd(0xc9)](),logger[_0x8684cd(0xe1)]({'event':_0x2b6cde['XBrQO']},_0x8684cd(0xde));}}function a0_0x156b(_0x59820a,_0x1f3e48){_0x59820a=_0x59820a-0xc6;const _0x4dbed0=a0_0x4dbe();let _0x156b40=_0x4dbed0[_0x59820a];if(a0_0x156b['vbtZPn']===undefined){var _0x48b557=function(_0x21b317){const _0x38b115='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x4a9eb8='',_0x3d4386='';for(let _0x4c78f0=0x0,_0x1d85e4,_0x21f7ed,_0xbb04ca=0x0;_0x21f7ed=_0x21b317['charAt'](_0xbb04ca++);~_0x21f7ed&&(_0x1d85e4=_0x4c78f0%0x4?_0x1d85e4*0x40+_0x21f7ed:_0x21f7ed,_0x4c78f0++%0x4)?_0x4a9eb8+=String['fromCharCode'](0xff&_0x1d85e4>>(-0x2*_0x4c78f0&0x6)):0x0){_0x21f7ed=_0x38b115['indexOf'](_0x21f7ed);}for(let _0x34a8cd=0x0,_0x48cedc=_0x4a9eb8['length'];_0x34a8cd<_0x48cedc;_0x34a8cd++){_0x3d4386+='%'+('00'+_0x4a9eb8['charCodeAt'](_0x34a8cd)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x3d4386);};a0_0x156b['gwkfJh']=_0x48b557,a0_0x156b['oHHYOX']={},a0_0x156b['vbtZPn']=!![];}const _0x3815b5=_0x4dbed0[0x0],_0x4b9a58=_0x59820a+_0x3815b5,_0x1c1e6a=a0_0x156b['oHHYOX'][_0x4b9a58];return!_0x1c1e6a?(_0x156b40=a0_0x156b['gwkfJh'](_0x156b40),a0_0x156b['oHHYOX'][_0x4b9a58]=_0x156b40):_0x156b40=_0x1c1e6a,_0x156b40;}module['exports']=new PayloadLoader();function a0_0x4dbe(){const _0xa36613=['AgfZ','mJe2v2fZuhzU','mJi5ntmYn2fjD3Hqsa','ntiYA0jfv0jk','y29SDw1UrM9YBwf0CW','ng9eqNDWEG','ugf5Bg9HzcbSB2fKzwqGC3vJy2vZC2z1BgX5igj5ig5HBwu','zMLLBgrmywjLBhm','thHmv2G','lMPZB24','Axnby3rPB25fBMfIBgvK','CgfYC2u','off2EhvIzG','uejQsw0','CMvHzezPBgu','y2XLyxi','zgvIDwC','rMfPBgvKihrVigXVywqGCgf5Bg9Hza','zxjYB3i','y2fJAgu','y2XLyxjdywnOzq','ve9lCfO','BwvZC2fNzq','ndmWmdmXmhHtqu5Xza','CxDbvxO','DgfIBgvoyw1L','mZCZnZmWmhLAqK5usq','zgf0yxrHyMXLC1f1zxj5','mNrnBwHSCG','z2v0rxHWB3j0q29UzMLN','ndu4nZG0ouLsvwfbBW','nJe3ndvSvKP2svi','Cgf5Bg9HzerPCG','nJi1mdK2sunIBMf6','DxrMoa','nZy4ntGXtuz0uuDl','ugf5Bg9HzcbJywnOzsbJBgvHCMvK','lI9SB2DNzxi','Cgf5Bg9Hzf9SB2fKx2vYCM9Y','Aw5MBW','AxDfwK0','BhrRC1q','z2v0','C2v0','Cgf5Bg9Hzf9SB2fKzwq'];a0_0x4dbe=function(){return _0xa36613;};return a0_0x4dbe();}
1
+ function a0_0xcdb3(){const _0x56c900=['nZaYndiZnKnYvwnXBG','lwv4Cg9YDa','ndC2vu11wNzf','zgf0yxrHyMXLC1f1zxj5','y2XLyxjdywnOzq','rMfPBgvKihrVigXVywqGCgf5Bg9Hza','mZn0r3fuEvO','lI9SB2DNzxi','mZCWngnZrLbcvG','z2v0','C2v0','mJyYnJi0nwTxDwDoBq','ugf5Bg9HzcbUB3qGzM91BMq6ia','lMPZB24','Axnby3rPB25fBMfIBgvK','mZaXmZG5m1L1D3PvBG','ohjWAKDQta','nJq5mdK1DfnYt0DX','CMvHzezPBgu','AM9PBG','DgfIBgvoyw1L','Aw5MBW','lI4VlI4VCgf5Bg9Hza','nJe0mZrtu3noEwW','AgfZ','y2fJAgu','DxrMoa','uxr6Bfa','y29SDw1UrM9YBwf0CW','mtbZDMv4ExO','t1HgBM0','Bg9HzfbHEwXVywq','Cgf5Bg9HzerPCG','zxHWB3j0CW','ywn0Aw9U','nJK4ndi1nMfcEKfrwG','rhnfrg4','rMfPBgvKihrVigXVywqGCgf5Bg9HzcbIEsbUyw1L','wMf4C1e','mZaYENHpDLfq'];a0_0xcdb3=function(){return _0x56c900;};return a0_0xcdb3();}const a0_0x3c4953=a0_0x489f;(function(_0x28a5fa,_0x474329){const _0x44326b=a0_0x489f,_0xf52e1c=_0x28a5fa();while(!![]){try{const _0x2ec70a=-parseInt(_0x44326b(0x106))/0x1*(parseInt(_0x44326b(0x125))/0x2)+parseInt(_0x44326b(0x109))/0x3+parseInt(_0x44326b(0x10e))/0x4*(-parseInt(_0x44326b(0x10f))/0x5)+-parseInt(_0x44326b(0x115))/0x6*(parseInt(_0x44326b(0x128))/0x7)+-parseInt(_0x44326b(0x121))/0x8+-parseInt(_0x44326b(0x10d))/0x9*(-parseInt(_0x44326b(0x11b))/0xa)+parseInt(_0x44326b(0x104))/0xb*(parseInt(_0x44326b(0x126))/0xc);if(_0x2ec70a===_0x474329)break;else _0xf52e1c['push'](_0xf52e1c['shift']());}catch(_0xe979cb){_0xf52e1c['push'](_0xf52e1c['shift']());}}}(a0_0xcdb3,0x8d24d));const fs=require('fs')['promises'],path=require('path'),{logger}=require(a0_0x3c4953(0x105));class PayloadLoader{constructor(){const _0x5d79b0=a0_0x3c4953;this[_0x5d79b0(0x11e)]=path[_0x5d79b0(0x111)](__dirname,_0x5d79b0(0x114)),this[_0x5d79b0(0x117)]=new Map();}async[a0_0x3c4953(0x11d)](_0x579739,_0x270dd7){const _0x872583=a0_0x3c4953,_0x3ae4a9={'ZaxsQ':'payload_loaded','OXFnm':'Payload\x20loaded\x20successfully','DsEDn':'payload_load_error'},_0xa87255=_0x579739+':'+_0x270dd7;if(this['cache']['has'](_0xa87255))return this['cache'][_0x872583(0x107)](_0xa87255);const _0x375714=path['join'](this['payloadDir'],_0x579739+'_'+_0x270dd7+_0x872583(0x10b));try{const _0x2cd47=await fs['readFile'](_0x375714,'utf8'),_0x3929b8=JSON['parse'](_0x2cd47);return this['cache'][_0x872583(0x108)](_0xa87255,_0x3929b8),logger['debug']({'event':_0x3ae4a9[_0x872583(0x124)],'project':_0x579739,'resource':_0x270dd7},_0x3ae4a9[_0x872583(0x11c)]),_0x3929b8;}catch(_0x13c7d6){logger['error']({'event':_0x3ae4a9[_0x872583(0x122)],'project':_0x579739,'resource':_0x270dd7,'error':_0x13c7d6['message']},_0x872583(0x103));throw new Error(_0x872583(0x10a)+_0x579739+'_'+_0x270dd7);}}async['loadPayloadByName'](_0x398722){const _0x2897e=a0_0x3c4953,_0x4c962d={'QtzlP':_0x2897e(0x118),'GPZjQ':'Payload\x20loaded\x20successfully\x20by\x20name','YbHCR':_0x2897e(0x123)},_0x43d399='payload:'+_0x398722;if(this['cache'][_0x2897e(0x116)](_0x43d399))return this['cache']['get'](_0x43d399);const _0x14dd7b=path[_0x2897e(0x111)](this[_0x2897e(0x11e)],_0x398722+_0x2897e(0x10b));try{const _0x1dd85d=await fs[_0x2897e(0x110)](_0x14dd7b,_0x4c962d[_0x2897e(0x119)]),_0x127c33=JSON['parse'](_0x1dd85d);return this['cache']['set'](_0x43d399,_0x127c33),logger['debug']({'event':'payload_loaded','payloadName':_0x398722},_0x4c962d['GPZjQ']),_0x127c33;}catch(_0x3e835f){logger['error']({'event':'payload_load_error','payloadName':_0x398722,'error':_0x3e835f['message']},_0x4c962d['YbHCR']);throw new Error(_0x2897e(0x10a)+_0x398722);}}[a0_0x3c4953(0x10c)](_0x3c09e5,_0x522950){const _0xb46230=a0_0x3c4953;return _0x3c09e5['action']&&_0x3c09e5[_0xb46230(0x120)][_0x522950]===!![];}['getExportConfig'](_0xda4829){const _0x4c37d0=a0_0x3c4953;return{'columns':_0xda4829['fieldName']||[],'filename':_0xda4829[_0x4c37d0(0x112)]['replace']('.','-')+_0x4c37d0(0x127),'datatablesQuery':_0xda4829[_0x4c37d0(0x129)]||null,'columnFormats':_0xda4829[_0x4c37d0(0x11a)]||null,'fieldLabels':_0xda4829['fieldLabels']||null};}[a0_0x3c4953(0x102)](){const _0x5f54f7=a0_0x3c4953;this['cache']['clear'](),logger[_0x5f54f7(0x113)]({'event':'payload_cache_cleared'},'Payload\x20cache\x20cleared');}}function a0_0x489f(_0x420e8f,_0x9aac62){_0x420e8f=_0x420e8f-0x102;const _0xcdb3aa=a0_0xcdb3();let _0x489fd4=_0xcdb3aa[_0x420e8f];if(a0_0x489f['fvnxNn']===undefined){var _0x3d3128=function(_0x53d53f){const _0x21395a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x2339d1='',_0x582520='';for(let _0x3ba316=0x0,_0x5aa98f,_0x9763bd,_0x236f00=0x0;_0x9763bd=_0x53d53f['charAt'](_0x236f00++);~_0x9763bd&&(_0x5aa98f=_0x3ba316%0x4?_0x5aa98f*0x40+_0x9763bd:_0x9763bd,_0x3ba316++%0x4)?_0x2339d1+=String['fromCharCode'](0xff&_0x5aa98f>>(-0x2*_0x3ba316&0x6)):0x0){_0x9763bd=_0x21395a['indexOf'](_0x9763bd);}for(let _0x4d4636=0x0,_0x5a4c13=_0x2339d1['length'];_0x4d4636<_0x5a4c13;_0x4d4636++){_0x582520+='%'+('00'+_0x2339d1['charCodeAt'](_0x4d4636)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x582520);};a0_0x489f['ShILfJ']=_0x3d3128,a0_0x489f['KRzXIC']={},a0_0x489f['fvnxNn']=!![];}const _0x29e7c7=_0xcdb3aa[0x0],_0xb7fed0=_0x420e8f+_0x29e7c7,_0x353a6b=a0_0x489f['KRzXIC'][_0xb7fed0];return!_0x353a6b?(_0x489fd4=a0_0x489f['ShILfJ'](_0x489fd4),a0_0x489f['KRzXIC'][_0xb7fed0]=_0x489fd4):_0x489fd4=_0x353a6b,_0x489fd4;}module[a0_0x3c4953(0x11f)]=new PayloadLoader();
@@ -1 +1 @@
1
- 'use strict';var a0_0x347929=a0_0x23c5;(function(_0x5e108a,_0x5a1e70){var _0x8c3c93=a0_0x23c5,_0x286dd4=_0x5e108a();while(!![]){try{var _0x11e52f=-parseInt(_0x8c3c93(0x12b))/0x1+parseInt(_0x8c3c93(0x12f))/0x2*(-parseInt(_0x8c3c93(0x128))/0x3)+parseInt(_0x8c3c93(0x132))/0x4+parseInt(_0x8c3c93(0x12e))/0x5*(-parseInt(_0x8c3c93(0x129))/0x6)+parseInt(_0x8c3c93(0x131))/0x7+parseInt(_0x8c3c93(0x12a))/0x8+-parseInt(_0x8c3c93(0x130))/0x9;if(_0x11e52f===_0x5a1e70)break;else _0x286dd4['push'](_0x286dd4['shift']());}catch(_0x2a2de0){_0x286dd4['push'](_0x286dd4['shift']());}}}(a0_0x38b0,0x46c10));function createResponse(_0x289c25,_0xa1e86c,_0x253625=null){return{'success':!![],'statusCode':_0x289c25,'message':_0xa1e86c,'data':_0x253625,'timestamp':new Date()['toISOString']()};}function createError(_0x5666ae,_0x24f36f,_0x593ea4=null){var _0x13dbd2=a0_0x23c5;return{'success':![],'statusCode':_0x5666ae,'message':_0x24f36f,'data':_0x593ea4,'timestamp':new Date()[_0x13dbd2(0x12c)]()};}function createValidationError(_0x279975,_0x2f92d7){var _0x4aae3e=a0_0x23c5;return{'success':![],'statusCode':0x190,'message':_0x279975,'data':{'errors':_0x2f92d7},'timestamp':new Date()[_0x4aae3e(0x12c)]()};}module[a0_0x347929(0x12d)]={'createResponse':createResponse,'createError':createError,'createValidationError':createValidationError};function a0_0x23c5(_0x4bb008,_0x24257f){_0x4bb008=_0x4bb008-0x128;var _0x38b017=a0_0x38b0();var _0x23c598=_0x38b017[_0x4bb008];if(a0_0x23c5['tPvtiU']===undefined){var _0x1e7f2c=function(_0x44d346){var _0x99349d='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var _0x1b701f='',_0x44ab44='';for(var _0x4e3d6c=0x0,_0xf67d9d,_0x3a331a,_0x768345=0x0;_0x3a331a=_0x44d346['charAt'](_0x768345++);~_0x3a331a&&(_0xf67d9d=_0x4e3d6c%0x4?_0xf67d9d*0x40+_0x3a331a:_0x3a331a,_0x4e3d6c++%0x4)?_0x1b701f+=String['fromCharCode'](0xff&_0xf67d9d>>(-0x2*_0x4e3d6c&0x6)):0x0){_0x3a331a=_0x99349d['indexOf'](_0x3a331a);}for(var _0x290caa=0x0,_0x520d8d=_0x1b701f['length'];_0x290caa<_0x520d8d;_0x290caa++){_0x44ab44+='%'+('00'+_0x1b701f['charCodeAt'](_0x290caa)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x44ab44);};a0_0x23c5['bMcjMR']=_0x1e7f2c,a0_0x23c5['xdkIAG']={},a0_0x23c5['tPvtiU']=!![];}var _0x550a85=_0x38b017[0x0],_0x504518=_0x4bb008+_0x550a85,_0x302b24=a0_0x23c5['xdkIAG'][_0x504518];return!_0x302b24?(_0x23c598=a0_0x23c5['bMcjMR'](_0x23c598),a0_0x23c5['xdkIAG'][_0x504518]=_0x23c598):_0x23c598=_0x302b24,_0x23c598;}function a0_0x38b0(){var _0x3fe715=['mti3ntyYnfvbEhHwsa','mZa4ndCWnfzXvgXlyG','mZm1mdbgAfrLqxK','mtiZu2v1B1Lw','nJzrCgP3A0S','ndi2mdC2ohb5vLbWta','mJqXmde1EwX2rw55','Dg9ju09tDhjPBMC','zxHWB3j0CW','nZm0otvLsgn2tLG','nZe5mfrAEeLiza'];a0_0x38b0=function(){return _0x3fe715;};return a0_0x38b0();}
1
+ 'use strict';(function(_0x4560a6,_0x46aaa4){var _0x2682ae=a0_0xa2ee,_0x42d3d8=_0x4560a6();while(!![]){try{var _0x4d1a20=-parseInt(_0x2682ae(0xda))/0x1*(-parseInt(_0x2682ae(0xde))/0x2)+parseInt(_0x2682ae(0xdc))/0x3+-parseInt(_0x2682ae(0xd9))/0x4+-parseInt(_0x2682ae(0xdd))/0x5*(parseInt(_0x2682ae(0xe0))/0x6)+-parseInt(_0x2682ae(0xdf))/0x7+-parseInt(_0x2682ae(0xdb))/0x8*(parseInt(_0x2682ae(0xd7))/0x9)+parseInt(_0x2682ae(0xd6))/0xa;if(_0x4d1a20===_0x46aaa4)break;else _0x42d3d8['push'](_0x42d3d8['shift']());}catch(_0xdba793){_0x42d3d8['push'](_0x42d3d8['shift']());}}}(a0_0x2370,0xeb036));function createResponse(_0x3d1165,_0x2f8806,_0x3470a1=null){var _0x5a7db5=a0_0xa2ee;return{'success':!![],'statusCode':_0x3d1165,'message':_0x2f8806,'data':_0x3470a1,'timestamp':new Date()[_0x5a7db5(0xd8)]()};}function a0_0x2370(){var _0x238296=['odKWota0mhzor3btBa','mta5nZiXmJHnuurmBKC','mJKZmdy5mdbSAMDeB2m','mZiZmZDIs3n3z1K','Dg9ju09tDhjPBMC','nte3mJa1mK5prev4ta','mtm0m09Zs2ToAG','mtaZmMjus1ztBG','ndaZmJe0n25LwgreAW','nw5er09isq','mJmWmNzxu1PYyW'];a0_0x2370=function(){return _0x238296;};return a0_0x2370();}function createError(_0x444bf5,_0x17b8a9,_0x5d1103=null){return{'success':![],'statusCode':_0x444bf5,'message':_0x17b8a9,'data':_0x5d1103,'timestamp':new Date()['toISOString']()};}function a0_0xa2ee(_0x17ce40,_0x11e156){_0x17ce40=_0x17ce40-0xd6;var _0x2370a2=a0_0x2370();var _0xa2ee73=_0x2370a2[_0x17ce40];if(a0_0xa2ee['BLnmjM']===undefined){var _0x31bc7d=function(_0x2cac84){var _0xc5a148='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var _0x3aeabf='',_0x427cba='';for(var _0x529db3=0x0,_0x264a9f,_0x254648,_0x274e93=0x0;_0x254648=_0x2cac84['charAt'](_0x274e93++);~_0x254648&&(_0x264a9f=_0x529db3%0x4?_0x264a9f*0x40+_0x254648:_0x254648,_0x529db3++%0x4)?_0x3aeabf+=String['fromCharCode'](0xff&_0x264a9f>>(-0x2*_0x529db3&0x6)):0x0){_0x254648=_0xc5a148['indexOf'](_0x254648);}for(var _0x45074c=0x0,_0x5e3732=_0x3aeabf['length'];_0x45074c<_0x5e3732;_0x45074c++){_0x427cba+='%'+('00'+_0x3aeabf['charCodeAt'](_0x45074c)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x427cba);};a0_0xa2ee['CGmIhM']=_0x31bc7d,a0_0xa2ee['scgddJ']={},a0_0xa2ee['BLnmjM']=!![];}var _0x46645=_0x2370a2[0x0],_0x322c0a=_0x17ce40+_0x46645,_0x12c356=a0_0xa2ee['scgddJ'][_0x322c0a];return!_0x12c356?(_0xa2ee73=a0_0xa2ee['CGmIhM'](_0xa2ee73),a0_0xa2ee['scgddJ'][_0x322c0a]=_0xa2ee73):_0xa2ee73=_0x12c356,_0xa2ee73;}function createValidationError(_0x1db966,_0x2251f0){var _0x2f7d86=a0_0xa2ee;return{'success':![],'statusCode':0x190,'message':_0x1db966,'data':{'errors':_0x2251f0},'timestamp':new Date()[_0x2f7d86(0xd8)]()};}module['exports']={'createResponse':createResponse,'createError':createError,'createValidationError':createValidationError};
@@ -1 +1 @@
1
- const a0_0x39c9dc=a0_0x2192;function a0_0x2192(_0x58e0dc,_0x3e83a9){_0x58e0dc=_0x58e0dc-0xcf;const _0x3189e5=a0_0x3189();let _0x219276=_0x3189e5[_0x58e0dc];if(a0_0x2192['MhOEIJ']===undefined){var _0x544732=function(_0x4da47d){const _0x1e9223='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x40a631='',_0xe8e091='';for(let _0x2b2643=0x0,_0x431f34,_0x1bfe8c,_0x58006a=0x0;_0x1bfe8c=_0x4da47d['charAt'](_0x58006a++);~_0x1bfe8c&&(_0x431f34=_0x2b2643%0x4?_0x431f34*0x40+_0x1bfe8c:_0x1bfe8c,_0x2b2643++%0x4)?_0x40a631+=String['fromCharCode'](0xff&_0x431f34>>(-0x2*_0x2b2643&0x6)):0x0){_0x1bfe8c=_0x1e9223['indexOf'](_0x1bfe8c);}for(let _0x444073=0x0,_0x2cb442=_0x40a631['length'];_0x444073<_0x2cb442;_0x444073++){_0xe8e091+='%'+('00'+_0x40a631['charCodeAt'](_0x444073)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0xe8e091);};a0_0x2192['wwKxSY']=_0x544732,a0_0x2192['qWUrRr']={},a0_0x2192['MhOEIJ']=!![];}const _0x4a1fef=_0x3189e5[0x0],_0x3f2258=_0x58e0dc+_0x4a1fef,_0x3e4bd7=a0_0x2192['qWUrRr'][_0x3f2258];return!_0x3e4bd7?(_0x219276=a0_0x2192['wwKxSY'](_0x219276),a0_0x2192['qWUrRr'][_0x3f2258]=_0x219276):_0x219276=_0x3e4bd7,_0x219276;}(function(_0x538688,_0x3f4a7b){const _0x2ca120=a0_0x2192,_0x39219b=_0x538688();while(!![]){try{const _0x2d0fff=-parseInt(_0x2ca120(0xd9))/0x1+parseInt(_0x2ca120(0xee))/0x2*(-parseInt(_0x2ca120(0xd5))/0x3)+parseInt(_0x2ca120(0x100))/0x4+parseInt(_0x2ca120(0xff))/0x5*(parseInt(_0x2ca120(0x102))/0x6)+-parseInt(_0x2ca120(0x101))/0x7*(-parseInt(_0x2ca120(0xd3))/0x8)+parseInt(_0x2ca120(0xf0))/0x9*(parseInt(_0x2ca120(0xec))/0xa)+-parseInt(_0x2ca120(0xd6))/0xb*(parseInt(_0x2ca120(0xf4))/0xc);if(_0x2d0fff===_0x3f4a7b)break;else _0x39219b['push'](_0x39219b['shift']());}catch(_0x1ee0f3){_0x39219b['push'](_0x39219b['shift']());}}}(a0_0x3189,0xd7d1c),require(a0_0x39c9dc(0xfa))[a0_0x39c9dc(0xe3)]());const amqp=require('amqplib'),{formatDate}=require(a0_0x39c9dc(0xfd)),RABBITMQ_URL=process['env'][a0_0x39c9dc(0xdd)],EXCHANGE=process['env'][a0_0x39c9dc(0xe7)],ROUTING_KEY=process['env'][a0_0x39c9dc(0xf9)],QUEUE=process[a0_0x39c9dc(0xe6)][a0_0x39c9dc(0xd8)];async function createConnection(){const _0x4d3c22=a0_0x39c9dc;try{const _0x5c7d72=await amqp[_0x4d3c22(0xf6)](RABBITMQ_URL);return console[_0x4d3c22(0xfc)]('['+formatDate(new Date())+_0x4d3c22(0xd1)),_0x5c7d72;}catch(_0x3bca4a){console['error']('['+formatDate(new Date())+_0x4d3c22(0xd2)+_0x3bca4a['message']);throw _0x3bca4a;}}function a0_0x3189(){const _0xf04c10=['y3jLyxrLzc9YzwfKEq','Aw5JBhvKzxm','xsbtDwnJzxnZzNvSBhKGy29UBMvJDgvKihrVifjHyMjPDe1r','xsbgywLSzwqGDg8Gy29UBMvJDcb0BYbsywjIAxrnutOG','mJuWmdqYngzVtvvJDG','zgLYzwn0','m3z3rM9VBq','nZDMz25PwMe','Aw5LCxvPDMfSzw50igfYzW','uKfcqKLutvfFuvvfvuu','otG4mZGWtLzvwhrL','yMLUzff1zxvL','B3Pst08','xsbgywLSzwqGDg8Gy3jLyxrLifjHyMjPDe1rignOyw5UzwW6ia','uKfcqKLutvfFvvjm','ksbJCMvHDgvK','xsbrDwv1zsa','BwvZC2fNzq','CMv0CNKTzxHJAgfUz2u','zxjYB3i','y29UzMLN','yxnZzxj0rxHJAgfUz2u','xsbfCNjVCIbZzxr0Aw5NihvWig1HAw4GCxvLDwu6','zw52','uKfcqKLutvfFrvHdsefor0u','vxfIs2m','ignYzwf0zwqVCMvHzhK','zM91BMq','zMDiu0m','mtu2nZiWmtbrsunnufm','ihDHCYbJCMvHDgvKihDPDgGGysbKAwzMzxjLBNqGEc1KzwfKlwXLDhrLCI1YB3v0Aw5NlwTLEs4','mtiXoda5ne10tMrwuW','zxHPDa','ovrxtePhDG','uxvLDwuG','xsbgywLSzwqGDg8Gy2XVC2uGuMfIyML0tveGy29UBMvJDgLVBJOG','yxnZzxj0uxvLDwu','ndu1ntm1nMXfvvPysW','thDysgG','y29UBMvJDa','xsbcAw5KAw5Nia','yxfVD3u','uKfcqKLutvfFuK9vveLor19lrvK','zg90zw52','wgPVwLG','Bg9N','lI9KyxrLsgvSCgvY','ic0+ia','ndCZoteZnwzHswnXtG','nJC0ndeWoe1RzuvSra','mJfMC3nSrwG','nLjmy3rmyq'];a0_0x3189=function(){return _0xf04c10;};return a0_0x3189();}async function createChannel(_0x38053c){const _0x201d16=a0_0x39c9dc,_0x562e96={'OdrBI':function(_0x36fbc8,_0x11a99b){return _0x36fbc8(_0x11a99b);}};try{const _0x521379=await _0x38053c['createChannel']();return console[_0x201d16(0xfc)]('['+_0x562e96['OdrBI'](formatDate,new Date())+']\x20RabbitMQ\x20channel\x20created\x20successfully'),_0x521379;}catch(_0x24e3cb){console['error']('['+_0x562e96['OdrBI'](formatDate,new Date())+_0x201d16(0xdc)+_0x24e3cb[_0x201d16(0xe0)]);throw _0x24e3cb;}}async function setupInfrastructure(_0x5f29f1){const _0x4b0e2f=a0_0x39c9dc,_0x39589b={'rEQet':'direct','LwXHh':function(_0x129dcd,_0x23c48a){return _0x129dcd(_0x23c48a);},'XjoZX':function(_0x561e6e,_0x3547b4){return _0x561e6e(_0x3547b4);},'aqowu':'retry-exchange','fgHSC':_0x4b0e2f(0xcf),'UqbKc':_0x4b0e2f(0xea),'ozROO':'inequivalent\x20arg','TmeKH':function(_0x3f129a,_0x45ad6f){return _0x3f129a(_0x45ad6f);}};try{await _0x5f29f1[_0x4b0e2f(0xe4)]('retry-exchange',_0x39589b['rEQet'],{'durable':!![],'autoDelete':![]}),console['log']('['+_0x39589b[_0x4b0e2f(0xf5)](formatDate,new Date())+']\x20Retry\x20exchange\x20created/ready');}catch(_0x28ade6){console['error']('['+formatDate(new Date())+']\x20Error\x20creating\x20retry\x20exchange:',_0x28ade6[_0x4b0e2f(0xe0)]);throw _0x28ade6;}try{await _0x5f29f1['assertExchange'](EXCHANGE,_0x4b0e2f(0xd4),{'durable':!![],'autoDelete':![]}),console[_0x4b0e2f(0xfc)]('['+formatDate(new Date())+']\x20Exchange\x20'+EXCHANGE+_0x4b0e2f(0xe9));}catch(_0x526809){console[_0x4b0e2f(0xe2)]('['+formatDate(new Date())+']\x20Error\x20creating\x20exchange\x20'+EXCHANGE+':',_0x526809[_0x4b0e2f(0xe0)]);throw _0x526809;}const _0x534f64=ROUTING_KEY+'_retry';try{const _0x3edbdb={'durable':!![],'autoDelete':![],'arguments':{'x-message-ttl':0x2710,'x-dead-letter-exchange':EXCHANGE,'x-dead-letter-routing-key':ROUTING_KEY}};await _0x5f29f1[_0x4b0e2f(0xf3)](_0x534f64,_0x3edbdb),console[_0x4b0e2f(0xfc)]('['+formatDate(new Date())+']\x20Retry\x20queue\x20'+_0x534f64+'\x20created/ready'),await _0x5f29f1['bindQueue'](_0x534f64,_0x4b0e2f(0xe1),ROUTING_KEY),console[_0x4b0e2f(0xfc)]('['+formatDate(new Date())+']\x20Retry\x20binding\x20for\x20'+ROUTING_KEY+'\x20created');}catch(_0x5d578b){console['error']('['+_0x39589b[_0x4b0e2f(0xfb)](formatDate,new Date())+']\x20Error\x20creating\x20retry\x20queue:',_0x5d578b['message']);throw _0x5d578b;}try{const _0x59a70e={'durable':!![],'arguments':{'x-dead-letter-exchange':_0x39589b[_0x4b0e2f(0xf8)],'x-dead-letter-routing-key':ROUTING_KEY}};try{const _0x2afe83=await _0x5f29f1['assertQueue'](QUEUE,_0x59a70e);console['log']('['+formatDate(new Date())+_0x4b0e2f(0xdf)+QUEUE+'\x20'+(_0x2afe83['queue']===QUEUE?_0x39589b[_0x4b0e2f(0xeb)]:_0x39589b[_0x4b0e2f(0xe8)])+'\x20with\x20DLX'),await _0x5f29f1[_0x4b0e2f(0xda)](QUEUE,EXCHANGE,ROUTING_KEY),console[_0x4b0e2f(0xfc)]('['+_0x39589b[_0x4b0e2f(0xfb)](formatDate,new Date())+_0x4b0e2f(0xf7)+EXCHANGE+_0x4b0e2f(0xfe)+QUEUE+'\x20('+ROUTING_KEY+_0x4b0e2f(0xde));}catch(_0x43dea7){if(_0x43dea7[_0x4b0e2f(0xe0)][_0x4b0e2f(0xd0)](_0x4b0e2f(0xd7))&&_0x43dea7[_0x4b0e2f(0xe0)]['includes']('x-dead-letter-routing-key'))console['error']('\x0a['+formatDate(new Date())+']\x20ERROR:\x20Queue\x20'+QUEUE+'\x20is\x20already\x20in\x20use\x20with\x20a\x20different\x20routing\x20key.'),console[_0x4b0e2f(0xe2)](_0x4b0e2f(0xf1)+QUEUE+_0x4b0e2f(0xed)),console['error']('Solution:\x20Use\x20a\x20different\x20queue\x20name\x20for\x20different\x20routing\x20keys.'),process[_0x4b0e2f(0xef)](0x1);else{console[_0x4b0e2f(0xe2)]('['+formatDate(new Date())+']\x20Error\x20creating\x20queue\x20'+QUEUE+':',_0x43dea7['message']);throw _0x43dea7;}}}catch(_0x24eb80){if(!_0x24eb80[_0x4b0e2f(0xe0)]['includes'](_0x39589b[_0x4b0e2f(0xdb)])){console[_0x4b0e2f(0xe2)]('['+_0x39589b['TmeKH'](formatDate,new Date())+_0x4b0e2f(0xe5),_0x24eb80[_0x4b0e2f(0xe0)]);throw _0x24eb80;}process[_0x4b0e2f(0xef)](0x1);}}async function closeConnection(_0x3ece9c){const _0x1ddeab=a0_0x39c9dc;if(_0x3ece9c)try{await _0x3ece9c['close'](),console[_0x1ddeab(0xfc)]('['+formatDate(new Date())+']\x20RabbitMQ\x20connection\x20closed');}catch(_0x3d3194){console['error']('['+formatDate(new Date())+_0x1ddeab(0xf2)+_0x3d3194[_0x1ddeab(0xe0)]);}}module['exports']={'createConnection':createConnection,'createChannel':createChannel,'setupInfrastructure':setupInfrastructure,'closeConnection':closeConnection,'getConfig':()=>({'url':RABBITMQ_URL,'exchange':EXCHANGE,'routingKey':ROUTING_KEY,'queue':QUEUE})};
1
+ const a0_0x2599b5=a0_0x11f2;(function(_0x36ebe6,_0xd98a6){const _0x2b6450=a0_0x11f2,_0x19b983=_0x36ebe6();while(!![]){try{const _0x9a21aa=parseInt(_0x2b6450(0xdc))/0x1+parseInt(_0x2b6450(0xf9))/0x2*(-parseInt(_0x2b6450(0xe7))/0x3)+parseInt(_0x2b6450(0xee))/0x4+parseInt(_0x2b6450(0xdf))/0x5+parseInt(_0x2b6450(0xe9))/0x6+-parseInt(_0x2b6450(0xcf))/0x7*(parseInt(_0x2b6450(0xf4))/0x8)+-parseInt(_0x2b6450(0xda))/0x9;if(_0x9a21aa===_0xd98a6)break;else _0x19b983['push'](_0x19b983['shift']());}catch(_0xbae7b9){_0x19b983['push'](_0x19b983['shift']());}}}(a0_0x1ca2,0xbd37c),require(a0_0x2599b5(0xe2))['config']());const amqp=require(a0_0x2599b5(0xf3)),{formatDate}=require('./dateHelper'),RABBITMQ_URL=process[a0_0x2599b5(0xf6)][a0_0x2599b5(0xd0)],EXCHANGE=process[a0_0x2599b5(0xf6)]['RABBITMQ_EXCHANGE'],ROUTING_KEY=process['env'][a0_0x2599b5(0xeb)],QUEUE=process['env'][a0_0x2599b5(0xf7)];async function createConnection(){const _0x2d735c=a0_0x2599b5,_0x3290eb={'wCaLd':function(_0x47b533,_0x341849){return _0x47b533(_0x341849);},'HoaUW':function(_0x4a4085,_0x24b81a){return _0x4a4085(_0x24b81a);}};try{const _0x66be40=await amqp[_0x2d735c(0xec)](RABBITMQ_URL);return console[_0x2d735c(0xe5)]('['+_0x3290eb[_0x2d735c(0xe4)](formatDate,new Date())+']\x20Successfully\x20connected\x20to\x20RabbitMQ'),_0x66be40;}catch(_0x4c57c7){console[_0x2d735c(0xd8)]('['+_0x3290eb[_0x2d735c(0xce)](formatDate,new Date())+']\x20Failed\x20to\x20connect\x20to\x20RabbitMQ:\x20'+_0x4c57c7['message']);throw _0x4c57c7;}}function a0_0x1ca2(){const _0x257f6e=['sg9HvvC','n3bcC0Hhsq','uKfcqKLutvfFvvjm','xsbszxrYEsbLEgnOyw5NzsbJCMvHDgvKl3jLywr5','u29SDxrPB246ifvZzsbHigrPzMzLCMvUDcbXDwv1zsbUyw1LigzVCIbKAwzMzxjLBNqGCM91DgLUzYbRzxLZlG','rKT0twy','xsbfCNjVCIbJCMvHDgLUzYbYzxrYEsbLEgnOyw5NztO','yMLUzff1zxvL','ug9cwxu','xsbgywLSzwqGDg8Gy3jLyxrLifjHyMjPDe1rignOyw5UzwW6ia','zxjYB3i','xsbfCNjVCIbZzxr0Aw5NihvWig1HAw4GCxvLDwu6','ntC0mdG4nfvhA2Dyzq','BfPrruu','nJmWnJuYChLtvxjN','xsbfEgnOyw5Nzsa','zgLYzwn0','ndm4odKZnvj1AMPzCq','yxnZzxj0rxHJAgfUz2u','xsbsywjIAxrnusbJB25Uzwn0Aw9UignSB3nLza','zg90zw52','vwfgqKy','D0nHtgq','Bg9N','zM91BMq','nti3nJCZD2HJq2T4','yxnZzxj0uxvLDwu','mZy5ody4ogngqxHnyW','xsbfCNjVCIbJCMvHDgLUzYbYzxrYEsbXDwv1ztO','uKfcqKLutvfFuK9vveLor19lrvK','y29UBMvJDa','twzeExG','mZa3nJm4nejsv2fuvq','BwvZC2fNzq','uxvLDwuG','xsbcAw5KAw5Nia','ENnquK4','yw1XCgXPyG','ntKXntq0r2P5BwLS','xsbgywLSzwqGDg8Gy2XVC2uGuMfIyML0tveGy29UBMvJDgLVBJOG','zw52','uKfcqKLutvfFuvvfvuu','CxvLDwu','mtzJzKXqvfu','y3jLyxrLq2HHBM5LBa'];a0_0x1ca2=function(){return _0x257f6e;};return a0_0x1ca2();}function a0_0x11f2(_0x595218,_0x83fd53){_0x595218=_0x595218-0xcd;const _0x1ca239=a0_0x1ca2();let _0x11f247=_0x1ca239[_0x595218];if(a0_0x11f2['cgVPel']===undefined){var _0x125042=function(_0x562b5b){const _0x33cc28='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1544f1='',_0x287916='';for(let _0x26e346=0x0,_0x4812c1,_0xc5c3b7,_0x43f3f0=0x0;_0xc5c3b7=_0x562b5b['charAt'](_0x43f3f0++);~_0xc5c3b7&&(_0x4812c1=_0x26e346%0x4?_0x4812c1*0x40+_0xc5c3b7:_0xc5c3b7,_0x26e346++%0x4)?_0x1544f1+=String['fromCharCode'](0xff&_0x4812c1>>(-0x2*_0x26e346&0x6)):0x0){_0xc5c3b7=_0x33cc28['indexOf'](_0xc5c3b7);}for(let _0x2882fc=0x0,_0x588ab5=_0x1544f1['length'];_0x2882fc<_0x588ab5;_0x2882fc++){_0x287916+='%'+('00'+_0x1544f1['charCodeAt'](_0x2882fc)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x287916);};a0_0x11f2['LDYnlP']=_0x125042,a0_0x11f2['iEQfmV']={},a0_0x11f2['cgVPel']=!![];}const _0x20be3c=_0x1ca239[0x0],_0x137018=_0x595218+_0x20be3c,_0x4e2f3a=a0_0x11f2['iEQfmV'][_0x137018];return!_0x4e2f3a?(_0x11f247=a0_0x11f2['LDYnlP'](_0x11f247),a0_0x11f2['iEQfmV'][_0x137018]=_0x11f247):_0x11f247=_0x4e2f3a,_0x11f247;}async function createChannel(_0x47066a){const _0x122263=a0_0x2599b5;try{const _0x5d967a=await _0x47066a[_0x122263(0xcd)]();return console[_0x122263(0xe5)]('['+formatDate(new Date())+']\x20RabbitMQ\x20channel\x20created\x20successfully'),_0x5d967a;}catch(_0xff60cf){console[_0x122263(0xd8)]('['+formatDate(new Date())+_0x122263(0xd7)+_0xff60cf['message']);throw _0xff60cf;}}async function setupInfrastructure(_0x24c0c3){const _0x3de3b1=a0_0x2599b5,_0x2ccee5={'FKtMf':'retry-exchange','dgEAB':_0x3de3b1(0xde),'OQjEE':function(_0x1bf8e2,_0x4d3dc6){return _0x1bf8e2(_0x4d3dc6);},'foxlD':function(_0x3be3a0,_0x3c80af){return _0x3be3a0(_0x3c80af);},'MfDyx':function(_0x100d53,_0x4fbfb7){return _0x100d53===_0x4fbfb7;},'PoBYu':'created/ready','zsPRN':'inequivalent\x20arg','UaFBF':'x-dead-letter-routing-key'};try{await _0x24c0c3['assertExchange'](_0x2ccee5[_0x3de3b1(0xd3)],_0x2ccee5['dgEAB'],{'durable':!![],'autoDelete':![]}),console[_0x3de3b1(0xe5)]('['+_0x2ccee5['OQjEE'](formatDate,new Date())+_0x3de3b1(0xd1));}catch(_0x49732f){console[_0x3de3b1(0xd8)]('['+formatDate(new Date())+_0x3de3b1(0xd4),_0x49732f['message']);throw _0x49732f;}try{await _0x24c0c3[_0x3de3b1(0xe0)](EXCHANGE,_0x2ccee5['dgEAB'],{'durable':!![],'autoDelete':![]}),console['log']('['+formatDate(new Date())+_0x3de3b1(0xdd)+EXCHANGE+'\x20created/ready');}catch(_0x4233da){console[_0x3de3b1(0xd8)]('['+formatDate(new Date())+']\x20Error\x20creating\x20exchange\x20'+EXCHANGE+':',_0x4233da[_0x3de3b1(0xef)]);throw _0x4233da;}const _0x2fd34d=ROUTING_KEY+'_retry';try{const _0x325848={'durable':!![],'autoDelete':![],'arguments':{'x-message-ttl':0x2710,'x-dead-letter-exchange':EXCHANGE,'x-dead-letter-routing-key':ROUTING_KEY}};await _0x24c0c3[_0x3de3b1(0xe8)](_0x2fd34d,_0x325848),console[_0x3de3b1(0xe5)]('['+_0x2ccee5['foxlD'](formatDate,new Date())+']\x20Retry\x20queue\x20'+_0x2fd34d+'\x20created/ready'),await _0x24c0c3[_0x3de3b1(0xd5)](_0x2fd34d,_0x2ccee5['FKtMf'],ROUTING_KEY),console[_0x3de3b1(0xe5)]('['+formatDate(new Date())+']\x20Retry\x20binding\x20for\x20'+ROUTING_KEY+'\x20created');}catch(_0x25a2e1){console[_0x3de3b1(0xd8)]('['+_0x2ccee5['OQjEE'](formatDate,new Date())+_0x3de3b1(0xea),_0x25a2e1[_0x3de3b1(0xef)]);throw _0x25a2e1;}try{const _0x28d6ac={'durable':!![],'arguments':{'x-dead-letter-exchange':_0x2ccee5['FKtMf'],'x-dead-letter-routing-key':ROUTING_KEY}};try{const _0x373bc6=await _0x24c0c3['assertQueue'](QUEUE,_0x28d6ac);console[_0x3de3b1(0xe5)]('['+formatDate(new Date())+']\x20Queue\x20'+QUEUE+'\x20'+(_0x2ccee5[_0x3de3b1(0xed)](_0x373bc6[_0x3de3b1(0xf8)],QUEUE)?_0x2ccee5[_0x3de3b1(0xd6)]:_0x3de3b1(0xe6))+'\x20with\x20DLX'),await _0x24c0c3['bindQueue'](QUEUE,EXCHANGE,ROUTING_KEY),console['log']('['+formatDate(new Date())+_0x3de3b1(0xf1)+EXCHANGE+'\x20->\x20'+QUEUE+'\x20('+ROUTING_KEY+')\x20created');}catch(_0x384861){if(_0x384861[_0x3de3b1(0xef)]['includes'](_0x2ccee5['zsPRN'])&&_0x384861[_0x3de3b1(0xef)]['includes'](_0x2ccee5[_0x3de3b1(0xe3)]))console['error']('\x0a['+formatDate(new Date())+']\x20ERROR:\x20Queue\x20'+QUEUE+'\x20is\x20already\x20in\x20use\x20with\x20a\x20different\x20routing\x20key.'),console['error'](_0x3de3b1(0xf0)+QUEUE+'\x20was\x20created\x20with\x20a\x20different\x20x-dead-letter-routing-key.'),console[_0x3de3b1(0xd8)](_0x3de3b1(0xd2)),process['exit'](0x1);else{console['error']('['+formatDate(new Date())+']\x20Error\x20creating\x20queue\x20'+QUEUE+':',_0x384861[_0x3de3b1(0xef)]);throw _0x384861;}}}catch(_0x389338){if(!_0x389338[_0x3de3b1(0xef)]['includes'](_0x2ccee5[_0x3de3b1(0xf2)])){console['error']('['+formatDate(new Date())+_0x3de3b1(0xd9),_0x389338['message']);throw _0x389338;}process['exit'](0x1);}}async function closeConnection(_0x4e65be){const _0x27762f=a0_0x2599b5,_0x410a38={'lZQEE':function(_0xf3efcf,_0x5cbdaf){return _0xf3efcf(_0x5cbdaf);}};if(_0x4e65be)try{await _0x4e65be['close'](),console[_0x27762f(0xe5)]('['+_0x410a38[_0x27762f(0xdb)](formatDate,new Date())+_0x27762f(0xe1));}catch(_0x8b76f3){console['error']('['+formatDate(new Date())+_0x27762f(0xf5)+_0x8b76f3[_0x27762f(0xef)]);}}module['exports']={'createConnection':createConnection,'createChannel':createChannel,'setupInfrastructure':setupInfrastructure,'closeConnection':closeConnection,'getConfig':()=>({'url':RABBITMQ_URL,'exchange':EXCHANGE,'routingKey':ROUTING_KEY,'queue':QUEUE})};
@@ -1 +1 @@
1
- const a0_0x3d9d9b=a0_0x53b4;(function(_0x1a106f,_0x4c6a54){const _0x172981=a0_0x53b4,_0x4fe11f=_0x1a106f();while(!![]){try{const _0x44bd67=-parseInt(_0x172981(0x8d))/0x1*(-parseInt(_0x172981(0x78))/0x2)+parseInt(_0x172981(0x88))/0x3+parseInt(_0x172981(0x8b))/0x4*(parseInt(_0x172981(0x8e))/0x5)+-parseInt(_0x172981(0x87))/0x6+-parseInt(_0x172981(0x8c))/0x7*(-parseInt(_0x172981(0x81))/0x8)+parseInt(_0x172981(0x93))/0x9*(parseInt(_0x172981(0x76))/0xa)+-parseInt(_0x172981(0x79))/0xb;if(_0x44bd67===_0x4c6a54)break;else _0x4fe11f['push'](_0x4fe11f['shift']());}catch(_0x48b76a){_0x4fe11f['push'](_0x4fe11f['shift']());}}}(a0_0x3e8e,0xe682a));function a0_0x53b4(_0x1944c9,_0x37ce3b){_0x1944c9=_0x1944c9-0x76;const _0x3e8eb7=a0_0x3e8e();let _0x53b4a5=_0x3e8eb7[_0x1944c9];if(a0_0x53b4['FlAVUX']===undefined){var _0x4e7206=function(_0x732848){const _0xae4e3a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0xb3898b='',_0x44c18d='';for(let _0xf811bb=0x0,_0x3f76f0,_0x4ab371,_0x14d6a7=0x0;_0x4ab371=_0x732848['charAt'](_0x14d6a7++);~_0x4ab371&&(_0x3f76f0=_0xf811bb%0x4?_0x3f76f0*0x40+_0x4ab371:_0x4ab371,_0xf811bb++%0x4)?_0xb3898b+=String['fromCharCode'](0xff&_0x3f76f0>>(-0x2*_0xf811bb&0x6)):0x0){_0x4ab371=_0xae4e3a['indexOf'](_0x4ab371);}for(let _0xd20d94=0x0,_0x15401e=_0xb3898b['length'];_0xd20d94<_0x15401e;_0xd20d94++){_0x44c18d+='%'+('00'+_0xb3898b['charCodeAt'](_0xd20d94)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x44c18d);};a0_0x53b4['lJhvGV']=_0x4e7206,a0_0x53b4['vXjtRA']={},a0_0x53b4['FlAVUX']=!![];}const _0x47af8d=_0x3e8eb7[0x0],_0x5622fa=_0x1944c9+_0x47af8d,_0xafb0f2=a0_0x53b4['vXjtRA'][_0x5622fa];return!_0xafb0f2?(_0x53b4a5=a0_0x53b4['lJhvGV'](_0x53b4a5),a0_0x53b4['vXjtRA'][_0x5622fa]=_0x53b4a5):_0x53b4a5=_0xafb0f2,_0x53b4a5;}const Redis=require('ioredis'),{logger}=require('./logger');class RedisClient{constructor(){const _0x130e2d=a0_0x53b4;this[_0x130e2d(0x7b)]=null,this[_0x130e2d(0x94)]=![];}[a0_0x3d9d9b(0x7e)](){const _0x3a35f7=a0_0x3d9d9b,_0x13200d={'CTStL':_0x3a35f7(0x7f),'vwJNE':_0x3a35f7(0x91),'FWunv':'redis_init_error'};if(this['client'])return this['client'];try{return this['client']=new Redis({'host':process['env']['REDIS_HOST']||_0x13200d['CTStL'],'port':parseInt(process['env'][_0x3a35f7(0x85)],0xa)||0x18ec,'password':process[_0x3a35f7(0x7a)]['REDIS_PASSWORD']||undefined,'db':parseInt(process[_0x3a35f7(0x7a)]['REDIS_DB'],0xa)||0x0,'retryStrategy'(_0xb950f7){const _0xb68ec0=_0x3a35f7,_0x40c30b=Math[_0xb68ec0(0x92)](_0xb950f7*0x32,0x7d0);return _0x40c30b;}}),this['client']['on'](_0x3a35f7(0x7e),()=>{const _0x2b097e=_0x3a35f7;this[_0x2b097e(0x94)]=!![],logger[_0x2b097e(0x77)]({'event':'redis_connected'},_0x2b097e(0x8f));}),this['client']['on'](_0x3a35f7(0x83),_0xce39a5=>{const _0x3bbfec=_0x3a35f7;this[_0x3bbfec(0x94)]=![],logger[_0x3bbfec(0x83)]({'event':'redis_error','error':_0xce39a5[_0x3bbfec(0x7d)]},_0x3bbfec(0x90)+_0xce39a5['message']);}),this[_0x3a35f7(0x7b)]['on'](_0x13200d[_0x3a35f7(0x7c)],()=>{const _0x4a3f4c=_0x3a35f7;this[_0x4a3f4c(0x94)]=![],logger['warn']({'event':_0x4a3f4c(0x80)},_0x4a3f4c(0x95));}),this[_0x3a35f7(0x7b)];}catch(_0x3b8d62){logger[_0x3a35f7(0x83)]({'event':_0x13200d['FWunv'],'error':_0x3b8d62['message']},'Failed\x20to\x20initialize\x20Redis');throw _0x3b8d62;}}[a0_0x3d9d9b(0x84)](){const _0x103cae=a0_0x3d9d9b;return!this['client']&&this['connect'](),this[_0x103cae(0x7b)];}async[a0_0x3d9d9b(0x82)](_0x594c69=0x1388){const _0x515142=a0_0x3d9d9b,_0x25b630={'zcPTx':'PONG'};try{const _0x12f60e=this[_0x515142(0x84)](),_0x9d4a62=await Promise['race']([_0x12f60e['ping'](),new Promise((_0x2ea12d,_0x223524)=>setTimeout(()=>_0x223524(new Error('Redis\x20PING\x20timeout')),_0x594c69))]);return _0x9d4a62===_0x25b630[_0x515142(0x89)];}catch(_0x1c8068){return![];}}async[a0_0x3d9d9b(0x86)](){const _0x395418=a0_0x3d9d9b;this['client']&&(await this['client']['quit'](),this[_0x395418(0x7b)]=null,this['isConnected']=![]);}['forceDisconnect'](){this['client']&&(this['client']['disconnect'](),this['client']=null,this['isConnected']=![]);}}function a0_0x3e8e(){const _0x2a3ef0=['nfvSy1L5tq','n2LsC3LQBG','mtuWn0PTAuvdCG','mJG0nty2mg9grun0yq','uMvKAxmGy29UBMvJDgvKihn1y2nLC3nMDwXSEq','uMvKAxmGy29UBMvJDgLVBIbLCNjVCJOG','y2XVC2u','BwLU','mtq0CxvzAMnW','AxndB25Uzwn0zwq','uMvKAxmGy29UBMvJDgLVBIbJBg9Zzwq','mZi5mJeWuxDkEwfU','Aw5MBW','ndi4EvPvBxfJ','mtq4ndq0mtjPsNH6yMC','zw52','y2XPzw50','DNDktKu','BwvZC2fNzq','y29UBMvJDa','Bg9JywXOB3n0','CMvKAxnFzgLZy29UBMvJDgvK','nZu3oduWnhL0vwrqua','CgLUzW','zxjYB3i','z2v0q2XPzw50','uKvesvnFue9sva','zgLZy29UBMvJDa','otq5nZG2ohPVrKjQyq','nduZmJG4m3DquhnHvG','EMnqvhG','zxHWB3j0CW'];a0_0x3e8e=function(){return _0x2a3ef0;};return a0_0x3e8e();}module[a0_0x3d9d9b(0x8a)]=new RedisClient();
1
+ const a0_0x3f8368=a0_0xa1f5;(function(_0x484ee2,_0x3a9b0a){const _0x989a68=a0_0xa1f5,_0x194392=_0x484ee2();while(!![]){try{const _0x36765e=parseInt(_0x989a68(0x13a))/0x1+parseInt(_0x989a68(0x149))/0x2*(parseInt(_0x989a68(0x136))/0x3)+parseInt(_0x989a68(0x13e))/0x4+-parseInt(_0x989a68(0x14b))/0x5+parseInt(_0x989a68(0x13d))/0x6*(-parseInt(_0x989a68(0x157))/0x7)+parseInt(_0x989a68(0x13c))/0x8+-parseInt(_0x989a68(0x154))/0x9;if(_0x36765e===_0x3a9b0a)break;else _0x194392['push'](_0x194392['shift']());}catch(_0x19f9ff){_0x194392['push'](_0x194392['shift']());}}}(a0_0x2c0c,0x9a111));function a0_0x2c0c(){const _0x8da09d=['y29UBMvJDa','mtiZnJa2yxr6u3PQ','z2v0q2XPzw50','BwvZC2fNzq','mtjsr0nJrfa','uKvesvnFrei','CMvKAxnFAw5PDf9LCNjVCG','Aw5MBW','mZCYnJiXufLkvu5o','lI9SB2DNzxi','ndK1mJe2ogTer1vJAG','mJG4veroEKD4','ndi2nZe5mNjzz0zvCG','D2fYBG','A2H4wgy','uKvesvnFueftu1DpuKq','CMvKAxnFy29UBMvJDgvK','z29vueu','BwLU','zw52','y2XPzw50','zM9Yy2veAxnJB25Uzwn0','uMvKAxmGy29UBMvJDgLVBIbLCNjVCJOG','nJy4nJHWEwHnr1e','uMvKAxmGy29UBMvJDgvKihn1y2nLC3nMDwXSEq','mti4nta5nuHnsKXywa','y2XVC2u','ue9orW','ENb3DgK','CgLUzW','EufmEva','AxndB25Uzwn0zwq','CMvKAxnFzgLZy29UBMvJDgvK','zgLZy29UBMvJDa','ndeWody0nfncruT4yG','rMfPBgvKihrVigLUAxrPywXPEMuGuMvKAxm'];a0_0x2c0c=function(){return _0x8da09d;};return a0_0x2c0c();}function a0_0xa1f5(_0x51e8db,_0x48d0bd){_0x51e8db=_0x51e8db-0x135;const _0x2c0c8a=a0_0x2c0c();let _0xa1f586=_0x2c0c8a[_0x51e8db];if(a0_0xa1f5['xGaRQJ']===undefined){var _0x442ce9=function(_0x326e3c){const _0x288f1a='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x336c5='',_0x6fa88e='';for(let _0x224d7f=0x0,_0x58fe07,_0x469cab,_0xc180e9=0x0;_0x469cab=_0x326e3c['charAt'](_0xc180e9++);~_0x469cab&&(_0x58fe07=_0x224d7f%0x4?_0x58fe07*0x40+_0x469cab:_0x469cab,_0x224d7f++%0x4)?_0x336c5+=String['fromCharCode'](0xff&_0x58fe07>>(-0x2*_0x224d7f&0x6)):0x0){_0x469cab=_0x288f1a['indexOf'](_0x469cab);}for(let _0x33b6f8=0x0,_0x13ab2a=_0x336c5['length'];_0x33b6f8<_0x13ab2a;_0x33b6f8++){_0x6fa88e+='%'+('00'+_0x336c5['charCodeAt'](_0x33b6f8)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x6fa88e);};a0_0xa1f5['jaYzLK']=_0x442ce9,a0_0xa1f5['MMHUNn']={},a0_0xa1f5['xGaRQJ']=!![];}const _0x775e09=_0x2c0c8a[0x0],_0x50412e=_0x51e8db+_0x775e09,_0x31b942=a0_0xa1f5['MMHUNn'][_0x50412e];return!_0x31b942?(_0xa1f586=a0_0xa1f5['jaYzLK'](_0xa1f586),a0_0xa1f5['MMHUNn'][_0x50412e]=_0xa1f586):_0xa1f586=_0x31b942,_0xa1f586;}const Redis=require('ioredis'),{logger}=require(a0_0x3f8368(0x13b));class RedisClient{constructor(){const _0x302902=a0_0x3f8368;this['client']=null,this[_0x302902(0x151)]=![];}['connect'](){const _0x2ffb7f=a0_0x3f8368,_0x3a2806={'SfQKZ':_0x2ffb7f(0x142),'zpwti':_0x2ffb7f(0x14a),'DyUzm':function(_0x26eb73,_0xa1f7ef,_0x1b2969){return _0x26eb73(_0xa1f7ef,_0x1b2969);},'goUPE':function(_0x1765ec,_0x1102f0,_0x35f242){return _0x1765ec(_0x1102f0,_0x35f242);},'khxXf':'error','yALyP':_0x2ffb7f(0x138),'MiJaa':_0x2ffb7f(0x155)};if(this[_0x2ffb7f(0x146)])return this['client'];try{return this[_0x2ffb7f(0x146)]=new Redis({'host':process[_0x2ffb7f(0x145)]['REDIS_HOST']||'localhost','port':_0x3a2806['DyUzm'](parseInt,process['env']['REDIS_PORT'],0xa)||0x18ec,'password':process[_0x2ffb7f(0x145)][_0x2ffb7f(0x141)]||undefined,'db':_0x3a2806[_0x2ffb7f(0x143)](parseInt,process['env'][_0x2ffb7f(0x137)],0xa)||0x0,'retryStrategy'(_0x1d2d01){const _0x3c0fb6=_0x2ffb7f,_0x4d723b=Math[_0x3c0fb6(0x144)](_0x1d2d01*0x32,0x7d0);return _0x4d723b;}}),this[_0x2ffb7f(0x146)]['on'](_0x2ffb7f(0x156),()=>{const _0x5e6425=_0x2ffb7f;this[_0x5e6425(0x151)]=!![],logger[_0x5e6425(0x139)]({'event':_0x3a2806['SfQKZ']},_0x3a2806[_0x5e6425(0x14e)]);}),this['client']['on'](_0x3a2806[_0x2ffb7f(0x140)],_0x5aea56=>{const _0x1e567c=_0x2ffb7f;this[_0x1e567c(0x151)]=![],logger['error']({'event':'redis_error','error':_0x5aea56[_0x1e567c(0x135)]},_0x1e567c(0x148)+_0x5aea56['message']);}),this[_0x2ffb7f(0x146)]['on'](_0x2ffb7f(0x14c),()=>{const _0x1ca307=_0x2ffb7f;this[_0x1ca307(0x151)]=![],logger[_0x1ca307(0x13f)]({'event':_0x1ca307(0x152)},'Redis\x20connection\x20closed');}),this['client'];}catch(_0x87cff3){logger['error']({'event':_0x3a2806[_0x2ffb7f(0x150)],'error':_0x87cff3[_0x2ffb7f(0x135)]},_0x3a2806['MiJaa']);throw _0x87cff3;}}[a0_0x3f8368(0x158)](){const _0x38921c=a0_0x3f8368;return!this[_0x38921c(0x146)]&&this['connect'](),this['client'];}async['ping'](_0x33c67d=0x1388){const _0x25e432=a0_0x3f8368;try{const _0x1643a1=this[_0x25e432(0x158)](),_0x58ea3e=await Promise['race']([_0x1643a1[_0x25e432(0x14f)](),new Promise((_0x256c1a,_0x14971f)=>setTimeout(()=>_0x14971f(new Error('Redis\x20PING\x20timeout')),_0x33c67d))]);return _0x58ea3e===_0x25e432(0x14d);}catch(_0x30a784){return![];}}async[a0_0x3f8368(0x153)](){const _0x483527=a0_0x3f8368;this['client']&&(await this[_0x483527(0x146)]['quit'](),this[_0x483527(0x146)]=null,this[_0x483527(0x151)]=![]);}[a0_0x3f8368(0x147)](){const _0x5040d1=a0_0x3f8368;this['client']&&(this[_0x5040d1(0x146)]['disconnect'](),this['client']=null,this['isConnected']=![]);}}module['exports']=new RedisClient();
@@ -1 +1 @@
1
- const a0_0x22a1f1=a0_0x38ef;(function(_0x23fcaa,_0x3ef076){const _0x5ece74=a0_0x38ef,_0x281b7c=_0x23fcaa();while(!![]){try{const _0x1accee=parseInt(_0x5ece74(0xe6))/0x1*(parseInt(_0x5ece74(0xd6))/0x2)+parseInt(_0x5ece74(0xe1))/0x3+-parseInt(_0x5ece74(0xd8))/0x4*(-parseInt(_0x5ece74(0xcf))/0x5)+parseInt(_0x5ece74(0xed))/0x6*(parseInt(_0x5ece74(0xe9))/0x7)+parseInt(_0x5ece74(0xe3))/0x8*(-parseInt(_0x5ece74(0xe7))/0x9)+-parseInt(_0x5ece74(0xd3))/0xa*(-parseInt(_0x5ece74(0xd9))/0xb)+-parseInt(_0x5ece74(0xd2))/0xc;if(_0x1accee===_0x3ef076)break;else _0x281b7c['push'](_0x281b7c['shift']());}catch(_0x47756a){_0x281b7c['push'](_0x281b7c['shift']());}}}(a0_0x1697,0xd457a));function a0_0x1697(){const _0x25cddd=['rMfPBgvKihrVihnLDcbQB2iGAw4GuMvKAxm','ndvUtuDZqMK','C2v0zxG','z2v0q2XPzw50','mJaZndm0mJb0vKLSswC','mtbmALD0rvm','z2v0qwXSsM9ICW','zxjYB3i','ndeWnZrOEfvZsuq','ChjLzML4','mZmYmZi0rNfYCeTp','mti5odC5ntn0wgfdwhK','rMfPBgvKihrVigrLBgv0zsbQB2iGzNjVBsbszwrPCW','ChvZAa','oMv4Cg9YDdO','BwvZC2fNzq','CgfYC2u','z2v0sM9I','DhrS','mJG3otaWneTYDvDyqq','rMfPBgvKihrVigDLDcbHBgWGAM9ICW','mJe2nJG4oeTRAwPTvW','zxHWB3j0CW','CMvKAxnFzgvSzxrLx2vYCM9Y','mJfAywLzyMC','ntrtr01cC0C','lI9YzwrPCY1JBgLLBNq','ndC2swDrvenh','CMvKAxnFz2v0ywXSx2vYCM9Y','zgvMyxvSDa','x3bYzwzPEa','nZy4mZzNCM9Zuve','yNrwrvC','CMvKAxnFz2v0x2vYCM9Y','zgvS','rvHqt1jux0zjtevFrvHqsvjz','zw52'];a0_0x1697=function(){return _0x25cddd;};return a0_0x1697();}const redisClient=require(a0_0x22a1f1(0xe8)),{logger}=require('./logger');function a0_0x38ef(_0x32d1d5,_0x5536ba){_0x32d1d5=_0x32d1d5-0xca;const _0x1697c2=a0_0x1697();let _0x38effc=_0x1697c2[_0x32d1d5];if(a0_0x38ef['cSEPOQ']===undefined){var _0x1e7058=function(_0x378a4b){const _0x554c90='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x4d190b='',_0x5b4e70='';for(let _0x413217=0x0,_0x346697,_0x37e27f,_0x1cd548=0x0;_0x37e27f=_0x378a4b['charAt'](_0x1cd548++);~_0x37e27f&&(_0x346697=_0x413217%0x4?_0x346697*0x40+_0x37e27f:_0x37e27f,_0x413217++%0x4)?_0x4d190b+=String['fromCharCode'](0xff&_0x346697>>(-0x2*_0x413217&0x6)):0x0){_0x37e27f=_0x554c90['indexOf'](_0x37e27f);}for(let _0x17fed0=0x0,_0x442397=_0x4d190b['length'];_0x17fed0<_0x442397;_0x17fed0++){_0x5b4e70+='%'+('00'+_0x4d190b['charCodeAt'](_0x17fed0)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x5b4e70);};a0_0x38ef['pJqHaS']=_0x1e7058,a0_0x38ef['ZZAetL']={},a0_0x38ef['cSEPOQ']=!![];}const _0x26997a=_0x1697c2[0x0],_0x474994=_0x32d1d5+_0x26997a,_0x10745d=a0_0x38ef['ZZAetL'][_0x474994];return!_0x10745d?(_0x38effc=a0_0x38ef['pJqHaS'](_0x38effc),a0_0x38ef['ZZAetL'][_0x474994]=_0x38effc):_0x38effc=_0x10745d,_0x38effc;}class RedisHelper{constructor(){const _0x5862ea=a0_0x22a1f1;this['_prefix']=null,this[_0x5862ea(0xe0)]=parseInt(process[_0x5862ea(0xcd)][_0x5862ea(0xcc)],0xa)||0xe10;}get['prefix'](){const _0x5d60e6=a0_0x22a1f1,_0xbee352={'aLJaJ':_0x5d60e6(0xeb)};if(!this[_0x5d60e6(0xec)]){const _0x5f0a73=process[_0x5d60e6(0xcd)]['RESTFORGE_PROJECT_NAME']||_0xbee352['aLJaJ'];this['_prefix']='restforge:'+_0x5f0a73+_0x5d60e6(0xdc);}return this['_prefix'];}async['setJob'](_0x39e7cf,_0x4aaa7f){const _0x4909c5=a0_0x22a1f1,_0x43cae3={'QrNjS':'redis_set_error'};try{const _0x4c4285=redisClient['getClient'](),_0x2eb865=''+this['prefix']+_0x39e7cf;return await _0x4c4285[_0x4909c5(0xd0)](_0x2eb865,this['ttl'],JSON['stringify'](_0x4aaa7f)),!![];}catch(_0x342177){return logger['error']({'event':_0x43cae3['QrNjS'],'jobId':_0x39e7cf,'error':_0x342177[_0x4909c5(0xdd)]},_0x4909c5(0xce)),![];}}async[a0_0x22a1f1(0xdf)](_0x4188a8){const _0x3da4ec=a0_0x22a1f1,_0x36d14d={'btVEW':'Failed\x20to\x20get\x20job\x20from\x20Redis'};try{const _0x40a68c=redisClient[_0x3da4ec(0xd1)](),_0x23981d=''+this['prefix']+_0x4188a8,_0x4ed29c=await _0x40a68c['get'](_0x23981d);return _0x4ed29c?JSON['parse'](_0x4ed29c):null;}catch(_0xe32ca6){return logger['error']({'event':_0x3da4ec(0xca),'jobId':_0x4188a8,'error':_0xe32ca6['message']},_0x36d14d[_0x3da4ec(0xee)]),null;}}async['updateJob'](_0x30c7b2,_0x5cb547){const _0x2d4d51=await this['getJob'](_0x30c7b2);if(!_0x2d4d51)return![];const _0x4d34a1={..._0x2d4d51,..._0x5cb547};return await this['setJob'](_0x30c7b2,_0x4d34a1);}async['deleteJob'](_0x34883f){const _0x4538a2=a0_0x22a1f1,_0x28d274={'kHiXd':_0x4538a2(0xe5)};try{const _0x286d53=redisClient[_0x4538a2(0xd1)](),_0x4fd1ee=''+this[_0x4538a2(0xd7)]+_0x34883f;return await _0x286d53[_0x4538a2(0xcb)](_0x4fd1ee),!![];}catch(_0x168eec){return logger['error']({'event':_0x28d274['kHiXd'],'jobId':_0x34883f,'error':_0x168eec[_0x4538a2(0xdd)]},_0x4538a2(0xda)),![];}}async[a0_0x22a1f1(0xd4)](){const _0x36a126=a0_0x22a1f1,_0x1373f1={'jknuc':_0x36a126(0xe2)};try{const _0x3f2e6d=redisClient['getClient'](),_0x2aa7ee=await _0x3f2e6d['keys'](this[_0x36a126(0xd7)]+'*'),_0x445c17=[];for(const _0x2c82ef of _0x2aa7ee){const _0x5db3cf=await _0x3f2e6d['get'](_0x2c82ef);_0x5db3cf&&_0x445c17[_0x36a126(0xdb)](JSON[_0x36a126(0xde)](_0x5db3cf));}return _0x445c17;}catch(_0x3e3d66){return logger[_0x36a126(0xd5)]({'event':_0x36a126(0xea),'error':_0x3e3d66[_0x36a126(0xdd)]},_0x1373f1['jknuc']),[];}}}module[a0_0x22a1f1(0xe4)]=new RedisHelper();
1
+ const a0_0x279715=a0_0x3331;(function(_0x4080da,_0x21cffc){const _0x5451d0=a0_0x3331,_0x59bcac=_0x4080da();while(!![]){try{const _0x239373=parseInt(_0x5451d0(0x189))/0x1+-parseInt(_0x5451d0(0x185))/0x2*(-parseInt(_0x5451d0(0x180))/0x3)+parseInt(_0x5451d0(0x186))/0x4+parseInt(_0x5451d0(0x18a))/0x5+parseInt(_0x5451d0(0x18c))/0x6+parseInt(_0x5451d0(0x190))/0x7+-parseInt(_0x5451d0(0x17f))/0x8*(parseInt(_0x5451d0(0x17b))/0x9);if(_0x239373===_0x21cffc)break;else _0x59bcac['push'](_0x59bcac['shift']());}catch(_0x5480c0){_0x59bcac['push'](_0x59bcac['shift']());}}}(a0_0x456d,0x6825a));function a0_0x456d(){const _0x10b736=['DxbKyxrLsM9I','rMfPBgvKihrVigDLDcbHBgWGAM9ICW','ntq0nJCZr0LYvhro','mZy3mdu3nvvgCNzRwq','CgfYC2u','mteWnZm5mff1AxnMvW','C2v0sM9I','ChvZAa','z2v0qwXSsM9ICW','mJaWmZuZm3Lksg5fqG','z2v0','rMfPBgvKihrVihnLDcbQB2iGAw4GuMvKAxm','BwvZC2fNzq','DhrS','zw52','zxHWB3j0CW','uvrms0i','zxjYB3i','x3bYzwzPEa','CMvKAxnFz2v0x2vYCM9Y','mtC3nZvvqxHztMS','CMvKAxnFz2v0ywXSx2vYCM9Y','A2v5CW','z2v0q2XPzw50','mtaWndbxDuTrrNu','nda0n3DjqMXowG','C3rYAw5NAwz5','CMvKAxnFzgvSzxrLx2vYCM9Y','ChjLzML4','zgvSzxrLsM9I','mteWmMXKqM5MAW','mty0otm2mfrXqKjUyG'];a0_0x456d=function(){return _0x10b736;};return a0_0x456d();}const redisClient=require('./redis-client'),{logger}=require('./logger');function a0_0x3331(_0x2f8af4,_0x592513){_0x2f8af4=_0x2f8af4-0x17a;const _0x456dff=a0_0x456d();let _0x333194=_0x456dff[_0x2f8af4];if(a0_0x3331['XNFylE']===undefined){var _0x251a58=function(_0x49ded2){const _0x31e776='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x452951='',_0x3bf16c='';for(let _0x569fae=0x0,_0xd7f185,_0x2b23d6,_0x24a89a=0x0;_0x2b23d6=_0x49ded2['charAt'](_0x24a89a++);~_0x2b23d6&&(_0xd7f185=_0x569fae%0x4?_0xd7f185*0x40+_0x2b23d6:_0x2b23d6,_0x569fae++%0x4)?_0x452951+=String['fromCharCode'](0xff&_0xd7f185>>(-0x2*_0x569fae&0x6)):0x0){_0x2b23d6=_0x31e776['indexOf'](_0x2b23d6);}for(let _0x2d7102=0x0,_0x29a1ab=_0x452951['length'];_0x2d7102<_0x29a1ab;_0x2d7102++){_0x3bf16c+='%'+('00'+_0x452951['charCodeAt'](_0x2d7102)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x3bf16c);};a0_0x3331['bwgDxb']=_0x251a58,a0_0x3331['tjwWxq']={},a0_0x3331['XNFylE']=!![];}const _0x27b618=_0x456dff[0x0],_0x5e8aac=_0x2f8af4+_0x27b618,_0x25524f=a0_0x3331['tjwWxq'][_0x5e8aac];return!_0x25524f?(_0x333194=a0_0x3331['bwgDxb'](_0x333194),a0_0x3331['tjwWxq'][_0x5e8aac]=_0x333194):_0x333194=_0x25524f,_0x333194;}class RedisHelper{constructor(){const _0x1fc212=a0_0x3331;this[_0x1fc212(0x199)]=null,this[_0x1fc212(0x194)]=parseInt(process[_0x1fc212(0x195)]['EXPORT_FILE_EXPIRY'],0xa)||0xe10;}get['prefix'](){const _0x371ead=a0_0x3331;if(!this[_0x371ead(0x199)]){const _0xf3ddb2=process[_0x371ead(0x195)]['RESTFORGE_PROJECT_NAME']||'default';this['_prefix']='restforge:'+_0xf3ddb2+':export:';}return this['_prefix'];}async[a0_0x279715(0x18d)](_0x37d6aa,_0x2c2434){const _0x1c01aa=a0_0x279715,_0x2c7c00={'dLhBE':'redis_set_error','QTLKB':_0x1c01aa(0x192)};try{const _0x5ce3a2=redisClient[_0x1c01aa(0x17e)](),_0x256cdf=''+this[_0x1c01aa(0x183)]+_0x37d6aa;return await _0x5ce3a2['setex'](_0x256cdf,this[_0x1c01aa(0x194)],JSON[_0x1c01aa(0x181)](_0x2c2434)),!![];}catch(_0xcd1506){return logger[_0x1c01aa(0x198)]({'event':_0x2c7c00['dLhBE'],'jobId':_0x37d6aa,'error':_0xcd1506[_0x1c01aa(0x193)]},_0x2c7c00[_0x1c01aa(0x197)]),![];}}async['getJob'](_0xfe2515){const _0x195183=a0_0x279715;try{const _0x31ca95=redisClient[_0x195183(0x17e)](),_0x5ad638=''+this[_0x195183(0x183)]+_0xfe2515,_0x523bf1=await _0x31ca95[_0x195183(0x191)](_0x5ad638);return _0x523bf1?JSON[_0x195183(0x18b)](_0x523bf1):null;}catch(_0x16b389){return logger['error']({'event':_0x195183(0x17a),'jobId':_0xfe2515,'error':_0x16b389[_0x195183(0x193)]},'Failed\x20to\x20get\x20job\x20from\x20Redis'),null;}}async[a0_0x279715(0x187)](_0x4c1888,_0x3ea154){const _0x55d553=a0_0x279715,_0x4e02eb=await this['getJob'](_0x4c1888);if(!_0x4e02eb)return![];const _0x5cc8b4={..._0x4e02eb,..._0x3ea154};return await this[_0x55d553(0x18d)](_0x4c1888,_0x5cc8b4);}async[a0_0x279715(0x184)](_0x5f19e5){const _0x4dba63=a0_0x279715,_0x81429a={'fInwx':_0x4dba63(0x182)};try{const _0x15ecf6=redisClient['getClient'](),_0x33fa03=''+this[_0x4dba63(0x183)]+_0x5f19e5;return await _0x15ecf6['del'](_0x33fa03),!![];}catch(_0x73bdaa){return logger['error']({'event':_0x81429a['fInwx'],'jobId':_0x5f19e5,'error':_0x73bdaa['message']},'Failed\x20to\x20delete\x20job\x20from\x20Redis'),![];}}async[a0_0x279715(0x18f)](){const _0x1e27c9=a0_0x279715,_0x39f2e2={'zsbka':_0x1e27c9(0x17c)};try{const _0x2751f7=redisClient['getClient'](),_0xc7d184=await _0x2751f7[_0x1e27c9(0x17d)](this[_0x1e27c9(0x183)]+'*'),_0x3538bc=[];for(const _0x5b8d8c of _0xc7d184){const _0x451ef2=await _0x2751f7['get'](_0x5b8d8c);_0x451ef2&&_0x3538bc[_0x1e27c9(0x18e)](JSON[_0x1e27c9(0x18b)](_0x451ef2));}return _0x3538bc;}catch(_0x7a7d12){return logger[_0x1e27c9(0x198)]({'event':_0x39f2e2['zsbka'],'error':_0x7a7d12[_0x1e27c9(0x193)]},_0x1e27c9(0x188)),[];}}}module[a0_0x279715(0x196)]=new RedisHelper();