@restforgejs/platform 5.1.0 → 5.1.4

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 (178) hide show
  1. package/build-info.json +2 -2
  2. package/cli/consumer-deploy.js +1 -1
  3. package/cli/consumer.js +1 -1
  4. package/generators/cli/data/pull.js +95 -0
  5. package/generators/cli/data/push.js +85 -0
  6. package/generators/cli/fast-track.js +12 -25
  7. package/generators/cli/schema/introspect.js +10 -10
  8. package/generators/lib/data/db-executor.js +440 -0
  9. package/generators/lib/data/dialect-kit.js +56 -0
  10. package/generators/lib/data/envelope.js +220 -0
  11. package/generators/lib/data/pull-runner.js +407 -0
  12. package/generators/lib/data/push-runner.js +382 -0
  13. package/generators/lib/data/sdf-reader.js +132 -0
  14. package/generators/lib/data/table-order.js +126 -0
  15. package/generators/lib/data/value-codec.js +188 -0
  16. package/generators/lib/templates/dashboard-catalog.js +1 -1
  17. package/generators/lib/templates/db-connection-env.js +1 -1
  18. package/generators/lib/templates/dbschema-catalog.js +1 -1
  19. package/generators/lib/templates/field-validation-catalog.js +1 -1
  20. package/generators/lib/templates/mysql-template.js +1 -1
  21. package/generators/lib/templates/oracle-template.js +1 -1
  22. package/generators/lib/templates/postgres-template.js +1 -1
  23. package/generators/lib/templates/query-declarative-catalog.js +1 -1
  24. package/generators/lib/templates/sqlite-template.js +1 -1
  25. package/integrity-manifest.json +18 -18
  26. package/package.json +1 -1
  27. package/scripts/verify-integrity.js +1 -1
  28. package/server.js +1 -1
  29. package/src/components/handlers/adjust_handler.js +1 -1
  30. package/src/components/handlers/audit_handler.js +1 -1
  31. package/src/components/handlers/delete_handler.js +1 -1
  32. package/src/components/handlers/export_handler.js +1 -1
  33. package/src/components/handlers/import_handler.js +1 -1
  34. package/src/components/handlers/insert_handler.js +1 -1
  35. package/src/components/handlers/update_handler.js +1 -1
  36. package/src/components/handlers/upload_handler.js +1 -1
  37. package/src/components/handlers/workflow_handler.js +1 -1
  38. package/src/components/integrations/webhook.js +1 -1
  39. package/src/consumers/baseConsumer.js +1 -1
  40. package/src/consumers/declarativeMapper.js +1 -1
  41. package/src/consumers/handlers/apiHandler.js +1 -1
  42. package/src/consumers/handlers/consoleHandler.js +1 -1
  43. package/src/consumers/handlers/databaseHandler.js +1 -1
  44. package/src/consumers/handlers/index.js +1 -1
  45. package/src/consumers/handlers/kafkaHandler.js +1 -1
  46. package/src/consumers/index.js +1 -1
  47. package/src/consumers/messageTransformer.js +1 -1
  48. package/src/consumers/validator.js +1 -1
  49. package/src/core/db/dialect/base-dialect.js +1 -1
  50. package/src/core/db/dialect/index.js +1 -1
  51. package/src/core/db/dialect/mysql-dialect.js +1 -1
  52. package/src/core/db/dialect/oracle-dialect.js +1 -1
  53. package/src/core/db/dialect/postgres-dialect.js +1 -1
  54. package/src/core/db/dialect/sqlite-dialect.js +1 -1
  55. package/src/core/db/flatten-helper.js +1 -1
  56. package/src/core/db/query-builder-error.js +1 -1
  57. package/src/core/db/query-builder.js +1 -1
  58. package/src/core/db/relation-helper.js +1 -1
  59. package/src/core/handlers/delete_handler.js +1 -1
  60. package/src/core/handlers/insert_handler.js +1 -1
  61. package/src/core/handlers/update_handler.js +1 -1
  62. package/src/core/models/base-model.js +1 -1
  63. package/src/core/utils/cache-manager.js +1 -1
  64. package/src/core/utils/component-engine.js +1 -1
  65. package/src/core/utils/context-builder.js +1 -1
  66. package/src/core/utils/datetime-formatter.js +1 -1
  67. package/src/core/utils/datetime-parser.js +1 -1
  68. package/src/core/utils/db.js +1 -1
  69. package/src/core/utils/logger.js +1 -1
  70. package/src/core/utils/payload-loader.js +1 -1
  71. package/src/core/utils/security-checks.js +1 -1
  72. package/src/middleware/body-options.js +1 -1
  73. package/src/middleware/cors.js +1 -1
  74. package/src/middleware/idempotency.js +1 -1
  75. package/src/middleware/rate-limiter.js +1 -1
  76. package/src/middleware/request-logger.js +1 -1
  77. package/src/middleware/security-headers.js +1 -1
  78. package/src/models/base-model-mysql.js +1 -1
  79. package/src/models/base-model-oracle.js +1 -1
  80. package/src/models/base-model-sqlite.js +1 -1
  81. package/src/models/base-model.js +1 -1
  82. package/src/pro/caching/redis-client.js +1 -1
  83. package/src/pro/caching/redis-helper.js +1 -1
  84. package/src/pro/consumers/baseConsumer.js +1 -1
  85. package/src/pro/consumers/declarativeMapper.js +1 -1
  86. package/src/pro/consumers/handlers/apiHandler.js +1 -1
  87. package/src/pro/consumers/handlers/consoleHandler.js +1 -1
  88. package/src/pro/consumers/handlers/databaseHandler.js +1 -1
  89. package/src/pro/consumers/handlers/index.js +1 -1
  90. package/src/pro/consumers/handlers/kafkaHandler.js +1 -1
  91. package/src/pro/consumers/index.js +1 -1
  92. package/src/pro/consumers/messageTransformer.js +1 -1
  93. package/src/pro/consumers/validator.js +1 -1
  94. package/src/pro/database/base-model-mysql.js +1 -1
  95. package/src/pro/database/base-model-oracle.js +1 -1
  96. package/src/pro/database/base-model-sqlite.js +1 -1
  97. package/src/pro/database/db-mysql.js +1 -1
  98. package/src/pro/database/db-oracle.js +1 -1
  99. package/src/pro/database/db-sqlite.js +1 -1
  100. package/src/pro/excel/excel-generator.js +1 -1
  101. package/src/pro/excel/excel-parser.js +1 -1
  102. package/src/pro/excel/export-service.js +1 -1
  103. package/src/pro/excel/export_handler.js +1 -1
  104. package/src/pro/excel/import-service.js +1 -1
  105. package/src/pro/excel/import-validator.js +1 -1
  106. package/src/pro/excel/import_handler.js +1 -1
  107. package/src/pro/excel/upsert-builder.js +1 -1
  108. package/src/pro/idgen/idgen-routes.js +1 -1
  109. package/src/pro/integrations/lookup-resolver.js +1 -1
  110. package/src/pro/integrations/upload-handler-v2.js +1 -1
  111. package/src/pro/integrations/upload-handler.js +1 -1
  112. package/src/pro/integrations/webhook.js +1 -1
  113. package/src/pro/locking/lock-routes.js +1 -1
  114. package/src/pro/locking/resource-lock-manager.js +1 -1
  115. package/src/pro/messaging/kafkaConsumerService.js +1 -1
  116. package/src/pro/messaging/kafkaService.js +1 -1
  117. package/src/pro/messaging/messagehubService.js +1 -1
  118. package/src/pro/messaging/rabbitmqService.js +1 -1
  119. package/src/pro/scheduler/job-manager.js +1 -1
  120. package/src/pro/scheduler/job-routes.js +1 -1
  121. package/src/pro/scheduler/job-validator.js +1 -1
  122. package/src/pro/storage/base-storage-provider.js +1 -1
  123. package/src/pro/storage/file-metadata-helper.js +1 -1
  124. package/src/pro/storage/index.js +1 -1
  125. package/src/pro/storage/local-storage-provider.js +1 -1
  126. package/src/pro/storage/s3-storage-provider.js +1 -1
  127. package/src/pro/storage/upload-cleanup-job.js +1 -1
  128. package/src/pro/storage/upload-cleanup-scheduler.js +1 -1
  129. package/src/pro/storage/upload-pending-tracker.js +1 -1
  130. package/src/pro/websocket/broadcast-helper.js +1 -1
  131. package/src/pro/websocket/index.js +1 -1
  132. package/src/pro/websocket/livesync-server.js +1 -1
  133. package/src/pro/websocket/ws-broadcaster.js +1 -1
  134. package/src/services/export-service.js +1 -1
  135. package/src/services/import-service.js +1 -1
  136. package/src/services/kafkaConsumerService.js +1 -1
  137. package/src/services/kafkaService.js +1 -1
  138. package/src/services/messagehubService.js +1 -1
  139. package/src/services/rabbitmqService.js +1 -1
  140. package/src/utils/cache-invalidation-registry.js +1 -1
  141. package/src/utils/cache-manager.js +1 -1
  142. package/src/utils/component-engine.js +1 -1
  143. package/src/utils/config-extractor.js +1 -1
  144. package/src/utils/consumerLogger.js +1 -1
  145. package/src/utils/context-builder.js +1 -1
  146. package/src/utils/dashboard-helpers.js +1 -1
  147. package/src/utils/dateHelper.js +1 -1
  148. package/src/utils/datetime-formatter.js +1 -1
  149. package/src/utils/datetime-parser.js +1 -1
  150. package/src/utils/db-bootstrap.js +1 -1
  151. package/src/utils/db-mysql.js +1 -1
  152. package/src/utils/db-oracle.js +1 -1
  153. package/src/utils/db-sqlite.js +1 -1
  154. package/src/utils/db.js +1 -1
  155. package/src/utils/demo-generator.js +1 -1
  156. package/src/utils/excel-generator.js +1 -1
  157. package/src/utils/excel-parser.js +1 -1
  158. package/src/utils/file-watcher.js +1 -1
  159. package/src/utils/id-generator.js +1 -1
  160. package/src/utils/idempotency-manager.js +1 -1
  161. package/src/utils/import-validator.js +1 -1
  162. package/src/utils/license-client.js +1 -1
  163. package/src/utils/lock-manager.js +1 -1
  164. package/src/utils/logger.js +1 -1
  165. package/src/utils/lookup-resolver.js +1 -1
  166. package/src/utils/payload-loader.js +1 -1
  167. package/src/utils/processor-response.js +1 -1
  168. package/src/utils/rabbitmq.js +1 -1
  169. package/src/utils/redis-client.js +1 -1
  170. package/src/utils/redis-helper.js +1 -1
  171. package/src/utils/request-scope.js +1 -1
  172. package/src/utils/security-checks.js +1 -1
  173. package/src/utils/service-resolver.js +1 -1
  174. package/src/utils/shutdown-coordinator.js +1 -1
  175. package/src/utils/trusted-keys.js +1 -1
  176. package/src/utils/upload-handler.js +1 -1
  177. package/src/utils/upsert-builder.js +1 -1
  178. package/src/utils/workflow-hook-executor.js +1 -1
@@ -1 +1 @@
1
- const a0_0xc9b27=a0_0x1984;function a0_0x2c77(){const _0x471fd0=['mJyXnde2mhnbvu5wrW','s1rnsuC','sw52ywXPzcb0Aw1LC3rHBxaGDMfSDwu6ia','Dwnptxa','z2v0twLUDxrLCW','zgf0zq','zM9YBwf0vgLTzq','zM9YBwf0vgLTzxn0yw1W','BgvUz3rO','svD0q0e','CxrKrLK','C3bSAxq','D2fYBG','mZG1mZCYmKvizKLcBW','mJu2oe9ssfDtuW','mtaXntDbAvLywNa','mJuYntmZmfrKCfHzva','z2v0tw9UDgG','zM9YBwf0','mJmWmJmXne5uDKrjCa','reHUChy','mJG2mtC2mtbqD1DZtha','DgLTzxn0yw1W','mZe4mZy5CML6vLHr','mtjAqunjzxC','C3rYAw5N','z2v0rgf0zq','CgfKu3rHCNq','zM9YBwf0rgf0zq','ovjeCKPPDW','z2v0vgLTzq'];a0_0x2c77=function(){return _0x471fd0;};return a0_0x2c77();}(function(_0x1e4c0b,_0x42b541){const _0xc4c74b=a0_0x1984,_0x5c7dae=_0x1e4c0b();while(!![]){try{const _0x2931c1=parseInt(_0xc4c74b(0x11c))/0x1+-parseInt(_0xc4c74b(0x118))/0x2+parseInt(_0xc4c74b(0x131))/0x3+-parseInt(_0xc4c74b(0x11d))/0x4*(parseInt(_0xc4c74b(0x115))/0x5)+parseInt(_0xc4c74b(0x132))/0x6*(-parseInt(_0xc4c74b(0x114))/0x7)+parseInt(_0xc4c74b(0x124))/0x8*(-parseInt(_0xc4c74b(0x122))/0x9)+parseInt(_0xc4c74b(0x11a))/0xa;if(_0x2931c1===_0x42b541)break;else _0x5c7dae['push'](_0x5c7dae['shift']());}catch(_0x1b1d9b){_0x5c7dae['push'](_0x5c7dae['shift']());}}}(a0_0x2c77,0xcfa77));function a0_0x1984(_0x5cf736,_0x461558){_0x5cf736=_0x5cf736-0x114;const _0x2c777a=a0_0x2c77();let _0x198457=_0x2c777a[_0x5cf736];if(a0_0x1984['aIMeQO']===undefined){var _0x5b10e9=function(_0x1c4272){const _0xa3dd25='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x15cfc6='',_0x14fa9b='';for(let _0x1e553f=0x0,_0x50155d,_0x16dc16,_0x321de5=0x0;_0x16dc16=_0x1c4272['charAt'](_0x321de5++);~_0x16dc16&&(_0x50155d=_0x1e553f%0x4?_0x50155d*0x40+_0x16dc16:_0x16dc16,_0x1e553f++%0x4)?_0x15cfc6+=String['fromCharCode'](0xff&_0x50155d>>(-0x2*_0x1e553f&0x6)):0x0){_0x16dc16=_0xa3dd25['indexOf'](_0x16dc16);}for(let _0x3c4dc5=0x0,_0x475c70=_0x15cfc6['length'];_0x3c4dc5<_0x475c70;_0x3c4dc5++){_0x14fa9b+='%'+('00'+_0x15cfc6['charCodeAt'](_0x3c4dc5)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x14fa9b);};a0_0x1984['qIGcyj']=_0x5b10e9,a0_0x1984['LzgADv']={},a0_0x1984['aIMeQO']=!![];}const _0x2fb0e4=_0x2c777a[0x0],_0xee4d63=_0x5cf736+_0x2fb0e4,_0x4fa517=a0_0x1984['LzgADv'][_0xee4d63];return!_0x4fa517?(_0x198457=a0_0x1984['qIGcyj'](_0x198457),a0_0x1984['LzgADv'][_0xee4d63]=_0x198457):_0x198457=_0x4fa517,_0x198457;}class DateTimeFormatter{static[a0_0xc9b27(0x117)](_0xfb92e6,_0x4efc34,_0x357964){const _0x273b1f=a0_0xc9b27,_0x151a46={'IWtCA':_0x273b1f(0x129),'PgHFQ':function(_0x5122f9,_0x36b43a){return _0x5122f9===_0x36b43a;},'KTMIG':'time'};if(!_0xfb92e6)return null;try{if(_0x357964===_0x151a46[_0x273b1f(0x12d)])return this[_0x273b1f(0x121)](_0xfb92e6,_0x4efc34);else{if(_0x151a46['PgHFQ'](_0x357964,_0x273b1f(0x11b)))return this[_0x273b1f(0x12b)](_0xfb92e6,_0x4efc34);else{if(_0x357964===_0x151a46[_0x273b1f(0x125)])return this[_0x273b1f(0x12a)](_0xfb92e6,_0x4efc34);}}return _0xfb92e6;}catch(_0x2b88d2){return console['error']('Error\x20formatting\x20datetime:\x20'+_0x2b88d2['message']),_0xfb92e6;}}static['formatDate'](_0x4778a1,_0x59602e){const _0x1433d3=a0_0xc9b27,_0x5b367b={'Owzjr':function(_0x4fd5ef,_0x22affe){return _0x4fd5ef(_0x22affe);},'DHnpv':function(_0x5cb266,_0x11a2d0){return _0x5cb266+_0x11a2d0;}},_0x1e086a=new Date(_0x4778a1);if(_0x5b367b['Owzjr'](isNaN,_0x1e086a['getTime']()))return console[_0x1433d3(0x130)]('Invalid\x20date\x20value:\x20'+_0x4778a1),_0x4778a1;const _0x16dc81=String(_0x1e086a['getDate']())[_0x1433d3(0x120)](0x2,'0'),_0x507793=String(_0x5b367b[_0x1433d3(0x119)](_0x1e086a[_0x1433d3(0x116)](),0x1))[_0x1433d3(0x120)](0x2,'0'),_0x15ffcd=_0x1e086a['getFullYear'](),_0x39c636={'dd/MM/yyyy':_0x16dc81+'/'+_0x507793+'/'+_0x15ffcd,'dd-MM-yyyy':_0x16dc81+'-'+_0x507793+'-'+_0x15ffcd,'MM/dd/yyyy':_0x507793+'/'+_0x16dc81+'/'+_0x15ffcd,'yyyy/MM/dd':_0x15ffcd+'/'+_0x507793+'/'+_0x16dc81,'yyyy-MM-dd':_0x15ffcd+'-'+_0x507793+'-'+_0x16dc81};return _0x39c636[_0x59602e]||_0x15ffcd+'-'+_0x507793+'-'+_0x16dc81;}static['formatTimestamp'](_0x512bb1,_0x22ed48){const _0x326083=a0_0xc9b27,_0x1b44cc={'ulCpq':function(_0x4ef338,_0x589a19){return _0x4ef338(_0x589a19);},'ucOMp':function(_0xc268b0,_0x48436e){return _0xc268b0(_0x48436e);},'bXegG':function(_0x3d3573,_0x4861f3){return _0x3d3573(_0x4861f3);}},_0x84e63a=new Date(_0x512bb1);if(isNaN(_0x84e63a[_0x326083(0x123)]()))return console[_0x326083(0x130)](_0x326083(0x126)+_0x512bb1),_0x512bb1;const _0x2009d8=_0x1b44cc['ulCpq'](String,_0x84e63a[_0x326083(0x11f)]())['padStart'](0x2,'0'),_0x36d0da=String(_0x84e63a[_0x326083(0x116)]()+0x1)[_0x326083(0x120)](0x2,'0'),_0x319ac7=_0x84e63a['getFullYear'](),_0x292302=_0x1b44cc['ulCpq'](String,_0x84e63a['getHours']())['padStart'](0x2,'0'),_0x1e536b=_0x1b44cc[_0x326083(0x127)](String,_0x84e63a[_0x326083(0x128)]())[_0x326083(0x120)](0x2,'0'),_0x11eac9=_0x1b44cc['bXegG'](String,_0x84e63a['getSeconds']())[_0x326083(0x120)](0x2,'0'),_0x486799=_0x22ed48['split']('\x20');if(_0x486799[_0x326083(0x12c)]!==0x2)return _0x319ac7+'-'+_0x36d0da+'-'+_0x2009d8+'\x20'+_0x292302+':'+_0x1e536b+':'+_0x11eac9;const _0x3e647d=_0x486799[0x0],_0x6f3f5a=_0x486799[0x1],_0x5a51b7={'dd/MM/yyyy':_0x2009d8+'/'+_0x36d0da+'/'+_0x319ac7,'dd-MM-yyyy':_0x2009d8+'-'+_0x36d0da+'-'+_0x319ac7,'MM/dd/yyyy':_0x36d0da+'/'+_0x2009d8+'/'+_0x319ac7,'yyyy/MM/dd':_0x319ac7+'/'+_0x36d0da+'/'+_0x2009d8,'yyyy-MM-dd':_0x319ac7+'-'+_0x36d0da+'-'+_0x2009d8},_0x12f28c={'HH:mm':_0x292302+':'+_0x1e536b,'HH:mm:ss':_0x292302+':'+_0x1e536b+':'+_0x11eac9,'hh:mm':_0x292302+':'+_0x1e536b},_0x4afaf9=_0x5a51b7[_0x3e647d]||_0x319ac7+'-'+_0x36d0da+'-'+_0x2009d8,_0x2670d1=_0x12f28c[_0x6f3f5a]||_0x292302+':'+_0x1e536b+':'+_0x11eac9;return _0x4afaf9+'\x20'+_0x2670d1;}static[a0_0xc9b27(0x12a)](_0x2b379f,_0x742721){const _0x1f03d2=a0_0xc9b27,_0x38bd26={'qtdFY':function(_0x37b631,_0x4b8aa5){return _0x37b631!==_0x4b8aa5;}};if(_0x38bd26[_0x1f03d2(0x12e)](typeof _0x2b379f,_0x1f03d2(0x11e)))return _0x2b379f;const _0x40ae30=_0x2b379f[_0x1f03d2(0x12f)](':');if(_0x40ae30[_0x1f03d2(0x12c)]<0x2)return console[_0x1f03d2(0x130)]('Invalid\x20time\x20value:\x20'+_0x2b379f),_0x2b379f;const _0x3ee885=_0x40ae30[0x0]['padStart'](0x2,'0'),_0x93954e=_0x40ae30[0x1]['padStart'](0x2,'0'),_0x49532d=_0x40ae30[0x2]?_0x40ae30[0x2][_0x1f03d2(0x12f)]('.')[0x0]['padStart'](0x2,'0'):'00',_0x2084ec={'HH:mm':_0x3ee885+':'+_0x93954e,'HH:mm:ss':_0x3ee885+':'+_0x93954e+':'+_0x49532d,'hh:mm':_0x3ee885+':'+_0x93954e};return _0x2084ec[_0x742721]||_0x3ee885+':'+_0x93954e+':'+_0x49532d;}}module['exports']=DateTimeFormatter;
1
+ const a0_0x3e9074=a0_0x2cfa;function a0_0x2cfa(_0x59a87e,_0x41c715){_0x59a87e=_0x59a87e-0xf1;const _0xd5aa13=a0_0xd5aa();let _0x2cfa13=_0xd5aa13[_0x59a87e];if(a0_0x2cfa['xMcbbg']===undefined){var _0xd2b562=function(_0x397610){const _0x3b0a1c='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x2e03b9='',_0x457b0d='';for(let _0x597f55=0x0,_0x371b17,_0xff4a40,_0x45c2fb=0x0;_0xff4a40=_0x397610['charAt'](_0x45c2fb++);~_0xff4a40&&(_0x371b17=_0x597f55%0x4?_0x371b17*0x40+_0xff4a40:_0xff4a40,_0x597f55++%0x4)?_0x2e03b9+=String['fromCharCode'](0xff&_0x371b17>>(-0x2*_0x597f55&0x6)):0x0){_0xff4a40=_0x3b0a1c['indexOf'](_0xff4a40);}for(let _0x3024ca=0x0,_0x58ce06=_0x2e03b9['length'];_0x3024ca<_0x58ce06;_0x3024ca++){_0x457b0d+='%'+('00'+_0x2e03b9['charCodeAt'](_0x3024ca)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x457b0d);};a0_0x2cfa['eJzIwG']=_0xd2b562,a0_0x2cfa['wgEppZ']={},a0_0x2cfa['xMcbbg']=!![];}const _0x4cdf35=_0xd5aa13[0x0],_0x4a24f9=_0x59a87e+_0x4cdf35,_0x39de04=a0_0x2cfa['wgEppZ'][_0x4a24f9];return!_0x39de04?(_0x2cfa13=a0_0x2cfa['eJzIwG'](_0x2cfa13),a0_0x2cfa['wgEppZ'][_0x4a24f9]=_0x2cfa13):_0x2cfa13=_0x39de04,_0x2cfa13;}(function(_0x531acc,_0x599ef9){const _0x4bd4c0=a0_0x2cfa,_0x32520e=_0x531acc();while(!![]){try{const _0x4098e6=-parseInt(_0x4bd4c0(0xfe))/0x1+-parseInt(_0x4bd4c0(0x100))/0x2+parseInt(_0x4bd4c0(0x105))/0x3+-parseInt(_0x4bd4c0(0xf9))/0x4+parseInt(_0x4bd4c0(0xf6))/0x5+parseInt(_0x4bd4c0(0xf8))/0x6+parseInt(_0x4bd4c0(0xfd))/0x7*(parseInt(_0x4bd4c0(0xf2))/0x8);if(_0x4098e6===_0x599ef9)break;else _0x32520e['push'](_0x32520e['shift']());}catch(_0x2858cb){_0x32520e['push'](_0x32520e['shift']());}}}(a0_0xd5aa,0x32d96));class DateTimeFormatter{static[a0_0x3e9074(0x109)](_0x2bbdbb,_0xf6477f,_0x38b461){const _0x339dad=a0_0x3e9074,_0x5bdd60={'JExwl':function(_0x516ced,_0x36f7b1){return _0x516ced===_0x36f7b1;},'oUgIl':function(_0x4cd6ed,_0x4836a2){return _0x4cd6ed===_0x4836a2;},'aNShk':'time'};if(!_0x2bbdbb)return null;try{if(_0x5bdd60[_0x339dad(0xfc)](_0x38b461,'date'))return this['formatDate'](_0x2bbdbb,_0xf6477f);else{if(_0x5bdd60['oUgIl'](_0x38b461,_0x339dad(0x10a)))return this[_0x339dad(0x10e)](_0x2bbdbb,_0xf6477f);else{if(_0x38b461===_0x5bdd60['aNShk'])return this['formatTime'](_0x2bbdbb,_0xf6477f);}}return _0x2bbdbb;}catch(_0x39f04f){return console['error'](_0x339dad(0x107)+_0x39f04f['message']),_0x2bbdbb;}}static['formatDate'](_0x1e350d,_0x11cbf1){const _0x510ac3=a0_0x3e9074,_0x279e4e={'WPMTP':function(_0xf475d7,_0x24b554){return _0xf475d7(_0x24b554);}},_0x1d5edc=new Date(_0x1e350d);if(_0x279e4e['WPMTP'](isNaN,_0x1d5edc[_0x510ac3(0x10c)]()))return console[_0x510ac3(0x10b)]('Invalid\x20date\x20value:\x20'+_0x1e350d),_0x1e350d;const _0x1d5a5b=String(_0x1d5edc['getDate']())[_0x510ac3(0x10d)](0x2,'0'),_0x5343c1=String(_0x1d5edc[_0x510ac3(0xff)]()+0x1)['padStart'](0x2,'0'),_0x2b2ca2=_0x1d5edc[_0x510ac3(0xfb)](),_0x1a0287={'dd/MM/yyyy':_0x1d5a5b+'/'+_0x5343c1+'/'+_0x2b2ca2,'dd-MM-yyyy':_0x1d5a5b+'-'+_0x5343c1+'-'+_0x2b2ca2,'MM/dd/yyyy':_0x5343c1+'/'+_0x1d5a5b+'/'+_0x2b2ca2,'yyyy/MM/dd':_0x2b2ca2+'/'+_0x5343c1+'/'+_0x1d5a5b,'yyyy-MM-dd':_0x2b2ca2+'-'+_0x5343c1+'-'+_0x1d5a5b};return _0x1a0287[_0x11cbf1]||_0x2b2ca2+'-'+_0x5343c1+'-'+_0x1d5a5b;}static[a0_0x3e9074(0x10e)](_0x2c554f,_0x595d79){const _0x13d307=a0_0x3e9074,_0x1e9a71={'QmTSM':function(_0x462659,_0x36e490){return _0x462659(_0x36e490);},'iOBJf':function(_0x1662a9,_0x739725){return _0x1662a9(_0x739725);},'aqTEg':function(_0x2d78eb,_0x2c5894){return _0x2d78eb(_0x2c5894);},'OKdda':function(_0x4c7739,_0x4e93d3){return _0x4c7739+_0x4e93d3;},'Zuchn':function(_0x281130,_0x25f931){return _0x281130(_0x25f931);},'dVwQi':function(_0x54058d,_0x501503){return _0x54058d(_0x501503);}},_0x439e07=new Date(_0x2c554f);if(_0x1e9a71[_0x13d307(0xf3)](isNaN,_0x439e07[_0x13d307(0x10c)]()))return console[_0x13d307(0x10b)](_0x13d307(0xf1)+_0x2c554f),_0x2c554f;const _0x547b6e=_0x1e9a71['iOBJf'](String,_0x439e07[_0x13d307(0xf7)]())[_0x13d307(0x10d)](0x2,'0'),_0x131ae6=_0x1e9a71[_0x13d307(0xf5)](String,_0x1e9a71['OKdda'](_0x439e07['getMonth'](),0x1))['padStart'](0x2,'0'),_0x254f58=_0x439e07[_0x13d307(0xfb)](),_0x5b760c=String(_0x439e07[_0x13d307(0x106)]())[_0x13d307(0x10d)](0x2,'0'),_0xd8caf5=_0x1e9a71[_0x13d307(0x108)](String,_0x439e07['getMinutes']())[_0x13d307(0x10d)](0x2,'0'),_0x1dfe84=_0x1e9a71[_0x13d307(0x104)](String,_0x439e07['getSeconds']())['padStart'](0x2,'0'),_0x3e9dd4=_0x595d79[_0x13d307(0xfa)]('\x20');if(_0x3e9dd4['length']!==0x2)return _0x254f58+'-'+_0x131ae6+'-'+_0x547b6e+'\x20'+_0x5b760c+':'+_0xd8caf5+':'+_0x1dfe84;const _0x1981f2=_0x3e9dd4[0x0],_0x10fb45=_0x3e9dd4[0x1],_0x2fc2fc={'dd/MM/yyyy':_0x547b6e+'/'+_0x131ae6+'/'+_0x254f58,'dd-MM-yyyy':_0x547b6e+'-'+_0x131ae6+'-'+_0x254f58,'MM/dd/yyyy':_0x131ae6+'/'+_0x547b6e+'/'+_0x254f58,'yyyy/MM/dd':_0x254f58+'/'+_0x131ae6+'/'+_0x547b6e,'yyyy-MM-dd':_0x254f58+'-'+_0x131ae6+'-'+_0x547b6e},_0x1f0c8c={'HH:mm':_0x5b760c+':'+_0xd8caf5,'HH:mm:ss':_0x5b760c+':'+_0xd8caf5+':'+_0x1dfe84,'hh:mm':_0x5b760c+':'+_0xd8caf5},_0x3a3cd6=_0x2fc2fc[_0x1981f2]||_0x254f58+'-'+_0x131ae6+'-'+_0x547b6e,_0x3a6a58=_0x1f0c8c[_0x10fb45]||_0x5b760c+':'+_0xd8caf5+':'+_0x1dfe84;return _0x3a3cd6+'\x20'+_0x3a6a58;}static[a0_0x3e9074(0x101)](_0x34dce2,_0x3a2a51){const _0x340c93=a0_0x3e9074,_0x2ec469={'TUqPc':_0x340c93(0x102)};if(typeof _0x34dce2!==_0x2ec469[_0x340c93(0x103)])return _0x34dce2;const _0x227f99=_0x34dce2[_0x340c93(0xfa)](':');if(_0x227f99['length']<0x2)return console[_0x340c93(0x10b)](_0x340c93(0x10f)+_0x34dce2),_0x34dce2;const _0x24bba5=_0x227f99[0x0][_0x340c93(0x10d)](0x2,'0'),_0x45f18d=_0x227f99[0x1][_0x340c93(0x10d)](0x2,'0'),_0xc97a86=_0x227f99[0x2]?_0x227f99[0x2]['split']('.')[0x0]['padStart'](0x2,'0'):'00',_0x5a8196={'HH:mm':_0x24bba5+':'+_0x45f18d,'HH:mm:ss':_0x24bba5+':'+_0x45f18d+':'+_0xc97a86,'hh:mm':_0x24bba5+':'+_0x45f18d};return _0x5a8196[_0x3a2a51]||_0x24bba5+':'+_0x45f18d+':'+_0xc97a86;}}module[a0_0x3e9074(0xf4)]=DateTimeFormatter;function a0_0xd5aa(){const _0x5d0c55=['sw52ywXPzcb0Aw1LC3rHBxaGDMfSDwu6ia','ogrtBLjrtq','uw1uu00','zxHWB3j0CW','yxfurwC','ndKZmZKWs0PbAKPs','z2v0rgf0zq','mJiXmJGWnNPlCe5hqG','mtuXmdeYq1nAwwTn','C3bSAxq','z2v0rNvSBfLLyxi','sKv4D2W','mtCZotq2nvPfBLDgBW','mZiZmJyXywvrr2rg','z2v0tw9UDgG','ndu4mZy0zLfMuvHZ','zM9YBwf0vgLTzq','C3rYAw5N','vfvXugm','zfz3uwK','mJq3ntaWEgnWEMzw','z2v0sg91CNm','rxjYB3iGzM9YBwf0DgLUzYbKyxrLDgLTztOG','wNvJAg4','zM9YBwf0','DgLTzxn0yw1W','D2fYBG','z2v0vgLTzq','CgfKu3rHCNq','zM9YBwf0vgLTzxn0yw1W','sw52ywXPzcb0Aw1LihzHBhvLoIa'];a0_0xd5aa=function(){return _0x5d0c55;};return a0_0xd5aa();}
@@ -1 +1 @@
1
- const a0_0x44a094=a0_0x1094;(function(_0x15831c,_0x560cce){const _0x263ab2=a0_0x1094,_0x2a258b=_0x15831c();while(!![]){try{const _0xd9b883=parseInt(_0x263ab2(0x15f))/0x1*(-parseInt(_0x263ab2(0x157))/0x2)+parseInt(_0x263ab2(0x146))/0x3*(-parseInt(_0x263ab2(0x155))/0x4)+parseInt(_0x263ab2(0x15c))/0x5+parseInt(_0x263ab2(0x162))/0x6+-parseInt(_0x263ab2(0x158))/0x7+parseInt(_0x263ab2(0x144))/0x8+-parseInt(_0x263ab2(0x15d))/0x9*(-parseInt(_0x263ab2(0x15b))/0xa);if(_0xd9b883===_0x560cce)break;else _0x2a258b['push'](_0x2a258b['shift']());}catch(_0x3a7ea1){_0x2a258b['push'](_0x2a258b['shift']());}}}(a0_0x48e7,0x8d04b));class DateTimeParser{static[a0_0x44a094(0x148)](_0x3b6e08,_0x6eebc7,_0x2f45c9){const _0x1aabdd=a0_0x44a094,_0x57ee0f={'ydLUD':function(_0x3da7d1,_0x3a6ad1){return _0x3da7d1===_0x3a6ad1;},'CrBpf':function(_0x122d09,_0x1449aa){return _0x122d09===_0x1449aa;},'TtYcJ':_0x1aabdd(0x14d),'nEONO':'timestamp'};if(!_0x3b6e08||_0x57ee0f['ydLUD'](_0x3b6e08,''))return null;try{if(_0x57ee0f['CrBpf'](_0x2f45c9,_0x57ee0f[_0x1aabdd(0x161)]))return this[_0x1aabdd(0x160)](_0x3b6e08,_0x6eebc7);else{if(_0x57ee0f[_0x1aabdd(0x152)](_0x2f45c9,_0x57ee0f[_0x1aabdd(0x164)]))return this['parseTimestamp'](_0x3b6e08,_0x6eebc7);else{if(_0x2f45c9===_0x1aabdd(0x15a))return this[_0x1aabdd(0x141)](_0x3b6e08,_0x6eebc7);}}return _0x3b6e08;}catch(_0x97a9a7){return console[_0x1aabdd(0x14b)](_0x1aabdd(0x159)+_0x97a9a7[_0x1aabdd(0x14a)]),null;}}static[a0_0x44a094(0x160)](_0x2cc24d,_0x4d4a74){const _0x3c0b1e=a0_0x44a094,_0x72b415={'NfHCO':function(_0x2fd5a2,_0x21c1b0){return _0x2fd5a2+_0x21c1b0;},'azQlT':function(_0x476cfc,_0x2aa2ef){return _0x476cfc===_0x2aa2ef;},'gTZCv':'day','RpcXl':_0x3c0b1e(0x150)};if(!_0x4d4a74||_0x72b415[_0x3c0b1e(0x153)](_0x4d4a74,'yyyy-MM-dd'))return _0x2cc24d;const _0x3b8d34={'dd/MM/yyyy':{'pattern':/^(\d{2})\/(\d{2})\/(\d{4})$/,'order':[_0x72b415['gTZCv'],_0x72b415[_0x3c0b1e(0x149)],_0x3c0b1e(0x147)]},'dd-MM-yyyy':{'pattern':/^(\d{2})-(\d{2})-(\d{4})$/,'order':[_0x72b415['gTZCv'],'month','year']},'MM/dd/yyyy':{'pattern':/^(\d{2})\/(\d{2})\/(\d{4})$/,'order':['month','day','year']},'yyyy/MM/dd':{'pattern':/^(\d{4})\/(\d{2})\/(\d{2})$/,'order':[_0x3c0b1e(0x147),_0x72b415[_0x3c0b1e(0x149)],_0x72b415['gTZCv']]}},_0x29b81d=_0x3b8d34[_0x4d4a74];if(!_0x29b81d)return console['warn']('Unknown\x20date\x20format:\x20'+_0x4d4a74+',\x20returning\x20null'),null;const _0x2db848=_0x2cc24d['match'](_0x29b81d['pattern']);if(!_0x2db848)return console[_0x3c0b1e(0x14f)](_0x3c0b1e(0x165)+_0x2cc24d+_0x3c0b1e(0x14e)+_0x4d4a74+'\x22'),null;const _0x4dcb37={'day':null,'month':null,'year':null};return _0x29b81d['order'][_0x3c0b1e(0x15e)]((_0x271fa8,_0x3f965d)=>{_0x4dcb37[_0x271fa8]=_0x2db848[_0x72b415['NfHCO'](_0x3f965d,0x1)];}),_0x4dcb37['year']+'-'+_0x4dcb37[_0x3c0b1e(0x150)]+'-'+_0x4dcb37[_0x3c0b1e(0x154)];}static['parseTimestamp'](_0x1eed47,_0x406786){const _0x20e4b0=a0_0x44a094,_0x3c280f={'HboJM':function(_0x78f8ad,_0x53362b){return _0x78f8ad===_0x53362b;},'ePPTS':_0x20e4b0(0x145)};if(!_0x406786||_0x3c280f[_0x20e4b0(0x14c)](_0x406786,_0x3c280f['ePPTS']))return _0x1eed47;const _0x546dbd=_0x1eed47[_0x20e4b0(0x156)]('\x20');if(_0x546dbd[_0x20e4b0(0x163)]!==0x2)return console['warn']('Invalid\x20timestamp\x20format:\x20'+_0x1eed47),null;const [_0x2900b0,_0x122ab2]=_0x546dbd,_0x20e333=_0x406786['split']('\x20')[0x0],_0x2aab49=this[_0x20e4b0(0x160)](_0x2900b0,_0x20e333);if(!_0x2aab49)return null;const _0x2d17ff=_0x122ab2['split'](':')['length']===0x2?_0x122ab2+':00':_0x122ab2;return _0x2aab49+'\x20'+_0x2d17ff;}static['parseTime'](_0xf25c01,_0x1cc151){const _0x1d1984=a0_0x44a094,_0x5f2cd0={'hnaKA':function(_0xbcfe12,_0x460dee){return _0xbcfe12===_0x460dee;},'LSpNK':'HH:mm'};if(!_0x1cc151||_0x1cc151==='HH:mm:ss')return _0xf25c01;if(_0x5f2cd0[_0x1d1984(0x151)](_0x1cc151,_0x5f2cd0[_0x1d1984(0x143)])){if(_0xf25c01['match'](/^\d{2}:\d{2}$/))return _0xf25c01+_0x1d1984(0x142);}return _0xf25c01;}}module[a0_0x44a094(0x140)]=DateTimeParser;function a0_0x1094(_0x58d0e4,_0x5312fa){_0x58d0e4=_0x58d0e4-0x140;const _0x48e782=a0_0x48e7();let _0x1094be=_0x48e782[_0x58d0e4];if(a0_0x1094['WKQiZq']===undefined){var _0xadc10b=function(_0x4d84f4){const _0x451726='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x55f54f='',_0x3b81f0='';for(let _0x2f906b=0x0,_0x19f690,_0x58204f,_0x32a014=0x0;_0x58204f=_0x4d84f4['charAt'](_0x32a014++);~_0x58204f&&(_0x19f690=_0x2f906b%0x4?_0x19f690*0x40+_0x58204f:_0x58204f,_0x2f906b++%0x4)?_0x55f54f+=String['fromCharCode'](0xff&_0x19f690>>(-0x2*_0x2f906b&0x6)):0x0){_0x58204f=_0x451726['indexOf'](_0x58204f);}for(let _0x526982=0x0,_0x299076=_0x55f54f['length'];_0x526982<_0x299076;_0x526982++){_0x3b81f0+='%'+('00'+_0x55f54f['charCodeAt'](_0x526982)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x3b81f0);};a0_0x1094['XhrXkM']=_0xadc10b,a0_0x1094['GsgxAf']={},a0_0x1094['WKQiZq']=!![];}const _0x304441=_0x48e782[0x0],_0x595a33=_0x58d0e4+_0x304441,_0x3b16b3=a0_0x1094['GsgxAf'][_0x595a33];return!_0x3b16b3?(_0x1094be=a0_0x1094['XhrXkM'](_0x1094be),a0_0x1094['GsgxAf'][_0x595a33]=_0x1094be):_0x1094be=_0x3b16b3,_0x1094be;}function a0_0x48e7(){const _0x32ee87=['Ag5Hs0e','Ewrmvuq','yxPrBfq','zgf5','ntCZmMXtuwX0Ea','C3bSAxq','odG5mJjNwMflshK','nZKZnZaYmeXiDxfqvq','rxjYB3iGCgfYC2LUzYbKyxrLDgLTztOG','DgLTzq','otiWotG3mhbPqvjoEq','ntyWndC0mhPTq2PJqW','ou9ss1zoCW','zM9YrwfJAa','mJjoA2fkzeq','CgfYC2veyxrL','vhrzy0O','nde0nde4ofv5qLblAW','BgvUz3rO','BKvptK8','rgf0zsb2ywX1zsaI','zxHWB3j0CW','CgfYC2vuAw1L','oJaW','tfnWtKS','odaWmdHVtxzQz1O','ExL5Es1nts1KzcbisdPTBtPZCW','mteXsfjKANPo','EwvHCG','CgfYC2u','uNbJwgW','BwvZC2fNzq','zxjYB3i','sgjVsK0','zgf0zq','iIbKB2vZBID0ig1HDgnOigzVCM1HDcaI','D2fYBG','Bw9UDgG'];a0_0x48e7=function(){return _0x32ee87;};return a0_0x48e7();}
1
+ const a0_0x5c9285=a0_0x3d41;function a0_0x3b5d(){const _0x17ee1f=['tevIBe8','zgf5','ExL5Es1nts1KzcbisdPTBtPZCW','DgLTzxn0yw1W','BwvZC2fNzq','D2fYBG','CgfYC2u','ntq5mhP4uu1Hza','seG6Bw06C3m','mtG0mvDduhHoqW','mtu3nJG0ntzTq2zjywe','CgfYC2veyxrL','CgfYC2vuAw1LC3rHBxa','iIbKB2vZBID0ig1HDgnOigzVCM1HDcaI','EwvHCG','C3bSAxq','A2jkwu0','vw5RBM93BIbKyxrLigzVCM1HDdOG','ndqZmteWmfPnt1HSuq','weL0Eha','mtK1nZCXmLz2A2juDq','CgfYC2vuAw1L','mtK4mtmYnLzhBurzqW','Bw9UDgG','DgLTzq','mJqWotq5uenrzxDt','Bwf0y2G','BgvUz3rO','zM9YrwfJAa','y1vxCuW','mtqWntiWmLnvs0LtqG'];a0_0x3b5d=function(){return _0x17ee1f;};return a0_0x3b5d();}(function(_0x1008a3,_0x1b5734){const _0x3c93ac=a0_0x3d41,_0x30c135=_0x1008a3();while(!![]){try{const _0x4ce430=-parseInt(_0x3c93ac(0x8f))/0x1+-parseInt(_0x3c93ac(0x94))/0x2+-parseInt(_0x3c93ac(0x8c))/0x3+-parseInt(_0x3c93ac(0x8a))/0x4+parseInt(_0x3c93ac(0x88))/0x5+parseInt(_0x3c93ac(0x7d))/0x6*(-parseInt(_0x3c93ac(0x7f))/0x7)+parseInt(_0x3c93ac(0x80))/0x8;if(_0x4ce430===_0x1b5734)break;else _0x30c135['push'](_0x30c135['shift']());}catch(_0x2a284c){_0x30c135['push'](_0x30c135['shift']());}}}(a0_0x3b5d,0x7fbcc));function a0_0x3d41(_0x4e3dd2,_0x2eb712){_0x4e3dd2=_0x4e3dd2-0x79;const _0x3b5dc0=a0_0x3b5d();let _0x3d414f=_0x3b5dc0[_0x4e3dd2];if(a0_0x3d41['SbKJxn']===undefined){var _0x593b4a=function(_0x2f3be3){const _0x31fe8b='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0xcb4fa5='',_0x584c14='';for(let _0x1dc642=0x0,_0x5a1bcd,_0x84388a,_0x2203c2=0x0;_0x84388a=_0x2f3be3['charAt'](_0x2203c2++);~_0x84388a&&(_0x5a1bcd=_0x1dc642%0x4?_0x5a1bcd*0x40+_0x84388a:_0x84388a,_0x1dc642++%0x4)?_0xcb4fa5+=String['fromCharCode'](0xff&_0x5a1bcd>>(-0x2*_0x1dc642&0x6)):0x0){_0x84388a=_0x31fe8b['indexOf'](_0x84388a);}for(let _0xaca8d1=0x0,_0x42ccd2=_0xcb4fa5['length'];_0xaca8d1<_0x42ccd2;_0xaca8d1++){_0x584c14+='%'+('00'+_0xcb4fa5['charCodeAt'](_0xaca8d1)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x584c14);};a0_0x3d41['kCvzhM']=_0x593b4a,a0_0x3d41['KqztdW']={},a0_0x3d41['SbKJxn']=!![];}const _0x3804c7=_0x3b5dc0[0x0],_0x355c6c=_0x4e3dd2+_0x3804c7,_0x2379b9=a0_0x3d41['KqztdW'][_0x355c6c];return!_0x2379b9?(_0x3d414f=a0_0x3d41['kCvzhM'](_0x3d414f),a0_0x3d41['KqztdW'][_0x355c6c]=_0x3d414f):_0x3d414f=_0x2379b9,_0x3d414f;}class DateTimeParser{static[a0_0x5c9285(0x7c)](_0x3ab0f9,_0x43cb22,_0x1b53fa){const _0x2e60c9=a0_0x5c9285,_0x78b40d={'Bagoq':function(_0x32df0a,_0x20a386){return _0x32df0a===_0x20a386;},'kKXCE':'date'};if(!_0x3ab0f9||_0x78b40d['Bagoq'](_0x3ab0f9,''))return null;try{if(_0x1b53fa===_0x78b40d['kKXCE'])return this[_0x2e60c9(0x81)](_0x3ab0f9,_0x43cb22);else{if(_0x78b40d['Bagoq'](_0x1b53fa,_0x2e60c9(0x79)))return this['parseTimestamp'](_0x3ab0f9,_0x43cb22);else{if(_0x1b53fa===_0x2e60c9(0x8e))return this[_0x2e60c9(0x8b)](_0x3ab0f9,_0x43cb22);}}return _0x3ab0f9;}catch(_0x413f60){return console['error']('Error\x20parsing\x20datetime:\x20'+_0x413f60[_0x2e60c9(0x7a)]),null;}}static['parseDate'](_0x2ba6b4,_0x4a4249){const _0x4242aa=a0_0x5c9285,_0x3065af={'PaIOY':'yyyy-MM-dd','kbJYM':_0x4242aa(0x96),'bECOS':_0x4242aa(0x8d),'XItxp':_0x4242aa(0x84)};if(!_0x4a4249||_0x4a4249===_0x3065af['PaIOY'])return _0x2ba6b4;const _0x289906={'dd/MM/yyyy':{'pattern':/^(\d{2})\/(\d{2})\/(\d{4})$/,'order':[_0x3065af[_0x4242aa(0x86)],_0x3065af['bECOS'],_0x3065af[_0x4242aa(0x89)]]},'dd-MM-yyyy':{'pattern':/^(\d{2})-(\d{2})-(\d{4})$/,'order':[_0x3065af[_0x4242aa(0x86)],_0x3065af['bECOS'],_0x3065af['XItxp']]},'MM/dd/yyyy':{'pattern':/^(\d{2})\/(\d{2})\/(\d{4})$/,'order':[_0x4242aa(0x8d),_0x3065af[_0x4242aa(0x86)],_0x3065af['XItxp']]},'yyyy/MM/dd':{'pattern':/^(\d{4})\/(\d{2})\/(\d{2})$/,'order':[_0x3065af['XItxp'],'month',_0x3065af[_0x4242aa(0x86)]]}},_0x274fe6=_0x289906[_0x4a4249];if(!_0x274fe6)return console['warn'](_0x4242aa(0x87)+_0x4a4249+',\x20returning\x20null'),null;const _0x356375=_0x2ba6b4['match'](_0x274fe6['pattern']);if(!_0x356375)return console[_0x4242aa(0x7b)]('Date\x20value\x20\x22'+_0x2ba6b4+_0x4242aa(0x83)+_0x4a4249+'\x22'),null;const _0x15b75e={'day':null,'month':null,'year':null};return _0x274fe6['order'][_0x4242aa(0x92)]((_0x15c2dd,_0x58ce44)=>{_0x15b75e[_0x15c2dd]=_0x356375[_0x58ce44+0x1];}),_0x15b75e[_0x4242aa(0x84)]+'-'+_0x15b75e['month']+'-'+_0x15b75e[_0x4242aa(0x96)];}static[a0_0x5c9285(0x82)](_0x19def2,_0x23f8e7){const _0x365dc5=a0_0x5c9285,_0x219927={'qkifn':_0x365dc5(0x97),'LEblO':function(_0x98837c,_0x3e09c2){return _0x98837c!==_0x3e09c2;}};if(!_0x23f8e7||_0x23f8e7===_0x219927['qkifn'])return _0x19def2;const _0x7dc9aa=_0x19def2[_0x365dc5(0x85)]('\x20');if(_0x219927[_0x365dc5(0x95)](_0x7dc9aa[_0x365dc5(0x91)],0x2))return console[_0x365dc5(0x7b)]('Invalid\x20timestamp\x20format:\x20'+_0x19def2),null;const [_0x468338,_0x587896]=_0x7dc9aa,_0x595d3b=_0x23f8e7[_0x365dc5(0x85)]('\x20')[0x0],_0x285c86=this[_0x365dc5(0x81)](_0x468338,_0x595d3b);if(!_0x285c86)return null;const _0x70a043=_0x587896['split'](':')[_0x365dc5(0x91)]===0x2?_0x587896+':00':_0x587896;return _0x285c86+'\x20'+_0x70a043;}static['parseTime'](_0x4b335e,_0x353292){const _0x3b5739=a0_0x5c9285,_0x2d9de1={'TWamp':function(_0xb1425d,_0xcf50d6){return _0xb1425d===_0xcf50d6;},'cUWqL':_0x3b5739(0x7e),'rYHJK':'HH:mm'};if(!_0x353292||_0x2d9de1['TWamp'](_0x353292,_0x2d9de1[_0x3b5739(0x93)]))return _0x4b335e;if(_0x353292===_0x2d9de1['rYHJK']){if(_0x4b335e[_0x3b5739(0x90)](/^\d{2}:\d{2}$/))return _0x4b335e+':00';}return _0x4b335e;}}module['exports']=DateTimeParser;
@@ -1 +1 @@
1
- const a0_0x59b2a8=a0_0x3211;function a0_0x27da(){const _0x91b2eb=['zgjFy29UBMvJDgLVBL9JAgvJA19LCNjVCG','tgfKsxy','mtq5mZy5nJbNBKvUsgS','mtKYlJe2oc4XmdaUmq','zgvIDwC','ChvZAa','Cg9ZDgDYzxmXmJm0','CM9SBgjHy2TFzxjYB3i','rwXfDha','CMvSzwfZzq','zw5K','C2LeqMW','rxjYB3iGy2XVC2LUzYbKyxrHyMfZzsbWB29SoIa','zxHWB3j0CW','Aw1Xy3O','mZu3mZu0mhvTBNzPrW','C3fS','vefctevFtK9ux0zpvu5e','y29Kzq','vhjHBNnHy3rPB24Gy29TBwL0DgvKicG','zgjFCg9VBf9JBg9Zzv9LCNjVCG','rfvXugS','AenKz2K','BgvUz3rO','CM93q291BNq','Aw5MBW','CM9SBgjHy2S','mJKWuezothLy','Cg9ZDgDYzxm','ihf1zxjPzxmP','Cg9ZDgDYzxnXBa','u1Lovefyx0vsuK9s','BxmSia','vhjHBNnHy3rPB24GzMfPBgvKoIa','rejFueftu1DpuKq','q0vSEe8','nwLqCgrXtW','rxjYB3iGCM9SBgLUzYbIywnRihrYyw5Zywn0Aw9UoIa','B1rzwhO','rxjYB3iGy2HLy2TPBMCGzgf0ywjHC2uGy29UBMvJDgLVBJOG','rgf0ywjHC2uGzxjYB3i6ia','CgfYyw1Z','ntq2mtK5nKzXB0TKzG','rgf0ywjHC2uGCg9VBcbJBg9ZzwqGC3vJy2vZC2z1BgX5','AM9NBNq','ve9vthO','q3jLyxrPBMCGBMv3igrHDgfIyxnLihbVB2WGkhbYzxzPB3vZihbVB2WGD2fZignSB3nLzcK','u253D2G','mZGYnJu4nfDTzNDyva','uvzbvfy','ndjqmde','nZm4nZC3ovzXs2XLsW','CxvLCNK','rejFse9tva','nJm3oxzWsNb2qq','zgjFCg9VBf9HBhjLywr5x2nSB3nLza','r0rmrfO','uxvLCNKGCMv0DxjUzwqG','q3LqDwG','C3LUDgf4igvYCM9Y','rfLUBNm','EKjRsKe','rxjYB3iGCMvSzwfZAw5NihrYyw5Zywn0Aw9UignSAwvUDdOG','Dxnit0G','BwvZC2fNzq','zw52','mtCXndK3otD0s3Luuw4','rejFue9sva','CK1JEKm','y29UBMvJDa'];a0_0x27da=function(){return _0x91b2eb;};return a0_0x27da();}(function(_0x27700d,_0x52cb84){const _0x5dd46d=a0_0x3211,_0x5c9aad=_0x27700d();while(!![]){try{const _0x868c52=parseInt(_0x5dd46d(0x1a1))/0x1*(-parseInt(_0x5dd46d(0x1cc))/0x2)+-parseInt(_0x5dd46d(0x1c0))/0x3+-parseInt(_0x5dd46d(0x195))/0x4*(-parseInt(_0x5dd46d(0x1d5))/0x5)+parseInt(_0x5dd46d(0x19b))/0x6+parseInt(_0x5dd46d(0x19e))/0x7+-parseInt(_0x5dd46d(0x1b3))/0x8+parseInt(_0x5dd46d(0x1ad))/0x9;if(_0x868c52===_0x52cb84)break;else _0x5c9aad['push'](_0x5c9aad['shift']());}catch(_0x556849){_0x5c9aad['push'](_0x5c9aad['shift']());}}}(a0_0x27da,0xef7ca));const {Pool}=require('pg'),{logQuery,logTransaction,startQueryTimer,logDatabaseConfig,logger,logError}=require('./logger'),dbConfig={'host':process['env'][a0_0x59b2a8(0x1a0)]||a0_0x59b2a8(0x1b4),'port':parseInt(process['env'][a0_0x59b2a8(0x1ae)]||'5432'),'user':process[a0_0x59b2a8(0x1ac)]['DB_USER']||a0_0x59b2a8(0x1cd),'password':process['env'][a0_0x59b2a8(0x1d3)]||a0_0x59b2a8(0x1b7),'database':process['env']['DB_NAME']||'dbxa03'};logDatabaseConfig({'host':dbConfig['host'],'port':dbConfig['port'],'database':dbConfig['database'],'type':'postgresql','user':dbConfig['user']});let pool=new Pool(dbConfig),isPoolClosed=![];function getPool(){const _0x241887=a0_0x59b2a8,_0x395ac4={'LadIv':_0x241887(0x199)};return isPoolClosed&&(logger[_0x241887(0x1ca)]({'event':'db_pool_recreate'},_0x395ac4[_0x241887(0x1b2)]),pool=new Pool(dbConfig),isPoolClosed=![]),pool;}async function executeQuery(_0x1a54e2,_0x5e98e8=[]){const _0x3a7963=a0_0x59b2a8,_0x8830e={'DYnns':function(_0x4b5211){return _0x4b5211();},'imqcz':'postgresql','mAsqe':'sql_error'},_0x511fa0=startQueryTimer();try{const _0x3aba27=_0x8830e[_0x3a7963(0x1a7)](getPool),_0x51a36b=await _0x3aba27['connect']();try{const _0x3246c1=await _0x51a36b['query'](_0x1a54e2,_0x5e98e8),_0xe88777=_0x511fa0();return logQuery(_0x1a54e2,_0x5e98e8,{'duration':_0xe88777,'rowsAffected':_0x3246c1[_0x3a7963(0x1c9)],'dbType':_0x8830e[_0x3a7963(0x1bf)]}),_0x3246c1['rows'];}finally{_0x51a36b['release']();}}catch(_0xce0859){const _0xe62771=_0x511fa0();logError(_0xce0859,{'event':_0x8830e['mAsqe'],'query':_0x1a54e2['substring'](0x0,0x1f4),'paramCount':_0x5e98e8['length'],'durationMs':_0xe62771,'code':_0xce0859['code'],'dbType':_0x3a7963(0x1cf)},'SQL\x20Error:\x20'+_0xce0859[_0x3a7963(0x1ab)]);throw _0xce0859;}}function formatResponse(_0x294994,_0x5aa19a=null){const _0x1244ea=a0_0x59b2a8,_0x8fefe6={'usHOH':_0x1244ea(0x1a6),'Snwwh':function(_0x58434b,_0x53d7ff){return _0x58434b===_0x53d7ff;},'ZZkbG':'AUTHENTICATION_ERROR','zBkJA':function(_0x32bb0c,_0x1968be){return _0x32bb0c===_0x1968be;},'AUzWf':'08006','MEZNf':'CONNECTION_ERROR','CyPuh':function(_0x24bf05,_0x151832){return _0x24bf05===_0x151832;},'CElxO':'No\x20data\x20found.','ElEtp':function(_0x4da60d,_0x4d4865){return _0x4da60d===_0x4d4865;}};if(_0x5aa19a){let _0xb85273='UNKNOWN_ERROR';if(_0x5aa19a['message']['includes'](_0x8fefe6[_0x1244ea(0x1aa)]))_0xb85273=_0x1244ea(0x1d0);else{if(_0x8fefe6['Snwwh'](_0x5aa19a['code'],_0x1244ea(0x19d)))_0xb85273=_0x1244ea(0x1c2);else{if(_0x8fefe6[_0x1244ea(0x19a)](_0x5aa19a[_0x1244ea(0x1c3)],'28P01'))_0xb85273=_0x8fefe6['ZZkbG'];else(_0x8fefe6[_0x1244ea(0x1a8)](_0x5aa19a[_0x1244ea(0x1c3)],_0x8fefe6['AUzWf'])||_0x8fefe6[_0x1244ea(0x19a)](_0x5aa19a['code'],'08001'))&&(_0xb85273=_0x8fefe6['MEZNf']);}}return{'success':![],'message':_0x1244ea(0x1d9)+_0x5aa19a['message'],'count':-0x1,'error_code':_0xb85273};}else{if(!_0x294994||_0x8fefe6[_0x1244ea(0x1a5)](_0x294994['length'],0x0))return{'success':!![],'message':_0x8fefe6[_0x1244ea(0x1d4)],'count':0x0,'data':[]};return{'success':!![],'message':_0x1244ea(0x1a4)+_0x294994['length']+'\x20row'+(_0x8fefe6[_0x1244ea(0x1b9)](_0x294994[_0x1244ea(0x1c8)],0x1)?'':'s')+'.','count':_0x294994['length'],'data':_0x294994};}}async function closePool(){const _0xf05b55=a0_0x59b2a8,_0x4d877f={'QVATV':'db_pool_closed','TGrUG':function(_0x5a80aa,_0x4761be,_0x953b39,_0x4e40f1){return _0x5a80aa(_0x4761be,_0x953b39,_0x4e40f1);},'SQhGK':_0xf05b55(0x1c5),'cnWdO':_0xf05b55(0x1a2),'bykFs':'Database\x20pool\x20was\x20already\x20closed'};if(!isPoolClosed)try{isPoolClosed=!![],await pool[_0xf05b55(0x1bb)](),logger[_0xf05b55(0x1ca)]({'event':_0x4d877f[_0xf05b55(0x19c)]},_0xf05b55(0x196));}catch(_0x519029){_0x4d877f['TGrUG'](logError,_0x519029,{'event':_0x4d877f['SQhGK']},_0xf05b55(0x1bd)+_0x519029['message']);}else logger[_0xf05b55(0x1b5)]({'event':_0x4d877f['cnWdO']},_0x4d877f['bykFs']);}function a0_0x3211(_0xd84e13,_0x45f9a8){_0xd84e13=_0xd84e13-0x194;const _0x27da6d=a0_0x27da();let _0x3211e8=_0x27da6d[_0xd84e13];if(a0_0x3211['rLquph']===undefined){var _0x464667=function(_0x41229a){const _0x456353='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x25b3c5='',_0x2f23f9='';for(let _0x17a74c=0x0,_0x6a30d2,_0x3ecc36,_0x702729=0x0;_0x3ecc36=_0x41229a['charAt'](_0x702729++);~_0x3ecc36&&(_0x6a30d2=_0x17a74c%0x4?_0x6a30d2*0x40+_0x3ecc36:_0x3ecc36,_0x17a74c++%0x4)?_0x25b3c5+=String['fromCharCode'](0xff&_0x6a30d2>>(-0x2*_0x17a74c&0x6)):0x0){_0x3ecc36=_0x456353['indexOf'](_0x3ecc36);}for(let _0x1a9279=0x0,_0x39f8a7=_0x25b3c5['length'];_0x1a9279<_0x39f8a7;_0x1a9279++){_0x2f23f9+='%'+('00'+_0x25b3c5['charCodeAt'](_0x1a9279)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2f23f9);};a0_0x3211['Crkqcc']=_0x464667,a0_0x3211['nQpvab']={},a0_0x3211['rLquph']=!![];}const _0x297c47=_0x27da6d[0x0],_0x387f80=_0xd84e13+_0x297c47,_0x40820d=a0_0x3211['nQpvab'][_0x387f80];return!_0x40820d?(_0x3211e8=a0_0x3211['Crkqcc'](_0x3211e8),a0_0x3211['nQpvab'][_0x387f80]=_0x3211e8):_0x3211e8=_0x40820d,_0x3211e8;}async function checkConnection(){const _0x412ea5=a0_0x59b2a8,_0x2612da={'hCdgi':'SELECT\x201','siDBl':function(_0x17c9ef,_0xe6238f,_0x1d34d5,_0x4324d5){return _0x17c9ef(_0xe6238f,_0x1d34d5,_0x4324d5);}};try{const _0x4e7dd0=getPool(),_0x5f1853=await _0x4e7dd0['connect']();try{return await _0x5f1853[_0x412ea5(0x19f)](_0x2612da[_0x412ea5(0x1c7)]),!![];}finally{_0x5f1853['release']();}}catch(_0x48f02d){return _0x2612da[_0x412ea5(0x1bc)](logError,_0x48f02d,{'event':_0x412ea5(0x1b1)},_0x412ea5(0x1d8)+_0x48f02d[_0x412ea5(0x1ab)]),![];}}async function executeTransaction(_0x17c51e){const _0x21d28e=a0_0x59b2a8,_0x4d6ff0={'rMczC':function(_0x4ada8f){return _0x4ada8f();},'DUqPk':function(_0x2f9089){return _0x2f9089();},'GDLDZ':function(_0x1e4206,_0x2596c2,_0x4988cc){return _0x1e4206(_0x2596c2,_0x4988cc);},'RLGPF':function(_0x2d91f2,_0xc9fe04,_0x157eec,_0x23a79e){return _0x2d91f2(_0xc9fe04,_0x157eec,_0x23a79e);},'atGwi':function(_0x3128f6){return _0x3128f6();},'EGFou':'commit','jognt':_0x21d28e(0x1cf),'TOULz':function(_0x16658a,_0x4e9ad6,_0x4008af,_0x2b3b79){return _0x16658a(_0x4e9ad6,_0x4008af,_0x2b3b79);},'UsRcJ':'ROLLBACK','rlQNa':function(_0x22585c,_0x5ea555,_0x58277f){return _0x22585c(_0x5ea555,_0x58277f);},'klKvz':_0x21d28e(0x1cb),'PRIsL':function(_0x19cb4c,_0x41f456,_0x2a0a9d,_0x5d4134){return _0x19cb4c(_0x41f456,_0x2a0a9d,_0x5d4134);},'oTYXz':_0x21d28e(0x1b8)};let _0x8fb996;const _0x1aca3d=_0x4d6ff0[_0x21d28e(0x1af)](startQueryTimer);try{const _0x22179c=_0x4d6ff0[_0x21d28e(0x1c6)](getPool);_0x8fb996=await _0x22179c[_0x21d28e(0x1b0)](),_0x4d6ff0[_0x21d28e(0x1a3)](logTransaction,'start',_0x17c51e['length']),await _0x8fb996['query']('BEGIN');const _0x56ef28=[];for(const _0x4ad319 of _0x17c51e){const _0x221bb5=startQueryTimer(),_0x359162=await _0x8fb996[_0x21d28e(0x19f)](_0x4ad319['sql'],_0x4ad319[_0x21d28e(0x194)]||[]),_0x23dd8c=_0x221bb5();_0x4d6ff0['RLGPF'](logQuery,_0x4ad319[_0x21d28e(0x1c1)],_0x4ad319[_0x21d28e(0x194)]||[],{'duration':_0x23dd8c,'rowsAffected':_0x359162[_0x21d28e(0x1c9)],'dbType':_0x21d28e(0x1cf)}),_0x56ef28[_0x21d28e(0x1b6)](_0x359162['rows']);}await _0x8fb996[_0x21d28e(0x19f)]('COMMIT');const _0x760701=_0x4d6ff0['atGwi'](_0x1aca3d);return logTransaction(_0x4d6ff0['EGFou'],_0x17c51e['length']),logger['info']({'event':'transaction_complete','queryCount':_0x17c51e['length'],'totalDurationMs':_0x760701,'dbType':_0x4d6ff0[_0x21d28e(0x197)]},_0x21d28e(0x1c4)+_0x760701+_0x21d28e(0x1d1)+_0x17c51e[_0x21d28e(0x1c8)]+_0x21d28e(0x1ce)),_0x56ef28;}catch(_0x2bd963){const _0x2df54c=_0x4d6ff0['rMczC'](_0x1aca3d);_0x4d6ff0[_0x21d28e(0x198)](logError,_0x2bd963,{'event':'transaction_error','queryCount':_0x17c51e['length'],'totalDurationMs':_0x2df54c,'code':_0x2bd963['code'],'dbType':'postgresql'},_0x21d28e(0x1d2)+_0x2bd963[_0x21d28e(0x1ab)]);if(_0x8fb996)try{await _0x8fb996[_0x21d28e(0x19f)](_0x4d6ff0['UsRcJ']),_0x4d6ff0['rlQNa'](logTransaction,_0x4d6ff0['klKvz'],_0x17c51e[_0x21d28e(0x1c8)]);}catch(_0x344c65){_0x4d6ff0['PRIsL'](logError,_0x344c65,{'event':_0x4d6ff0[_0x21d28e(0x1d7)],'dbType':_0x4d6ff0[_0x21d28e(0x197)]},_0x21d28e(0x1d6)+_0x344c65[_0x21d28e(0x1ab)]);}throw _0x2bd963;}finally{if(_0x8fb996)try{_0x8fb996[_0x21d28e(0x1ba)]();}catch(_0x103813){logger['error']({'event':'client_release_error','error':_0x103813['message'],'dbType':_0x21d28e(0x1cf)},_0x21d28e(0x1a9)+_0x103813['message']);}}}module[a0_0x59b2a8(0x1be)]={'executeQuery':executeQuery,'executeTransaction':executeTransaction,'formatResponse':formatResponse,'closePool':closePool,'getPool':getPool,'checkConnection':checkConnection};
1
+ const a0_0x381fbd=a0_0x44b0;(function(_0x4e0e1d,_0x1fde7e){const _0x30950d=a0_0x44b0,_0x3b53c2=_0x4e0e1d();while(!![]){try{const _0x3d900d=parseInt(_0x30950d(0x18f))/0x1+-parseInt(_0x30950d(0x175))/0x2+parseInt(_0x30950d(0x17f))/0x3*(-parseInt(_0x30950d(0x18b))/0x4)+parseInt(_0x30950d(0x17b))/0x5*(parseInt(_0x30950d(0x168))/0x6)+-parseInt(_0x30950d(0x17e))/0x7*(parseInt(_0x30950d(0x15c))/0x8)+parseInt(_0x30950d(0x15d))/0x9*(-parseInt(_0x30950d(0x197))/0xa)+parseInt(_0x30950d(0x177))/0xb;if(_0x3d900d===_0x1fde7e)break;else _0x3b53c2['push'](_0x3b53c2['shift']());}catch(_0x577c30){_0x3b53c2['push'](_0x3b53c2['shift']());}}}(a0_0x200a,0xa252a));const {Pool}=require('pg'),{logQuery,logTransaction,startQueryTimer,logDatabaseConfig,logger,logError}=require(a0_0x381fbd(0x188)),dbConfig={'host':process[a0_0x381fbd(0x199)]['DB_HOST']||a0_0x381fbd(0x180),'port':parseInt(process['env'][a0_0x381fbd(0x160)]||a0_0x381fbd(0x174)),'user':process[a0_0x381fbd(0x199)][a0_0x381fbd(0x191)]||'postgres','password':process['env']['DB_PASSWORD']||a0_0x381fbd(0x198),'database':process['env'][a0_0x381fbd(0x183)]||a0_0x381fbd(0x193)};logDatabaseConfig({'host':dbConfig[a0_0x381fbd(0x172)],'port':dbConfig['port'],'database':dbConfig[a0_0x381fbd(0x16b)],'type':a0_0x381fbd(0x179),'user':dbConfig[a0_0x381fbd(0x189)]});let pool=new Pool(dbConfig),isPoolClosed=![];function getPool(){const _0x54e180=a0_0x381fbd;return isPoolClosed&&(logger[_0x54e180(0x16f)]({'event':_0x54e180(0x178)},'Creating\x20new\x20database\x20pool\x20(previous\x20pool\x20was\x20closed)'),pool=new Pool(dbConfig),isPoolClosed=![]),pool;}async function executeQuery(_0x74feb6,_0x1614be=[]){const _0x5a2e37=a0_0x381fbd,_0x46cc5b={'CSdDz':function(_0x2d30da){return _0x2d30da();},'UUVre':function(_0x5efede){return _0x5efede();},'xsXOc':function(_0x5ec288,_0x16dbe7,_0xc9a0b6,_0x1034ab){return _0x5ec288(_0x16dbe7,_0xc9a0b6,_0x1034ab);},'NJtcf':_0x5a2e37(0x179),'XSkVl':function(_0x1f5100){return _0x1f5100();}},_0x1e6fa6=_0x46cc5b[_0x5a2e37(0x19d)](startQueryTimer);try{const _0x26a873=_0x46cc5b[_0x5a2e37(0x19d)](getPool),_0x44d514=await _0x26a873[_0x5a2e37(0x176)]();try{const _0x1bf56b=await _0x44d514['query'](_0x74feb6,_0x1614be),_0x167529=_0x46cc5b['UUVre'](_0x1e6fa6);return _0x46cc5b['xsXOc'](logQuery,_0x74feb6,_0x1614be,{'duration':_0x167529,'rowsAffected':_0x1bf56b[_0x5a2e37(0x162)],'dbType':_0x46cc5b[_0x5a2e37(0x171)]}),_0x1bf56b['rows'];}finally{_0x44d514[_0x5a2e37(0x192)]();}}catch(_0x14765d){const _0x4dc9c0=_0x46cc5b[_0x5a2e37(0x194)](_0x1e6fa6);logError(_0x14765d,{'event':_0x5a2e37(0x187),'query':_0x74feb6['substring'](0x0,0x1f4),'paramCount':_0x1614be[_0x5a2e37(0x185)],'durationMs':_0x4dc9c0,'code':_0x14765d['code'],'dbType':_0x46cc5b[_0x5a2e37(0x171)]},_0x5a2e37(0x16e)+_0x14765d['message']);throw _0x14765d;}}function formatResponse(_0x4c3aaa,_0x47ef7f=null){const _0x2a9e02=a0_0x381fbd,_0x512678={'eOgQG':_0x2a9e02(0x164),'FgAEo':_0x2a9e02(0x18a),'qrmOG':function(_0x1c8ae0,_0x50a2ec){return _0x1c8ae0===_0x50a2ec;},'WWMpM':'AUTHENTICATION_ERROR','uXzIr':function(_0x3c953b,_0x170a6b){return _0x3c953b===_0x170a6b;}};if(_0x47ef7f){let _0x33fcc1=_0x512678[_0x2a9e02(0x18e)];if(_0x47ef7f[_0x2a9e02(0x19a)]['includes']('syntax\x20error'))_0x33fcc1='SYNTAX_ERROR';else{if(_0x47ef7f['code']===_0x512678['FgAEo'])_0x33fcc1='TABLE_NOT_FOUND';else{if(_0x512678[_0x2a9e02(0x16a)](_0x47ef7f['code'],_0x2a9e02(0x182)))_0x33fcc1=_0x512678['WWMpM'];else(_0x512678[_0x2a9e02(0x16a)](_0x47ef7f[_0x2a9e02(0x18c)],'08006')||_0x47ef7f[_0x2a9e02(0x18c)]==='08001')&&(_0x33fcc1=_0x2a9e02(0x16c));}}return{'success':![],'message':_0x2a9e02(0x190)+_0x47ef7f['message'],'count':-0x1,'error_code':_0x33fcc1};}else{if(!_0x4c3aaa||_0x4c3aaa[_0x2a9e02(0x185)]===0x0)return{'success':!![],'message':_0x2a9e02(0x17c),'count':0x0,'data':[]};return{'success':!![],'message':_0x2a9e02(0x19c)+_0x4c3aaa[_0x2a9e02(0x185)]+'\x20row'+(_0x512678[_0x2a9e02(0x15e)](_0x4c3aaa['length'],0x1)?'':'s')+'.','count':_0x4c3aaa[_0x2a9e02(0x185)],'data':_0x4c3aaa};}}async function closePool(){const _0x3d9b6f=a0_0x381fbd,_0x8e1409={'HaZOP':'db_pool_closed'};if(!isPoolClosed)try{isPoolClosed=!![],await pool[_0x3d9b6f(0x167)](),logger['info']({'event':_0x8e1409[_0x3d9b6f(0x169)]},'Database\x20pool\x20closed\x20successfully');}catch(_0x2c298e){logError(_0x2c298e,{'event':'db_pool_close_error'},_0x3d9b6f(0x15f)+_0x2c298e[_0x3d9b6f(0x19a)]);}else logger['debug']({'event':_0x3d9b6f(0x195)},_0x3d9b6f(0x17d));}async function checkConnection(){const _0x3572c5=a0_0x381fbd,_0x56a7cd={'hWeuB':function(_0x5ebf3b){return _0x5ebf3b();},'nMMsI':function(_0x5444c9,_0x54e481,_0x222257,_0x2d844a){return _0x5444c9(_0x54e481,_0x222257,_0x2d844a);}};try{const _0x13ed45=_0x56a7cd[_0x3572c5(0x19e)](getPool),_0x3e2219=await _0x13ed45['connect']();try{return await _0x3e2219['query'](_0x3572c5(0x181)),!![];}finally{_0x3e2219['release']();}}catch(_0x3e4012){return _0x56a7cd[_0x3572c5(0x19b)](logError,_0x3e4012,{'event':'db_connection_check_error'},_0x3572c5(0x173)+_0x3e4012['message']),![];}}function a0_0x200a(){const _0x55d5f2=['mZy0mK12rffRAq','mtKYlJe2oc4XmdaUmq','u0vmrunuide','mJHqmde','rejFtKfnrq','zxjYB3i','BgvUz3rO','vhjHBNnHy3rPB24Gy29TBwL0DgvKicG','C3fSx2vYCM9Y','lI9SB2DNzxi','DxnLCG','ndjqmde','mZK5mMPpAMTdsq','y29Kzq','C3rHCNq','zu9NuuC','otaZmtuXz09uzvnu','rgf0ywjHC2uGzxjYB3i6ia','rejFvvnfuG','CMvSzwfZzq','zgj4ytaZ','wfnRvMW','zgjFCg9VBf9HBhjLywr5x2nSB3nLza','vhjHBNnHy3rPB24GzMfPBgvKoIa','nteZmgvYz0fMyq','Cg9ZDgDYzxmXmJm0','zw52','BwvZC2fNzq','BK1nC0K','uxvLCNKGCMv0DxjUzwqG','q1nKrhO','AfDLDui','mtGYmJGXnNnoyNnltW','mJiZodncu29eveC','DvH6sxi','rxjYB3iGy2XVC2LUzYbKyxrHyMfZzsbWB29SoIa','rejFue9sva','rxjYB3iGCMvSzwfZAw5NihrYyw5Zywn0Aw9UignSAwvUDdOG','CM93q291BNq','CM93CW','vu5ltK9xtL9fuLjpuG','zxHWB3j0CW','D1nYrhO','zw5K','mZb1vwvNzfe','sgfAt1a','CxjTt0C','zgf0ywjHC2u','q09otKvdveLptL9fuLjpuG','C3fS','u1fmievYCM9YoIa','Aw5MBW','CM9SBgjHy2S','tKP0y2y','Ag9ZDa','rxjYB3iGy2HLy2TPBMCGzgf0ywjHC2uGy29UBMvJDgLVBJOG','ntqZmG','nJC0mJyWrhbmyNjI','y29UBMvJDa','mJqWnZyXndbwDxzbzgO','zgjFCg9VBf9YzwnYzwf0zq','Cg9ZDgDYzxnXBa','CxvLCNK','oduZmJiWBNrpwvLW','tM8Gzgf0ysbMB3vUzc4','rgf0ywjHC2uGCg9VBcb3yxmGywXYzwfKEsbJBg9Zzwq','mtrZquXlzNa'];a0_0x200a=function(){return _0x55d5f2;};return a0_0x200a();}function a0_0x44b0(_0x32284c,_0x1270cb){_0x32284c=_0x32284c-0x15c;const _0x200a75=a0_0x200a();let _0x44b03f=_0x200a75[_0x32284c];if(a0_0x44b0['AuPaUx']===undefined){var _0x5ebe76=function(_0x246e97){const _0x1f5f77='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1ab47f='',_0xed3482='';for(let _0x44a477=0x0,_0x21f49,_0x4ac22c,_0x4ed507=0x0;_0x4ac22c=_0x246e97['charAt'](_0x4ed507++);~_0x4ac22c&&(_0x21f49=_0x44a477%0x4?_0x21f49*0x40+_0x4ac22c:_0x4ac22c,_0x44a477++%0x4)?_0x1ab47f+=String['fromCharCode'](0xff&_0x21f49>>(-0x2*_0x44a477&0x6)):0x0){_0x4ac22c=_0x1f5f77['indexOf'](_0x4ac22c);}for(let _0x3011a9=0x0,_0x2d873f=_0x1ab47f['length'];_0x3011a9<_0x2d873f;_0x3011a9++){_0xed3482+='%'+('00'+_0x1ab47f['charCodeAt'](_0x3011a9)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0xed3482);};a0_0x44b0['DmrIrQ']=_0x5ebe76,a0_0x44b0['jIQdgU']={},a0_0x44b0['AuPaUx']=!![];}const _0x334847=_0x200a75[0x0],_0x45485b=_0x32284c+_0x334847,_0x35c1a2=a0_0x44b0['jIQdgU'][_0x45485b];return!_0x35c1a2?(_0x44b03f=a0_0x44b0['DmrIrQ'](_0x44b03f),a0_0x44b0['jIQdgU'][_0x45485b]=_0x44b03f):_0x44b03f=_0x35c1a2,_0x44b03f;}async function executeTransaction(_0x327e04){const _0x3ed606=a0_0x381fbd,_0x514aa1={'wSrDz':function(_0x42f728){return _0x42f728();},'Lidon':'BEGIN','sxSjE':_0x3ed606(0x179),'GOjaP':'COMMIT','CzlwZ':'transaction_complete','PQZqt':'ROLLBACK','GmVgo':function(_0x54a6bc,_0x4c8330,_0x2e3953,_0x587118){return _0x54a6bc(_0x4c8330,_0x2e3953,_0x587118);}};let _0x5150b4;const _0x531b1e=_0x514aa1[_0x3ed606(0x166)](startQueryTimer);try{const _0x1c9043=getPool();_0x5150b4=await _0x1c9043[_0x3ed606(0x176)](),logTransaction(_0x3ed606(0x18d),_0x327e04[_0x3ed606(0x185)]),await _0x5150b4['query'](_0x514aa1['Lidon']);const _0x2f8d56=[];for(const _0x315ecf of _0x327e04){const _0x243dd6=_0x514aa1['wSrDz'](startQueryTimer),_0x916150=await _0x5150b4[_0x3ed606(0x17a)](_0x315ecf[_0x3ed606(0x16d)],_0x315ecf['params']||[]),_0x1415ab=_0x243dd6();logQuery(_0x315ecf['sql'],_0x315ecf['params']||[],{'duration':_0x1415ab,'rowsAffected':_0x916150['rowCount'],'dbType':_0x514aa1['sxSjE']}),_0x2f8d56['push'](_0x916150[_0x3ed606(0x163)]);}await _0x5150b4['query'](_0x514aa1['GOjaP']);const _0x19fe8d=_0x514aa1['wSrDz'](_0x531b1e);return logTransaction('commit',_0x327e04[_0x3ed606(0x185)]),logger[_0x3ed606(0x16f)]({'event':_0x514aa1['CzlwZ'],'queryCount':_0x327e04['length'],'totalDurationMs':_0x19fe8d,'dbType':_0x514aa1['sxSjE']},_0x3ed606(0x186)+_0x19fe8d+'ms,\x20'+_0x327e04[_0x3ed606(0x185)]+'\x20queries)'),_0x2f8d56;}catch(_0x3e86c2){const _0x267c5c=_0x531b1e();logError(_0x3e86c2,{'event':'transaction_error','queryCount':_0x327e04['length'],'totalDurationMs':_0x267c5c,'code':_0x3e86c2[_0x3ed606(0x18c)],'dbType':_0x3ed606(0x179)},_0x3ed606(0x196)+_0x3e86c2[_0x3ed606(0x19a)]);if(_0x5150b4)try{await _0x5150b4['query'](_0x514aa1['PQZqt']),logTransaction(_0x3ed606(0x170),_0x327e04['length']);}catch(_0x212763){_0x514aa1['GmVgo'](logError,_0x212763,{'event':'rollback_error','dbType':_0x514aa1['sxSjE']},'Error\x20rolling\x20back\x20transaction:\x20'+_0x212763['message']);}throw _0x3e86c2;}finally{if(_0x5150b4)try{_0x5150b4[_0x3ed606(0x192)]();}catch(_0x3e85ba){logger[_0x3ed606(0x184)]({'event':'client_release_error','error':_0x3e85ba[_0x3ed606(0x19a)],'dbType':_0x3ed606(0x179)},_0x3ed606(0x161)+_0x3e85ba[_0x3ed606(0x19a)]);}}}module[a0_0x381fbd(0x165)]={'executeQuery':executeQuery,'executeTransaction':executeTransaction,'formatResponse':formatResponse,'closePool':closePool,'getPool':getPool,'checkConnection':checkConnection};
@@ -1 +1 @@
1
- const a0_0x1bfe63=a0_0x90f3;(function(_0x174b88,_0x5a2f86){const _0x2b2dbd=a0_0x90f3,_0x5e59dd=_0x174b88();while(!![]){try{const _0x48296f=-parseInt(_0x2b2dbd(0x1c0))/0x1+parseInt(_0x2b2dbd(0x1b0))/0x2*(-parseInt(_0x2b2dbd(0x202))/0x3)+parseInt(_0x2b2dbd(0x237))/0x4*(-parseInt(_0x2b2dbd(0x1eb))/0x5)+parseInt(_0x2b2dbd(0x1d2))/0x6*(parseInt(_0x2b2dbd(0x1fd))/0x7)+parseInt(_0x2b2dbd(0x1c9))/0x8+parseInt(_0x2b2dbd(0x21c))/0x9+parseInt(_0x2b2dbd(0x199))/0xa*(parseInt(_0x2b2dbd(0x1b7))/0xb);if(_0x48296f===_0x5a2f86)break;else _0x5e59dd['push'](_0x5e59dd['shift']());}catch(_0x387bbd){_0x5e59dd['push'](_0x5e59dd['shift']());}}}(a0_0x252d,0x937ce));const pino=require('pino'),fs=require('fs'),path=require('path');let logToFile=![],logDir='./logs',serviceName='restforge',sqlLogEnabled=![],sqlLogLevel=a0_0x1bfe63(0x21b),sqlLogParams=!![],sqlLogSlowThreshold=0x3e8,fileLoggingInitialized=![],appLogStream=null,errorLogStream=null;const prettyPrintOptions={'colorize':!![],'translateTime':'SYS:HH:MM:ss','ignore':'pid,hostname,service,version,env,event,module,port,config,apiKeyEnabled,path,workingDir,isPkg,isNodeScript,file,email,type,cors,logging,apiKey,count,endpoint,route','singleLine':![],'levelFirst':!![],'messageFormat':a0_0x1bfe63(0x19f),'customColors':'info:blue,warn:yellow,error:red,debug:gray','hideObject':!![]},isDevelopment=process[a0_0x1bfe63(0x236)][a0_0x1bfe63(0x23d)]!==a0_0x1bfe63(0x1de),logLevel=process['env'][a0_0x1bfe63(0x20d)]||a0_0x1bfe63(0x1f2);let logger=pino({'level':logLevel,'transport':isDevelopment?{'target':a0_0x1bfe63(0x220),'options':prettyPrintOptions}:undefined,'base':{'service':a0_0x1bfe63(0x221),'version':process[a0_0x1bfe63(0x236)]['APP_VERSION']||a0_0x1bfe63(0x19d),'env':process[a0_0x1bfe63(0x236)]['NODE_ENV']||a0_0x1bfe63(0x1af)},'timestamp':pino['stdTimeFunctions']['isoTime'],'redact':{'paths':[a0_0x1bfe63(0x1c7),'req.headers[\x22x-api-key\x22]','password',a0_0x1bfe63(0x22e),'apiKey',a0_0x1bfe63(0x1b6),a0_0x1bfe63(0x1c4)],'censor':a0_0x1bfe63(0x1a1)},'serializers':{'req':_0xf743cd=>({'id':_0xf743cd['id'],'method':_0xf743cd['method'],'url':_0xf743cd['url'],'path':_0xf743cd[a0_0x1bfe63(0x190)],'remoteAddress':_0xf743cd['ip']||_0xf743cd[a0_0x1bfe63(0x238)]?.[a0_0x1bfe63(0x1f1)]}),'res':_0xcc2ec6=>({'statusCode':_0xcc2ec6['statusCode'],'headers':_0xcc2ec6['getHeaders']?.()}),'err':pino[a0_0x1bfe63(0x1d1)]['err']}});function a0_0x90f3(_0x14cb23,_0x5808cb){_0x14cb23=_0x14cb23-0x17e;const _0x252d50=a0_0x252d();let _0x90f32c=_0x252d50[_0x14cb23];if(a0_0x90f3['oczZnQ']===undefined){var _0x4cc608=function(_0x272ad5){const _0x244928='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x552671='',_0x283095='';for(let _0xafb438=0x0,_0x11657d,_0x1a2c4f,_0x527dfc=0x0;_0x1a2c4f=_0x272ad5['charAt'](_0x527dfc++);~_0x1a2c4f&&(_0x11657d=_0xafb438%0x4?_0x11657d*0x40+_0x1a2c4f:_0x1a2c4f,_0xafb438++%0x4)?_0x552671+=String['fromCharCode'](0xff&_0x11657d>>(-0x2*_0xafb438&0x6)):0x0){_0x1a2c4f=_0x244928['indexOf'](_0x1a2c4f);}for(let _0x30809b=0x0,_0x14588e=_0x552671['length'];_0x30809b<_0x14588e;_0x30809b++){_0x283095+='%'+('00'+_0x552671['charCodeAt'](_0x30809b)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x283095);};a0_0x90f3['minUmi']=_0x4cc608,a0_0x90f3['NZcIXZ']={},a0_0x90f3['oczZnQ']=!![];}const _0x403009=_0x252d50[0x0],_0x3d474b=_0x14cb23+_0x403009,_0x1c26c2=a0_0x90f3['NZcIXZ'][_0x3d474b];return!_0x1c26c2?(_0x90f32c=a0_0x90f3['minUmi'](_0x90f32c),a0_0x90f3['NZcIXZ'][_0x3d474b]=_0x90f32c):_0x90f32c=_0x1c26c2,_0x90f32c;}function initFileLogging(){const _0x53eb98=a0_0x1bfe63,_0x32b210={'WVOJp':function(_0xf20b32,_0x525d4c){return _0xf20b32===_0x525d4c;},'OeeMZ':_0x53eb98(0x1f6),'xXTtD':'debug','WvKAN':function(_0x1749ab,_0x32b5da){return _0x1749ab!==_0x32b5da;},'RoEEN':_0x53eb98(0x188),'PVGpr':function(_0x2f6a09,_0x59179c){return _0x2f6a09(_0x59179c);},'WQCRm':_0x53eb98(0x23a),'nLNKo':_0x53eb98(0x189),'cpjxu':_0x53eb98(0x1f2)};if(fileLoggingInitialized)return;logToFile=_0x32b210[_0x53eb98(0x211)](process['env']['LOG_TO_FILE'],_0x32b210['OeeMZ']),logDir=process['env'][_0x53eb98(0x1d0)]||_0x53eb98(0x18e),serviceName=process['env'][_0x53eb98(0x223)]||_0x53eb98(0x221),sqlLogEnabled=process[_0x53eb98(0x236)]['SQL_LOG_ENABLED']===_0x32b210[_0x53eb98(0x233)],sqlLogLevel=process['env'][_0x53eb98(0x232)]||_0x32b210[_0x53eb98(0x1ba)],sqlLogParams=_0x32b210[_0x53eb98(0x1c8)](process[_0x53eb98(0x236)]['SQL_LOG_PARAMS'],_0x32b210[_0x53eb98(0x1ee)]),sqlLogSlowThreshold=_0x32b210[_0x53eb98(0x1b5)](parseInt,process['env'][_0x53eb98(0x20f)])||0x3e8;if(!logToFile){fileLoggingInitialized=!![];return;}const _0x4f3544=path[_0x53eb98(0x1ea)](process['cwd'](),logDir);try{!fs[_0x53eb98(0x1d3)](_0x4f3544)&&fs['mkdirSync'](_0x4f3544,{'recursive':!![]});}catch(_0x342a24){console['error']('Failed\x20to\x20create\x20log\x20directory\x20'+_0x4f3544+':',_0x342a24['message']),fileLoggingInitialized=!![];return;}const _0x417c55=path['join'](_0x4f3544,'app.log'),_0x50c5bc=path[_0x53eb98(0x1b4)](_0x4f3544,'error.log');try{appLogStream=fs[_0x53eb98(0x21e)](_0x417c55,{'flags':'a'}),errorLogStream=fs[_0x53eb98(0x21e)](_0x50c5bc,{'flags':'a'}),fileLoggingInitialized=!![];const _0x34c58d={'event':_0x32b210[_0x53eb98(0x1d7)],'logDir':_0x4f3544,'files':[_0x32b210['nLNKo'],_0x53eb98(0x1a7)]},_0x46c738=_0x53eb98(0x1a6)+_0x4f3544;logger['info'](_0x34c58d,_0x46c738),writeToFileLog({..._0x34c58d,'level':_0x32b210[_0x53eb98(0x210)],'msg':_0x46c738,'time':new Date()['toISOString']()},'info');}catch(_0x1c22c2){console[_0x53eb98(0x1f5)]('Failed\x20to\x20create\x20log\x20streams:',_0x1c22c2['message']),fileLoggingInitialized=!![];}}function writeToFileLog(_0x142216,_0xa245b5){const _0x30d5a1=a0_0x1bfe63,_0x1ac7a3={'fPrKc':function(_0x38a76f,_0x21e40c){return _0x38a76f||_0x21e40c;},'sUjZg':function(_0x39a678,_0x246381){return _0x39a678+_0x246381;},'gcJPk':function(_0x5844bb,_0xecd08d){return _0x5844bb===_0xecd08d;},'PIlij':'fatal'};if(_0x1ac7a3[_0x30d5a1(0x1fb)](!logToFile,!appLogStream))return;const _0x2223c6={'service':serviceName,..._0x142216},_0x5e3b63=_0x1ac7a3['sUjZg'](JSON['stringify'](_0x2223c6),'\x0a');appLogStream[_0x30d5a1(0x17e)](_0x5e3b63),(_0xa245b5===_0x30d5a1(0x1f5)||_0x1ac7a3['gcJPk'](_0xa245b5,_0x1ac7a3['PIlij']))&&(errorLogStream&&errorLogStream['write'](_0x5e3b63));}function a0_0x252d(){const _0x16bb85=['ufzhChi','rejFueftu1DpuKq','nJKWmtrutuX0rM8','zhvYyxrPB25nCW','zgjFCxvLCNK','EfHuDeq','tM9Kzs5QCW','zK1nuva','u0vmrunu','zNPZuuy','D2fYBG','otaZnJe1Eg90q2Dr','Ec1Yzxf1zxn0lwLK','C3bSAxq','C0fdvxK','sLDux1nfq1jfva','vwXeA3m','C2vJCMv0','CMvXlMHLywrLCNmUyxv0Ag9YAxPHDgLVBG','v3zlqu4','nJiXodGWog9oAfz3uW','ANnVBG','CgfKrw5K','z2L3txC','C2vYDMLJzuLUzM8','Dw5Oyw5KBgvKuMvQzwn0Aw9U','zxHWB3j0CW','te9hx0rjuG','C3rKu2vYAwfSAxPLCNm','nKHpBxDKAq','zxHPC3rZu3LUyW','z2v0','BwvTB3j5vxnHz2u','C3rHCNrZv2L0Aa','v1fduM0','iokvKqRILzeGiefqssblzxKGicaGidOG','BwfW','Aw5JBhvKzxm','u2vYDMvYihn0yxj0Aw5NoIa','vfjbtLnbq1rjt05FuK9mtejbq0S','y3jLzgvUDgLHBhm','ChjVzhvJDgLVBG','y3jLzgL0y2fYza','yM9KEq','r2XVyMfSigvYCM9YigHHBMrSzxjZigLUAxrPywXPEMvK','DKTQwMO','AgjoANO','DgvZDa','qunusvzf','yNvovxy','Dw5JyxvNAhrfEgnLChrPB24','rgvMyxvSDa','CgLK','CMvZB2X2zq','ntGZnte4mgPZDezKyW','CgfZC3DK','q1jjveLdquW','uM9fru4','yMfZzvvYBa','B2jQzwn0','CMvTB3rLqwrKCMvZCW','Aw5MBW','zgjFDhjHBNnHy3rPB24','C3rHDhvZq29Kzq','zxjYB3i','Dhj1zq','AxntBg93','B2HvC24','ANfHzfa','rxjYB3i','zLbYs2m','q1jfqvrf','nJe3odq2nLDUCeXjAq','CMvWBgfJzq','Bg9N','y3jLzgL0x2nHCMq','CgfYyw1Z','mJCYntqXm256AuTKtq','zMf0ywW','vu5ltK9xtG','rxjYB3i6ia','A2v5CW','CMvMCMvZAf90B2TLBG','zw52AxjVBM1LBNq','yLPwEuG','BLfABhq','C29Tzq','zfnwwMS','te9hx0XfvKvm','AgvHBhrOq2HLy2S','u1fmx0Xpr19tte9xx1riuKvtse9mra','y3bQEhu','v1zpsNa','ChjPDMf0zv9RzxK','C3rHDhvZ','Ahr0Cf9LCNjVCG','DxjS','Ahj0Aw1L','yxbPA2v5','r1LtsuC','zvjMreC','y3z2','zgvIDwC','mJK2nJGYm1nvv0LOBa','ChDK','y3jLyxrLv3jPDgvtDhjLyw0','iokvKqRILzRILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILz0','CgLUBY1WCMv0DhK','CMvZDgzVCMDL','rermx0fmvevs','u0vsvKLdrv9oqu1f','Dg9ju09tDhjPBMC','uLjotg4','BgvUz3rO','z0fIzK0','rermx0rst1a','CuTHDwq','rKfuquW6ia','C2vYDMvYx3jLywr5','icdIHPiG','ChjPDMf0zwTLEq','Dg9Rzw4','vxnpuKy','w09lxsbqCM9Qzwn0igXVywrLzdOG','Dxb0Aw1L','u1fmx0Xpr19mrvzfta','t2vLtvO','Dw5RBM93BG','vLj6t2C','zw52','nhPurxzyzW','y29UBMvJDgLVBG','sw1ms3C','zMLSzv9SB2DNAw5Nx2vUywjSzwq','su5trvju','CxvLCNK','tK9erv9ftLy','D3jPDgu','v0nlyxq','Ahr0Cf9Yzxf1zxn0','yxv0Ag9YAxPHDgLVBG','Exf5req','ic0G','Cg9YDa','z2XVyMfSx2vYCM9Yx2HHBMrSzxjZx3nLDhvW','Dg9mB3DLCKnHC2u','yxbPs2v5','zMfSC2u','yxbWlMXVzW','tMnNqKe','DurlyLq','A2LItfa','u1rbuLqGvfjbtLnbq1rjt04','lI9SB2DZ','wuPKC28','Cgf0Aa','BxmP','tI9b','C3b1v24','Bwv0Ag9K','oI8V','DhLWzq','DKjLC2y','AxrlBMy','mJu0mg9Ks0j0wq','vvjkv3O','Bwf0y2G','wu5MsgG','ms4WlJu','BMfTzq','E21Zz30','q09ntuLu','w1jfrefdvevexq','B3LLCxi','ChjVAMvJDf9SB2fKzwq','zw5KCg9PBNrFCMvNAxn0zxjLza','BwvZC2fNzq','rMLSzsbSB2DNAw5NigvUywjSzwq6ia','zxjYB3iUBg9N','AgvHzgvYCW','tKPVv28','sw50zxjUywWGC2vYDMvYigvYCM9Y','z2Xetge','y29Kzq','CgLU','DMLkuLy','zgv2zwXVCg1LBNq','mNbpt3DWyG','revmrvrf','Ag9ZDa','iokvKqRILzeGifbYB2PLy3qGicaGidOG','AM9PBG'];a0_0x252d=function(){return _0x16bb85;};return a0_0x252d();}const createRequestLogger=(_0x935f67={})=>{return logger['child'](_0x935f67);},logServerStart=_0x19b749=>{const _0x2e9186=a0_0x1bfe63,_0x437baf={'UlDks':_0x2e9186(0x1bb),'vBesf':_0x2e9186(0x1e8),'NJoWo':'NOT\x20ACTIVE','jbNqi':_0x2e9186(0x1f2)},_0x2e0207='\x0a╔═══════════════════════════════════════════════════════╗\x0a║\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20RESTFORGE\x20RUNTIME\x20SERVER\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20║\x0a╠═══════════════════════════════════════════════════════╣\x0a║\x20\x20Environment\x20:\x20'+(_0x19b749[_0x2e9186(0x208)]||_0x437baf[_0x2e9186(0x1c5)])['padEnd'](0x26)+_0x2e9186(0x1b3)+(_0x19b749['project']||_0x2e9186(0x192))[_0x2e9186(0x1cb)](0x26)+'\x20║\x0a║\x20\x20Port\x20\x20\x20\x20\x20\x20\x20\x20:\x20'+String(_0x19b749[_0x2e9186(0x184)]||0xbb8)['padEnd'](0x26)+'\x20║\x0a║\x20\x20Config\x20\x20\x20\x20\x20\x20:\x20'+(_0x19b749['configFile']||_0x437baf[_0x2e9186(0x197)])['padEnd'](0x26)+_0x2e9186(0x1d8)+(_0x19b749[_0x2e9186(0x187)]?_0x2e9186(0x1e5):_0x437baf[_0x2e9186(0x1a9)])[_0x2e9186(0x1cb)](0x26)+_0x2e9186(0x21f);console[_0x2e9186(0x1ff)](_0x2e0207);const _0x371029={'event':'server_starting','project':_0x19b749['project'],'port':_0x19b749[_0x2e9186(0x184)],'config':_0x19b749['configFile'],'apiKeyEnabled':!!_0x19b749['apiKey']};logger[_0x2e9186(0x1f2)](_0x371029),writeToFileLog({..._0x371029,'level':'info','msg':_0x2e9186(0x1db)+_0x19b749['project']+'\x20on\x20port\x20'+_0x19b749['port'],'time':new Date()['toISOString']()},_0x437baf['jbNqi']);},logServerReady=_0x3795b5=>{const _0x3e628a=a0_0x1bfe63,_0x228021={'dmgcE':_0x3e628a(0x22b),'uDKbT':function(_0x23f521,_0x48b5ba,_0x486e9a){return _0x23f521(_0x48b5ba,_0x486e9a);},'GYSIG':_0x3e628a(0x1f2)},_0x353ea2={'event':_0x228021['dmgcE'],'port':_0x3795b5[_0x3e628a(0x184)],'module':_0x3795b5['module'],'healthCheck':_0x3795b5[_0x3e628a(0x20e)],'serviceInfo':_0x3795b5[_0x3e628a(0x1cd)],'baseUrl':_0x3795b5['baseUrl']},_0x74bb24='[OK]\x20Server\x20ready\x20on\x20port\x20'+_0x3795b5['port'];logger[_0x3e628a(0x1f2)](_0x353ea2,_0x74bb24),_0x228021[_0x3e628a(0x18b)](writeToFileLog,{..._0x353ea2,'level':'info','msg':_0x74bb24,'time':new Date()[_0x3e628a(0x224)]()},_0x228021[_0x3e628a(0x218)]),_0x3795b5['healthCheck']&&logger[_0x3e628a(0x1f2)]('\x20\x20Health:\x20'+_0x3795b5[_0x3e628a(0x20e)]),_0x3795b5[_0x3e628a(0x1cd)]&&logger[_0x3e628a(0x1f2)]('\x20\x20Info:\x20\x20\x20'+_0x3795b5['serviceInfo']),_0x3795b5[_0x3e628a(0x1ef)]&&logger[_0x3e628a(0x1f2)]('\x20\x20URL:\x20\x20\x20\x20'+_0x3795b5['baseUrl']);},logProjectLoaded=(_0x962b9e,_0x3a06e9)=>{const _0x3a6136=a0_0x1bfe63,_0x568863={'PhHby':function(_0x2f6621,_0x6925b4,_0x17eced){return _0x2f6621(_0x6925b4,_0x17eced);},'mvQam':_0x3a6136(0x1f2)},_0x55d0e3={'event':_0x3a6136(0x1a3),'project':_0x962b9e,'path':_0x3a06e9},_0xf7de1b=_0x3a6136(0x230)+_0x962b9e;logger['info'](_0x55d0e3,_0xf7de1b),_0x568863['PhHby'](writeToFileLog,{..._0x55d0e3,'level':_0x568863['mvQam'],'msg':_0xf7de1b,'time':new Date()[_0x3a6136(0x224)]()},'info');},logEndpointRegistered=(_0x581ece,_0x1deec8)=>{const _0xce9fcd=a0_0x1bfe63,_0x3be213={'kibLP':_0xce9fcd(0x1a4),'zHQRI':'debug'},_0x4d23ab={'event':_0x3be213[_0xce9fcd(0x18c)],'endpoint':_0x581ece,'route':_0x1deec8},_0x262174=_0xce9fcd(0x22c)+_0x581ece+':\x20'+_0x1deec8;logger[_0xce9fcd(0x21b)](_0x4d23ab,_0x262174),writeToFileLog({..._0x4d23ab,'level':_0xce9fcd(0x21b),'msg':_0x262174,'time':new Date()['toISOString']()},_0x3be213['zHQRI']);},logDatabaseConfig=_0x439b3c=>{const _0x3769ca=a0_0x1bfe63,_0x69e0d2={'Durta':function(_0x3d5a02,_0x2fbcd4,_0x1c6ee2){return _0x3d5a02(_0x2fbcd4,_0x1c6ee2);},'WCKat':'debug'},_0x12aaeb={'event':'database_config','host':_0x439b3c['host'],'port':_0x439b3c['port'],'database':_0x439b3c['database'],'type':_0x439b3c[_0x3769ca(0x196)],'user':_0x439b3c['user']},_0x1d6ce4='Database:\x20'+_0x439b3c['type']+_0x3769ca(0x195)+_0x439b3c[_0x3769ca(0x1b2)]+':'+_0x439b3c['port']+'/'+_0x439b3c['database'];logger[_0x3769ca(0x21b)](_0x12aaeb,_0x1d6ce4),_0x69e0d2['Durta'](writeToFileLog,{..._0x12aaeb,'level':'debug','msg':_0x1d6ce4,'time':new Date()['toISOString']()},_0x69e0d2[_0x3769ca(0x17f)]);},logRequest=(_0x1d1384,_0x4a02f6,_0x4da5c9)=>{const _0x389f7f=a0_0x1bfe63,_0x14142f={'bztrK':_0x389f7f(0x1f2),'giwMw':function(_0x125376,_0x3d82e9){return _0x125376>=_0x3d82e9;},'eRfDG':_0x389f7f(0x1f5),'MUFot':function(_0x5b6599,_0xfd57ac,_0x3a5c34){return _0x5b6599(_0xfd57ac,_0x3a5c34);}},_0x17e7b7={'event':_0x389f7f(0x180),'method':_0x1d1384[_0x389f7f(0x194)],'path':_0x1d1384['path'],'statusCode':_0x4a02f6['statusCode'],'durationMs':_0x4da5c9,'ip':_0x1d1384['ip']},_0x92535e=_0x1d1384['method']+'\x20'+_0x1d1384['path']+_0x389f7f(0x183)+_0x4a02f6['statusCode']+'\x20('+_0x4da5c9+'ms)';let _0x5a151b=_0x14142f['bztrK'];if(_0x14142f[_0x389f7f(0x1cc)](_0x4a02f6['statusCode'],0x1f4))_0x5a151b=_0x14142f[_0x389f7f(0x219)],logger['error'](_0x17e7b7,_0x92535e);else _0x4a02f6['statusCode']>=0x190?(_0x5a151b=_0x389f7f(0x1bf),logger['warn'](_0x17e7b7,_0x92535e)):logger['info'](_0x17e7b7,_0x92535e);_0x14142f['MUFot'](writeToFileLog,{..._0x17e7b7,'level':_0x5a151b,'msg':_0x92535e,'time':new Date()['toISOString']()},_0x5a151b);},SENSITIVE_PARAM_PATTERNS=['password',a0_0x1bfe63(0x1ec),a0_0x1bfe63(0x21d),'token','access_token',a0_0x1bfe63(0x207),a0_0x1bfe63(0x1c6),'api_secret',a0_0x1bfe63(0x217),'api_key','credential',a0_0x1bfe63(0x1dd),'pin','otp','private_key','privatekey'],redactSensitiveParams=(_0x2e3947,_0x37beff)=>{const _0x4ac417=a0_0x1bfe63,_0x25c62b={'ltNDn':function(_0x92f2b4,_0x37762c){return _0x92f2b4>_0x37762c;},'oWrRA':'[REDACTED:token]','NMULV':function(_0x147f47,_0x3a8cad){return _0x147f47===_0x3a8cad;}};if(!_0x2e3947||_0x25c62b['NMULV'](_0x2e3947['length'],0x0))return _0x2e3947;const _0x36e1c6=_0x37beff[_0x4ac417(0x186)](),_0x5334f4=_0x36e1c6['match'](/\(([^)]+)\)\s*values/i);let _0x429285=[];_0x5334f4&&(_0x429285=_0x5334f4[0x1][_0x4ac417(0x1c2)](',')['map'](_0xdf79c7=>_0xdf79c7['trim']()['toLowerCase']()));const _0x1404d0=_0x36e1c6['match'](/set\s+(.+?)(?:\s+where|$)/i);if(_0x1404d0){const _0x515c64=_0x1404d0[0x1],_0xbc84e4=_0x515c64[_0x4ac417(0x19b)](/(\w+)\s*=/g);_0xbc84e4&&(_0x429285=_0xbc84e4[_0x4ac417(0x1d9)](_0x4f2617=>_0x4f2617[_0x4ac417(0x1fe)](/\s*=/,'')['trim']()[_0x4ac417(0x186)]()));}return _0x2e3947[_0x4ac417(0x1d9)]((_0x5d26c6,_0x2e610a)=>{const _0x46d4f0=_0x4ac417;if(_0x429285[_0x2e610a]){const _0x36a4e6=_0x429285[_0x2e610a],_0x4d8e2c=SENSITIVE_PARAM_PATTERNS[_0x46d4f0(0x20b)](_0x296721=>_0x36a4e6[_0x46d4f0(0x1da)](_0x296721));if(_0x4d8e2c)return'[REDACTED]';}if(typeof _0x5d26c6==='string'&&_0x25c62b['ltNDn'](_0x5d26c6['length'],0x20)){if(/^[a-zA-Z0-9+/=_.-]+$/['test'](_0x5d26c6)&&_0x5d26c6[_0x46d4f0(0x1da)]('.'))return _0x25c62b['oWrRA'];if(/^[a-fA-F0-9]{32,}$/[_0x46d4f0(0x1e4)](_0x5d26c6))return'[REDACTED:hash]';}return _0x5d26c6;});},parseQueryMetadata=_0x10670d=>{const _0x3266ad=a0_0x1bfe63,_0x3191b={'XVSSB':'SELECT','buNUv':_0x3266ad(0x23b),'jqadP':'UPDATE','fzsQF':_0x3266ad(0x1b1),'nQZlt':'BEGIN','URJWz':_0x3266ad(0x18d),'dSVZk':'TRANSACTION_BEGIN','bZVyH':_0x3266ad(0x1a0),'SqHqi':'ROLLBACK','rSOBp':'ALTER'},_0x44de6a=_0x10670d['trim'](),_0x294fa0=_0x44de6a['toUpperCase']();let _0x4c0a4e=_0x3266ad(0x204),_0x30e5e1=null;if(_0x294fa0[_0x3266ad(0x1d6)](_0x3266ad(0x1bd))){_0x4c0a4e=_0x3191b['XVSSB'];const _0x949a13=_0x44de6a[_0x3266ad(0x19b)](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x30e5e1=_0x949a13?_0x949a13[0x1]:null;}else{if(_0x294fa0['startsWith'](_0x3191b[_0x3266ad(0x1e6)])){_0x4c0a4e=_0x3191b['buNUv'];const _0x211607=_0x44de6a[_0x3266ad(0x19b)](/INTO\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x30e5e1=_0x211607?_0x211607[0x1]:null;}else{if(_0x294fa0[_0x3266ad(0x1d6)](_0x3191b['jqadP'])){_0x4c0a4e=_0x3191b[_0x3266ad(0x1f9)];const _0x385899=_0x44de6a['match'](/UPDATE\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x30e5e1=_0x385899?_0x385899[0x1]:null;}else{if(_0x294fa0[_0x3266ad(0x1d6)](_0x3191b[_0x3266ad(0x1be)])){_0x4c0a4e=_0x3191b[_0x3266ad(0x1be)];const _0x42b65c=_0x44de6a[_0x3266ad(0x19b)](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x30e5e1=_0x42b65c?_0x42b65c[0x1]:null;}else{if(_0x294fa0[_0x3266ad(0x1d6)](_0x3191b[_0x3266ad(0x20a)])||_0x294fa0[_0x3266ad(0x1d6)](_0x3191b[_0x3266ad(0x19a)]))_0x4c0a4e=_0x3191b[_0x3266ad(0x20c)];else{if(_0x294fa0['startsWith'](_0x3191b[_0x3266ad(0x209)]))_0x4c0a4e='TRANSACTION_COMMIT';else{if(_0x294fa0[_0x3266ad(0x1d6)](_0x3191b['SqHqi']))_0x4c0a4e=_0x3266ad(0x1dc);else{if(_0x294fa0['startsWith'](_0x3266ad(0x1fc)))_0x4c0a4e='DDL_CREATE';else{if(_0x294fa0[_0x3266ad(0x1d6)](_0x3191b['rSOBp']))_0x4c0a4e=_0x3266ad(0x222);else _0x294fa0[_0x3266ad(0x1d6)]('DROP')&&(_0x4c0a4e=_0x3266ad(0x228));}}}}}}}}return{'type':_0x4c0a4e,'table':_0x30e5e1};},startQueryTimer=()=>{const _0x4004f0=a0_0x1bfe63,_0x52a910={'AhqKO':function(_0x393ec5,_0x5c63d3){return _0x393ec5(_0x5c63d3);},'CPvSG':function(_0x1af6b5,_0x374eed){return _0x1af6b5+_0x374eed;},'zlOEf':function(_0x5182bf,_0x172580){return _0x5182bf/_0x172580;}},_0x2d7caa=process[_0x4004f0(0x216)]();return()=>{const _0x396bce=_0x4004f0,[_0x3041d2,_0x378916]=process[_0x396bce(0x216)](_0x2d7caa);return _0x52a910['AhqKO'](parseFloat,_0x52a910['CPvSG'](_0x3041d2*0x3e8,_0x52a910['zlOEf'](_0x378916,0xf4240))['toFixed'](0x2));};},logQuery=(_0xd8c70,_0x518802=[],_0x7ab862={})=>{const _0x17b6cd=a0_0x1bfe63,_0x3f0df5={'nIkbg':_0x17b6cd(0x1b9),'CXnIK':'postgresql','fMMQP':function(_0x222659,_0x302330,_0x236785){return _0x222659(_0x302330,_0x236785);},'YJdso':function(_0xcf65ef,_0x5eda45){return _0xcf65ef!==_0x5eda45;},'sACUy':function(_0xda7c05,_0xfb99e2){return _0xda7c05>_0xfb99e2;},'gAbfM':'\x20[SLOW]','RRNLn':'warn','zPMJX':function(_0x472fda,_0x39ff06){return _0x472fda===_0x39ff06;}};if(!sqlLogEnabled){logger[_0x17b6cd(0x21b)]({'event':_0x3f0df5['nIkbg'],'query':_0xd8c70['substring'](0x0,0xc8),'paramCount':_0x518802['length']},'DB\x20Query');return;}const {duration:duration=null,rowsAffected:rowsAffected=null,dbType:dbType=_0x3f0df5['CXnIK']}=_0x7ab862,{type:_0x18a087,table:_0x172f6d}=parseQueryMetadata(_0xd8c70),_0x450a4f={'event':'sql_query','queryType':_0x18a087,'table':_0x172f6d,'query':_0xd8c70,'paramCount':_0x518802[_0x17b6cd(0x226)],'dbType':dbType};sqlLogParams&&_0x518802[_0x17b6cd(0x226)]>0x0&&(_0x450a4f[_0x17b6cd(0x201)]=_0x3f0df5[_0x17b6cd(0x1bc)](redactSensitiveParams,_0x518802,_0xd8c70));_0x3f0df5[_0x17b6cd(0x18f)](duration,null)&&(_0x450a4f[_0x17b6cd(0x1b8)]=duration,_0x450a4f[_0x17b6cd(0x1f7)]=duration>sqlLogSlowThreshold);rowsAffected!==null&&(_0x450a4f['rowsAffected']=rowsAffected);const _0x4172ef=_0x172f6d||_0x17b6cd(0x234);let _0x5046db='['+_0x18a087+']\x20'+_0x4172ef;duration!==null&&(_0x5046db+='\x20('+duration+_0x17b6cd(0x191));const _0x28f508=duration!==null&&_0x3f0df5[_0x17b6cd(0x1c3)](duration,sqlLogSlowThreshold);let _0x2384a0=_0x17b6cd(0x21b);if(_0x28f508)_0x5046db+=_0x3f0df5[_0x17b6cd(0x227)],_0x2384a0=_0x3f0df5[_0x17b6cd(0x225)],logger['warn'](_0x450a4f,_0x5046db);else _0x3f0df5['zPMJX'](sqlLogLevel,'info')?(_0x2384a0=_0x17b6cd(0x1f2),logger['info'](_0x450a4f,_0x5046db)):logger[_0x17b6cd(0x21b)](_0x450a4f,_0x5046db);writeToFileLog({..._0x450a4f,'level':_0x2384a0,'msg':_0x5046db,'time':new Date()[_0x17b6cd(0x224)]()},_0x2384a0);},logTransaction=(_0x24a4a6,_0x66b4c4)=>{const _0x56d456=a0_0x1bfe63,_0x22352b={'DhbVa':_0x56d456(0x1f3),'VRzOg':'debug'},_0x47ad0b={'event':_0x22352b['DhbVa'],'status':_0x24a4a6,'queryCount':_0x66b4c4},_0x408f58='Transaction\x20'+_0x24a4a6;logger[_0x56d456(0x21b)](_0x47ad0b,_0x408f58),writeToFileLog({..._0x47ad0b,'level':'debug','msg':_0x408f58,'time':new Date()['toISOString']()},_0x22352b[_0x56d456(0x235)]);},redactObject=_0x4f2a9a=>{const _0x13f2e4=a0_0x1bfe63,_0x254673={'naihz':function(_0x27272c,_0xa7f68c){return _0x27272c!==_0xa7f68c;},'tOlov':'object','yqyDD':'pwd','itKnf':_0x13f2e4(0x181),'kGiOY':_0x13f2e4(0x1df),'UsORF':_0x13f2e4(0x200),'OtkWV':_0x13f2e4(0x21a),'vKjZj':_0x13f2e4(0x1ad),'wLHti':_0x13f2e4(0x22d),'pGrja':'[REDACTED]','YNfHh':function(_0x2a87b9,_0x4603e2){return _0x2a87b9(_0x4603e2);}};if(!_0x4f2a9a||_0x254673['naihz'](typeof _0x4f2a9a,_0x254673['tOlov']))return _0x4f2a9a;const _0x24f1f7=['password',_0x13f2e4(0x1ec),_0x254673[_0x13f2e4(0x182)],'token',_0x13f2e4(0x1c6),'apikey','api_key',_0x254673[_0x13f2e4(0x198)],_0x254673['kGiOY'],_0x254673[_0x13f2e4(0x22f)],_0x254673['OtkWV'],'ssn',_0x254673[_0x13f2e4(0x1e2)],_0x13f2e4(0x212),_0x254673['wLHti'],'refresh_token','access_token'],_0x358bd4=Array['isArray'](_0x4f2a9a)?[..._0x4f2a9a]:{..._0x4f2a9a};for(const _0x1ac90 of Object[_0x13f2e4(0x206)](_0x358bd4)){const _0x18a03f=_0x1ac90[_0x13f2e4(0x186)]();if(_0x24f1f7['some'](_0x43bbdf=>_0x18a03f['includes'](_0x43bbdf)))_0x358bd4[_0x1ac90]=_0x254673['pGrja'];else typeof _0x358bd4[_0x1ac90]===_0x13f2e4(0x1f0)&&_0x358bd4[_0x1ac90]!==null&&(_0x358bd4[_0x1ac90]=_0x254673[_0x13f2e4(0x19c)](redactObject,_0x358bd4[_0x1ac90]));}return _0x358bd4;},logError=(_0x38e3a1,_0x1517fb={},_0x255caf=null)=>{const _0x5c923a=a0_0x1bfe63,_0x27311d={'RwhTs':_0x5c923a(0x1f5),'hbNjz':_0x5c923a(0x1fa),'ImLKw':function(_0x4c837e,_0x4b726d,_0x388c32){return _0x4c837e(_0x4b726d,_0x388c32);}},_0x297f2c={'event':_0x27311d['RwhTs'],'errorName':_0x38e3a1[_0x5c923a(0x19e)]||_0x27311d[_0x5c923a(0x1e3)],'errorMessage':_0x38e3a1['message'],'errorCode':_0x38e3a1[_0x5c923a(0x1ac)]||null,'stack':_0x38e3a1['stack'],..._0x1517fb},_0x594ba3=_0x255caf||_0x5c923a(0x205)+_0x38e3a1[_0x5c923a(0x1a5)];logger[_0x5c923a(0x1f5)](_0x297f2c,_0x594ba3),_0x27311d[_0x5c923a(0x239)](writeToFileLog,{..._0x297f2c,'level':'error','msg':_0x594ba3,'time':new Date()['toISOString']()},_0x27311d['RwhTs']);},logFatalError=(_0x33fd2a,_0x2ca48e={},_0x169702=null)=>{const _0x7b8602=a0_0x1bfe63,_0x99e9c={'event':'fatal_error','errorName':_0x33fd2a[_0x7b8602(0x19e)]||_0x7b8602(0x1fa),'errorMessage':_0x33fd2a['message'],'errorCode':_0x33fd2a['code']||null,'stack':_0x33fd2a['stack'],'severity':'CRITICAL',..._0x2ca48e},_0x1de159=_0x169702||_0x7b8602(0x22a)+_0x33fd2a[_0x7b8602(0x1a5)];logger['fatal'](_0x99e9c,_0x1de159),writeToFileLog({..._0x99e9c,'level':_0x7b8602(0x203),'msg':_0x1de159,'time':new Date()[_0x7b8602(0x224)]()},_0x7b8602(0x1f5));},logHttpError=(_0x1e9bb3,_0x824ade,_0x3c58f4={})=>{const _0x4d4ab0=a0_0x1bfe63,_0x2ad7da={'vtcsm':'user-agent','NcgBA':_0x4d4ab0(0x1c1),'ptkpE':function(_0x58455d,_0xcaa2fa){return _0x58455d(_0xcaa2fa);},'qKaud':function(_0x56f909,_0x26d046){return _0x56f909>=_0x26d046;},'glDLa':function(_0x4a2c40,_0x39a7ff){return _0x4a2c40>=_0x39a7ff;},'ohUsn':_0x4d4ab0(0x1f5)},_0x18e44e={'event':_0x4d4ab0(0x214),'errorName':_0x1e9bb3['name']||'Error','errorMessage':_0x1e9bb3['message'],'errorCode':_0x1e9bb3['code']||_0x1e9bb3[_0x4d4ab0(0x1f4)]||0x1f4,'stack':_0x1e9bb3['stack'],'method':_0x824ade?.[_0x4d4ab0(0x194)],'url':_0x824ade?.[_0x4d4ab0(0x215)]||_0x824ade?.['originalUrl'],'path':_0x824ade?.[_0x4d4ab0(0x190)],'ip':_0x824ade?.['ip']||_0x824ade?.['connection']?.['remoteAddress'],'userAgent':_0x824ade?.[_0x4d4ab0(0x1d4)]?.(_0x2ad7da['vtcsm']),'requestId':_0x824ade?.['id']||_0x824ade?.[_0x4d4ab0(0x1a8)]?.[_0x2ad7da[_0x4d4ab0(0x18a)]],'body':_0x824ade?.[_0x4d4ab0(0x1e0)]?_0x2ad7da['ptkpE'](redactObject,_0x824ade[_0x4d4ab0(0x1e0)]):undefined,'query':_0x824ade?.[_0x4d4ab0(0x23c)],..._0x3c58f4},_0x40d066=_0x1e9bb3['statusCode']||_0x1e9bb3[_0x4d4ab0(0x213)]||0x1f4,_0x1759e3='HTTP\x20'+_0x40d066+':\x20'+_0x1e9bb3[_0x4d4ab0(0x1a5)];_0x2ad7da[_0x4d4ab0(0x229)](_0x40d066,0x1f4)?logger[_0x4d4ab0(0x1f5)](_0x18e44e,_0x1759e3):logger['warn'](_0x18e44e,_0x1759e3),writeToFileLog({..._0x18e44e,'level':_0x2ad7da['glDLa'](_0x40d066,0x1f4)?_0x4d4ab0(0x1f5):'warn','msg':_0x1759e3,'time':new Date()[_0x4d4ab0(0x224)]()},_0x2ad7da[_0x4d4ab0(0x1ab)](_0x40d066,0x1f4)?_0x2ad7da[_0x4d4ab0(0x1f8)]:'warn');},logUncaughtError=(_0x421e93,_0x307d1f)=>{const _0x16a75c=a0_0x1bfe63,_0x29fce3={'spuWn':'Error','gdUfk':function(_0x4e2821,_0x1837e8,_0x4e0e6f){return _0x4e2821(_0x1837e8,_0x4e0e6f);},'viJRV':_0x16a75c(0x1f5)},_0x88269f={'event':_0x421e93,'errorName':_0x307d1f?.[_0x16a75c(0x19e)]||_0x29fce3[_0x16a75c(0x193)],'errorMessage':_0x307d1f?.['message']||String(_0x307d1f),'errorCode':_0x307d1f?.['code']||null,'stack':_0x307d1f?.['stack'],'severity':_0x16a75c(0x1ed),'processId':process[_0x16a75c(0x1e9)],'memoryUsage':process[_0x16a75c(0x1d5)](),'uptime':process[_0x16a75c(0x231)]()},_0x483338='['+_0x421e93['toUpperCase']()+']\x20'+(_0x307d1f?.['message']||_0x307d1f);logger['fatal'](_0x88269f,_0x483338),_0x29fce3['gdUfk'](writeToFileLog,{..._0x88269f,'level':_0x16a75c(0x203),'msg':_0x483338,'time':new Date()['toISOString']()},_0x29fce3[_0x16a75c(0x1ae)]);},setupGlobalErrorHandlers=()=>{const _0x38c2d1=a0_0x1bfe63,_0x3f7323={'oyeqr':function(_0x2d1d0d,_0x5eb8e8,_0x329913){return _0x2d1d0d(_0x5eb8e8,_0x329913);},'jBhqQ':function(_0x2de8ff,_0x2f0491,_0xf8f681){return _0x2de8ff(_0x2f0491,_0xf8f681);},'HtIMK':function(_0x1ee30c,_0x424cbe){return _0x1ee30c(_0x424cbe);},'OORng':_0x38c2d1(0x1f2)};process['on'](_0x38c2d1(0x1e7),_0x1fbbc8=>{const _0x139e0d=_0x38c2d1;_0x3f7323[_0x139e0d(0x1a2)](logUncaughtError,'uncaughtException',_0x1fbbc8),_0x3f7323['jBhqQ'](setTimeout,()=>{process['exit'](0x1);},0x3e8);}),process['on'](_0x38c2d1(0x1ce),(_0x359d82,_0x198cd4)=>{const _0x143d53=_0x359d82 instanceof Error?_0x359d82:new Error(_0x3f7323['HtIMK'](String,_0x359d82));_0x3f7323['jBhqQ'](logUncaughtError,'unhandledRejection',_0x143d53);}),process['on']('warning',_0x3f60d1=>{const _0x18667d=_0x38c2d1;logger[_0x18667d(0x1bf)]({'event':'process_warning','name':_0x3f60d1[_0x18667d(0x19e)],'message':_0x3f60d1['message'],'stack':_0x3f60d1['stack']},'Process\x20Warning:\x20'+_0x3f60d1['message']);});const _0x4fed47={'event':_0x38c2d1(0x185)},_0x3d3ed4=_0x38c2d1(0x1e1);logger[_0x38c2d1(0x1f2)](_0x4fed47,_0x3d3ed4),_0x3f7323['oyeqr'](writeToFileLog,{..._0x4fed47,'level':'info','msg':_0x3d3ed4,'time':new Date()['toISOString']()},_0x3f7323['OORng']);},createErrorHandlerMiddleware=()=>{const _0x17471d=a0_0x1bfe63,_0x1a7cb0={'iMHhz':function(_0x3a0fc8,_0x2f8ca3){return _0x3a0fc8>=_0x2f8ca3;},'HyDxs':_0x17471d(0x1c1)};return(_0x5895e8,_0x593192,_0x1d48cd,_0x1f0b63)=>{const _0x2e5c4b=_0x17471d;logHttpError(_0x5895e8,_0x593192);const _0x1fe934=_0x5895e8['statusCode']||_0x5895e8[_0x2e5c4b(0x213)]||0x1f4;_0x1d48cd[_0x2e5c4b(0x213)](_0x1fe934)[_0x2e5c4b(0x1ca)]({'success':![],'error':_0x1a7cb0['iMHhz'](_0x1fe934,0x1f4)?_0x2e5c4b(0x1aa):_0x5895e8['message'],'requestId':_0x593192['id']||_0x593192['headers']?.[_0x1a7cb0['HyDxs']]||null});};};module[a0_0x1bfe63(0x1cf)]={'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_0x3c2379=a0_0x1ad0;(function(_0x5d10ab,_0xb4cfc5){const _0x256e61=a0_0x1ad0,_0x5a674a=_0x5d10ab();while(!![]){try{const _0x29a2dc=parseInt(_0x256e61(0x1cc))/0x1+-parseInt(_0x256e61(0x214))/0x2+parseInt(_0x256e61(0x1c9))/0x3+-parseInt(_0x256e61(0x220))/0x4*(parseInt(_0x256e61(0x1df))/0x5)+-parseInt(_0x256e61(0x1cf))/0x6*(-parseInt(_0x256e61(0x1fb))/0x7)+-parseInt(_0x256e61(0x226))/0x8*(-parseInt(_0x256e61(0x1c8))/0x9)+-parseInt(_0x256e61(0x1ef))/0xa*(parseInt(_0x256e61(0x1eb))/0xb);if(_0x29a2dc===_0xb4cfc5)break;else _0x5a674a['push'](_0x5a674a['shift']());}catch(_0xc8d35b){_0x5a674a['push'](_0x5a674a['shift']());}}}(a0_0x5bec,0x98a7e));const pino=require(a0_0x3c2379(0x22a)),fs=require('fs'),path=require(a0_0x3c2379(0x238));let logToFile=![],logDir=a0_0x3c2379(0x261),serviceName='restforge',sqlLogEnabled=![],sqlLogLevel='debug',sqlLogParams=!![],sqlLogSlowThreshold=0x3e8,fileLoggingInitialized=![],appLogStream=null,errorLogStream=null;const prettyPrintOptions={'colorize':!![],'translateTime':'SYS:HH:MM:ss','ignore':'pid,hostname,service,version,env,event,module,port,config,apiKeyEnabled,path,workingDir,isPkg,isNodeScript,file,email,type,cors,logging,apiKey,count,endpoint,route','singleLine':![],'levelFirst':!![],'messageFormat':'{msg}','customColors':'info:blue,warn:yellow,error:red,debug:gray','hideObject':!![]},isDevelopment=process[a0_0x3c2379(0x20c)]['NODE_ENV']!=='production',logLevel=process[a0_0x3c2379(0x20c)][a0_0x3c2379(0x1ce)]||'info';let logger=pino({'level':logLevel,'transport':isDevelopment?{'target':'pino-pretty','options':prettyPrintOptions}:undefined,'base':{'service':'restforge','version':process['env']['APP_VERSION']||a0_0x3c2379(0x20f),'env':process[a0_0x3c2379(0x20c)][a0_0x3c2379(0x217)]||'development'},'timestamp':pino['stdTimeFunctions']['isoTime'],'redact':{'paths':['req.headers.authorization',a0_0x3c2379(0x22c),'password','token',a0_0x3c2379(0x231),a0_0x3c2379(0x1fd),a0_0x3c2379(0x1f5)],'censor':'[REDACTED]'},'serializers':{'req':_0x8c4666=>({'id':_0x8c4666['id'],'method':_0x8c4666[a0_0x3c2379(0x1e6)],'url':_0x8c4666[a0_0x3c2379(0x272)],'path':_0x8c4666[a0_0x3c2379(0x238)],'remoteAddress':_0x8c4666['ip']||_0x8c4666['connection']?.['remoteAddress']}),'res':_0x1f311b=>({'statusCode':_0x1f311b[a0_0x3c2379(0x25e)],'headers':_0x1f311b[a0_0x3c2379(0x202)]?.()}),'err':pino['stdSerializers'][a0_0x3c2379(0x225)]}});function initFileLogging(){const _0x3732a5=a0_0x3c2379,_0x371529={'DAefZ':function(_0x5cede1,_0x2c86df){return _0x5cede1===_0x2c86df;},'WgSpN':_0x3732a5(0x230),'BmiLH':'./logs','zWCZz':'restforge','teDpG':'false','YcBCC':function(_0x3f7115,_0x4f2fc4){return _0x3f7115(_0x4f2fc4);},'diJJt':_0x3732a5(0x1be),'KOJRa':_0x3732a5(0x22f),'tEeIw':'error.log','EWAGB':function(_0x5a3d18,_0x96bac1,_0x2403c9){return _0x5a3d18(_0x96bac1,_0x2403c9);},'phDTu':'info'};if(fileLoggingInitialized)return;logToFile=_0x371529['DAefZ'](process[_0x3732a5(0x20c)]['LOG_TO_FILE'],_0x371529['WgSpN']),logDir=process['env']['LOG_DIR']||_0x371529[_0x3732a5(0x245)],serviceName=process[_0x3732a5(0x20c)][_0x3732a5(0x1f2)]||_0x371529['zWCZz'],sqlLogEnabled=_0x371529['DAefZ'](process[_0x3732a5(0x20c)][_0x3732a5(0x1d5)],'true'),sqlLogLevel=process['env']['SQL_LOG_LEVEL']||'debug',sqlLogParams=process['env'][_0x3732a5(0x1c3)]!==_0x371529[_0x3732a5(0x1dd)],sqlLogSlowThreshold=_0x371529['YcBCC'](parseInt,process[_0x3732a5(0x20c)][_0x3732a5(0x1c5)])||0x3e8;if(!logToFile){fileLoggingInitialized=!![];return;}const _0x42f55e=path[_0x3732a5(0x26e)](process['cwd'](),logDir);try{!fs[_0x3732a5(0x273)](_0x42f55e)&&fs['mkdirSync'](_0x42f55e,{'recursive':!![]});}catch(_0x292e05){console[_0x3732a5(0x1e0)](_0x3732a5(0x216)+_0x42f55e+':',_0x292e05['message']),fileLoggingInitialized=!![];return;}const _0x5a1b27=path[_0x3732a5(0x1b9)](_0x42f55e,'app.log'),_0x2947fa=path[_0x3732a5(0x1b9)](_0x42f55e,'error.log');try{appLogStream=fs['createWriteStream'](_0x5a1b27,{'flags':'a'}),errorLogStream=fs[_0x3732a5(0x21f)](_0x2947fa,{'flags':'a'}),fileLoggingInitialized=!![];const _0xc294a6={'event':_0x371529[_0x3732a5(0x1d7)],'logDir':_0x42f55e,'files':[_0x371529[_0x3732a5(0x22b)],_0x371529[_0x3732a5(0x1bb)]]},_0x445ff0=_0x3732a5(0x240)+_0x42f55e;logger[_0x3732a5(0x221)](_0xc294a6,_0x445ff0),_0x371529['EWAGB'](writeToFileLog,{..._0xc294a6,'level':_0x371529[_0x3732a5(0x1db)],'msg':_0x445ff0,'time':new Date()['toISOString']()},'info');}catch(_0xed021a){console[_0x3732a5(0x1e0)]('Failed\x20to\x20create\x20log\x20streams:',_0xed021a['message']),fileLoggingInitialized=!![];}}function writeToFileLog(_0x22d7c7,_0x15c323){const _0x37bc2e=a0_0x3c2379,_0x769ca2={'FPNbd':function(_0x1ab355,_0x434bab){return _0x1ab355||_0x434bab;},'kQiLj':'error'};if(_0x769ca2[_0x37bc2e(0x218)](!logToFile,!appLogStream))return;const _0x2ba7b4={'service':serviceName,..._0x22d7c7},_0x5b92b5=JSON[_0x37bc2e(0x268)](_0x2ba7b4)+'\x0a';appLogStream[_0x37bc2e(0x1fc)](_0x5b92b5),(_0x15c323===_0x769ca2['kQiLj']||_0x15c323===_0x37bc2e(0x254))&&(errorLogStream&&errorLogStream['write'](_0x5b92b5));}const createRequestLogger=(_0x29000f={})=>{return logger['child'](_0x29000f);},logServerStart=_0x3d4093=>{const _0xa47595=a0_0x3c2379,_0x1e6c0c={'lkrfi':_0xa47595(0x221)},_0x5c84e4=_0xa47595(0x265)+(_0x3d4093[_0xa47595(0x23f)]||_0xa47595(0x1f9))[_0xa47595(0x206)](0x26)+'\x20║\x0a║\x20\x20Project\x20\x20\x20\x20\x20:\x20'+(_0x3d4093[_0xa47595(0x1cd)]||_0xa47595(0x266))[_0xa47595(0x206)](0x26)+_0xa47595(0x235)+String(_0x3d4093[_0xa47595(0x246)]||0xbb8)[_0xa47595(0x206)](0x26)+_0xa47595(0x1f3)+(_0x3d4093[_0xa47595(0x1e2)]||'Default')['padEnd'](0x26)+_0xa47595(0x24f)+(_0x3d4093[_0xa47595(0x231)]?'ACTIVE':'NOT\x20ACTIVE')[_0xa47595(0x206)](0x26)+_0xa47595(0x25c);console['log'](_0x5c84e4);const _0x2a60d9={'event':'server_starting','project':_0x3d4093[_0xa47595(0x1cd)],'port':_0x3d4093['port'],'config':_0x3d4093['configFile'],'apiKeyEnabled':!!_0x3d4093['apiKey']};logger['info'](_0x2a60d9),writeToFileLog({..._0x2a60d9,'level':_0x1e6c0c[_0xa47595(0x250)],'msg':'Server\x20starting:\x20'+_0x3d4093['project']+_0xa47595(0x1e1)+_0x3d4093['port'],'time':new Date()['toISOString']()},_0x1e6c0c[_0xa47595(0x250)]);},logServerReady=_0x852266=>{const _0x213d22=a0_0x3c2379,_0xf6831b={'tEfMh':function(_0x1a7cea,_0x5c6a48,_0x193d98){return _0x1a7cea(_0x5c6a48,_0x193d98);}},_0x33c669={'event':'server_ready','port':_0x852266[_0x213d22(0x246)],'module':_0x852266[_0x213d22(0x26a)],'healthCheck':_0x852266['healthCheck'],'serviceInfo':_0x852266[_0x213d22(0x1f0)],'baseUrl':_0x852266['baseUrl']},_0xf07c22=_0x213d22(0x260)+_0x852266['port'];logger['info'](_0x33c669,_0xf07c22),_0xf6831b['tEfMh'](writeToFileLog,{..._0x33c669,'level':'info','msg':_0xf07c22,'time':new Date()[_0x213d22(0x1d8)]()},'info'),_0x852266['healthCheck']&&logger['info']('\x20\x20Health:\x20'+_0x852266['healthCheck']),_0x852266['serviceInfo']&&logger['info']('\x20\x20Info:\x20\x20\x20'+_0x852266[_0x213d22(0x1f0)]),_0x852266['baseUrl']&&logger[_0x213d22(0x221)](_0x213d22(0x23d)+_0x852266['baseUrl']);},logProjectLoaded=(_0x4f4d90,_0x414eb7)=>{const _0x7fc852=a0_0x3c2379,_0xe5c657={'GPMKC':function(_0x4c9367,_0x2e7c3b,_0x5e93a1){return _0x4c9367(_0x2e7c3b,_0x5e93a1);}},_0x4ffb86={'event':'project_loaded','project':_0x4f4d90,'path':_0x414eb7},_0xdecab8=_0x7fc852(0x269)+_0x4f4d90;logger['info'](_0x4ffb86,_0xdecab8),_0xe5c657[_0x7fc852(0x1ed)](writeToFileLog,{..._0x4ffb86,'level':_0x7fc852(0x221),'msg':_0xdecab8,'time':new Date()['toISOString']()},'info');},logEndpointRegistered=(_0x77999,_0x16c982)=>{const _0x3741ce=a0_0x3c2379,_0x28f1e8={'MNViC':'endpoint_registered'},_0x315589={'event':_0x28f1e8['MNViC'],'endpoint':_0x77999,'route':_0x16c982},_0x386af0='\x20\x20→\x20'+_0x77999+':\x20'+_0x16c982;logger['debug'](_0x315589,_0x386af0),writeToFileLog({..._0x315589,'level':'debug','msg':_0x386af0,'time':new Date()[_0x3741ce(0x1d8)]()},'debug');},logDatabaseConfig=_0x518664=>{const _0x427e52=a0_0x3c2379,_0x8a1561={'RFKPS':'database_config','wxDRc':function(_0x1cd701,_0xf95aa0,_0xe88043){return _0x1cd701(_0xf95aa0,_0xe88043);},'yydYJ':'debug'},_0x42c944={'event':_0x8a1561[_0x427e52(0x223)],'host':_0x518664[_0x427e52(0x256)],'port':_0x518664[_0x427e52(0x246)],'database':_0x518664['database'],'type':_0x518664[_0x427e52(0x21b)],'user':_0x518664[_0x427e52(0x1f7)]},_0x3049d6='Database:\x20'+_0x518664['type']+'://'+_0x518664['host']+':'+_0x518664['port']+'/'+_0x518664['database'];logger[_0x427e52(0x1c4)](_0x42c944,_0x3049d6),_0x8a1561[_0x427e52(0x1c0)](writeToFileLog,{..._0x42c944,'level':_0x8a1561['yydYJ'],'msg':_0x3049d6,'time':new Date()['toISOString']()},_0x8a1561[_0x427e52(0x200)]);},logRequest=(_0x1882c9,_0x413695,_0x326e4c)=>{const _0x4f6ad8=a0_0x3c2379,_0x1f5c60={'dCkBd':_0x4f6ad8(0x221),'krEWk':function(_0x157248,_0x42b19c){return _0x157248>=_0x42b19c;},'kFxbB':'error','sopqH':function(_0x31f3c3,_0x1a419e){return _0x31f3c3>=_0x1a419e;},'YCbqn':'warn','DwgoN':function(_0x16212a,_0xc82408,_0x580eb7){return _0x16212a(_0xc82408,_0x580eb7);}},_0xd35b9b={'event':_0x4f6ad8(0x255),'method':_0x1882c9['method'],'path':_0x1882c9['path'],'statusCode':_0x413695['statusCode'],'durationMs':_0x326e4c,'ip':_0x1882c9['ip']},_0x42d8a5=_0x1882c9['method']+'\x20'+_0x1882c9['path']+'\x20-\x20'+_0x413695['statusCode']+'\x20('+_0x326e4c+'ms)';let _0x2d0174=_0x1f5c60[_0x4f6ad8(0x1c7)];if(_0x1f5c60[_0x4f6ad8(0x251)](_0x413695[_0x4f6ad8(0x25e)],0x1f4))_0x2d0174=_0x1f5c60[_0x4f6ad8(0x20e)],logger[_0x4f6ad8(0x1e0)](_0xd35b9b,_0x42d8a5);else _0x1f5c60[_0x4f6ad8(0x1f6)](_0x413695['statusCode'],0x190)?(_0x2d0174=_0x1f5c60[_0x4f6ad8(0x1d0)],logger['warn'](_0xd35b9b,_0x42d8a5)):logger[_0x4f6ad8(0x221)](_0xd35b9b,_0x42d8a5);_0x1f5c60['DwgoN'](writeToFileLog,{..._0xd35b9b,'level':_0x2d0174,'msg':_0x42d8a5,'time':new Date()[_0x4f6ad8(0x1d8)]()},_0x2d0174);},SENSITIVE_PARAM_PATTERNS=[a0_0x3c2379(0x242),a0_0x3c2379(0x249),a0_0x3c2379(0x234),'token','access_token',a0_0x3c2379(0x1ba),a0_0x3c2379(0x1c2),'api_secret','apikey',a0_0x3c2379(0x26b),'credential',a0_0x3c2379(0x23e),a0_0x3c2379(0x257),'otp',a0_0x3c2379(0x263),'privatekey'],redactSensitiveParams=(_0x3f4484,_0x465074)=>{const _0x570a27=a0_0x3c2379,_0x29caae={'XXKWW':_0x570a27(0x1f8),'OxEfM':function(_0x10ffb6,_0x54669e){return _0x10ffb6>_0x54669e;},'vUaxa':'[REDACTED:hash]'};if(!_0x3f4484||_0x3f4484[_0x570a27(0x1d9)]===0x0)return _0x3f4484;const _0x44d339=_0x465074[_0x570a27(0x1de)](),_0x4ac7cf=_0x44d339[_0x570a27(0x1bf)](/\(([^)]+)\)\s*values/i);let _0x354463=[];_0x4ac7cf&&(_0x354463=_0x4ac7cf[0x1]['split'](',')[_0x570a27(0x22e)](_0x394c15=>_0x394c15[_0x570a27(0x1ca)]()['toLowerCase']()));const _0xef1875=_0x44d339['match'](/set\s+(.+?)(?:\s+where|$)/i);if(_0xef1875){const _0x3c3926=_0xef1875[0x1],_0x2f9c38=_0x3c3926['match'](/(\w+)\s*=/g);_0x2f9c38&&(_0x354463=_0x2f9c38['map'](_0x38751f=>_0x38751f[_0x570a27(0x1f4)](/\s*=/,'')['trim']()[_0x570a27(0x1de)]()));}return _0x3f4484['map']((_0x234719,_0x37bfcf)=>{const _0x4d8de1=_0x570a27;if(_0x354463[_0x37bfcf]){const _0x3a5977=_0x354463[_0x37bfcf],_0x453ad1=SENSITIVE_PARAM_PATTERNS['some'](_0x324d8f=>_0x3a5977['includes'](_0x324d8f));if(_0x453ad1)return _0x29caae[_0x4d8de1(0x262)];}if(typeof _0x234719==='string'&&_0x29caae['OxEfM'](_0x234719[_0x4d8de1(0x1d9)],0x20)){if(/^[a-zA-Z0-9+/=_.-]+$/[_0x4d8de1(0x23a)](_0x234719)&&_0x234719[_0x4d8de1(0x1f1)]('.'))return _0x4d8de1(0x1fe);if(/^[a-fA-F0-9]{32,}$/['test'](_0x234719))return _0x29caae['vUaxa'];}return _0x234719;});},parseQueryMetadata=_0x26192d=>{const _0x1444fa=a0_0x3c2379,_0x39a2d8={'NeliI':_0x1444fa(0x203),'owSzM':'INSERT','QdMBN':_0x1444fa(0x1ee),'ucoHT':_0x1444fa(0x207)},_0x222c7d=_0x26192d['trim'](),_0x37fe27=_0x222c7d[_0x1444fa(0x232)]();let _0x341d19=_0x1444fa(0x237),_0x3a8106=null;if(_0x37fe27['startsWith']('SELECT')){_0x341d19=_0x39a2d8['NeliI'];const _0x453d21=_0x222c7d[_0x1444fa(0x1bf)](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x3a8106=_0x453d21?_0x453d21[0x1]:null;}else{if(_0x37fe27[_0x1444fa(0x26c)]('INSERT')){_0x341d19=_0x39a2d8['owSzM'];const _0x433b70=_0x222c7d[_0x1444fa(0x1bf)](/INTO\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x3a8106=_0x433b70?_0x433b70[0x1]:null;}else{if(_0x37fe27[_0x1444fa(0x26c)](_0x1444fa(0x23c))){_0x341d19='UPDATE';const _0x586f9f=_0x222c7d[_0x1444fa(0x1bf)](/UPDATE\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x3a8106=_0x586f9f?_0x586f9f[0x1]:null;}else{if(_0x37fe27['startsWith']('DELETE')){_0x341d19=_0x1444fa(0x205);const _0x10d63e=_0x222c7d[_0x1444fa(0x1bf)](/FROM\s+["']?([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)?)["']?/i);_0x3a8106=_0x10d63e?_0x10d63e[0x1]:null;}else{if(_0x37fe27[_0x1444fa(0x26c)](_0x1444fa(0x26d))||_0x37fe27[_0x1444fa(0x26c)]('START\x20TRANSACTION'))_0x341d19=_0x39a2d8[_0x1444fa(0x264)];else{if(_0x37fe27['startsWith'](_0x39a2d8[_0x1444fa(0x247)]))_0x341d19='TRANSACTION_COMMIT';else{if(_0x37fe27['startsWith'](_0x1444fa(0x24d)))_0x341d19='TRANSACTION_ROLLBACK';else{if(_0x37fe27[_0x1444fa(0x26c)]('CREATE'))_0x341d19=_0x1444fa(0x20b);else{if(_0x37fe27[_0x1444fa(0x26c)]('ALTER'))_0x341d19=_0x1444fa(0x1ea);else _0x37fe27[_0x1444fa(0x26c)](_0x1444fa(0x1e7))&&(_0x341d19=_0x1444fa(0x25a));}}}}}}}}return{'type':_0x341d19,'table':_0x3a8106};},startQueryTimer=()=>{const _0x50d04c=a0_0x3c2379,_0x19d8eb={'mrdFh':function(_0x4dcff8,_0x51b562){return _0x4dcff8/_0x51b562;}},_0x5f3971=process[_0x50d04c(0x228)]();return()=>{const _0x27c541=_0x50d04c,[_0x3ad8c9,_0x18cfea]=process[_0x27c541(0x228)](_0x5f3971);return parseFloat((_0x3ad8c9*0x3e8+_0x19d8eb[_0x27c541(0x233)](_0x18cfea,0xf4240))['toFixed'](0x2));};},logQuery=(_0x324975,_0x4616a8=[],_0x436c8d={})=>{const _0x1d720d=a0_0x3c2379,_0x116747={'nBgVM':'postgresql','Wqcub':function(_0x38cdac,_0x1228b6){return _0x38cdac(_0x1228b6);},'tBYXX':function(_0x54d784,_0x202ace){return _0x54d784>_0x202ace;},'IPPkn':function(_0x7364d,_0x99aa2e,_0x35374e){return _0x7364d(_0x99aa2e,_0x35374e);},'PcqBh':function(_0x1ebff9,_0x3e55d7){return _0x1ebff9!==_0x3e55d7;},'UmmoZ':function(_0x42bc01,_0x48d4c0){return _0x42bc01===_0x48d4c0;}};if(!sqlLogEnabled){logger[_0x1d720d(0x1c4)]({'event':'db_query','query':_0x324975[_0x1d720d(0x1fa)](0x0,0xc8),'paramCount':_0x4616a8[_0x1d720d(0x1d9)]},_0x1d720d(0x1c1));return;}const {duration:duration=null,rowsAffected:rowsAffected=null,dbType:dbType=_0x116747[_0x1d720d(0x24a)]}=_0x436c8d,{type:_0x252636,table:_0x1a37d6}=_0x116747[_0x1d720d(0x1ec)](parseQueryMetadata,_0x324975),_0x42355b={'event':_0x1d720d(0x21c),'queryType':_0x252636,'table':_0x1a37d6,'query':_0x324975,'paramCount':_0x4616a8[_0x1d720d(0x1d9)],'dbType':dbType};sqlLogParams&&_0x116747['tBYXX'](_0x4616a8['length'],0x0)&&(_0x42355b['params']=_0x116747['IPPkn'](redactSensitiveParams,_0x4616a8,_0x324975));_0x116747[_0x1d720d(0x23b)](duration,null)&&(_0x42355b[_0x1d720d(0x1da)]=duration,_0x42355b['isSlow']=duration>sqlLogSlowThreshold);rowsAffected!==null&&(_0x42355b['rowsAffected']=rowsAffected);const _0x5b0dc7=_0x1a37d6||'unknown';let _0x50e992='['+_0x252636+']\x20'+_0x5b0dc7;duration!==null&&(_0x50e992+='\x20('+duration+'ms)');const _0x2561f2=_0x116747['PcqBh'](duration,null)&&_0x116747[_0x1d720d(0x210)](duration,sqlLogSlowThreshold);let _0x1d2274=_0x1d720d(0x1c4);if(_0x2561f2)_0x50e992+='\x20[SLOW]',_0x1d2274='warn',logger[_0x1d720d(0x267)](_0x42355b,_0x50e992);else _0x116747['UmmoZ'](sqlLogLevel,_0x1d720d(0x221))?(_0x1d2274='info',logger[_0x1d720d(0x221)](_0x42355b,_0x50e992)):logger['debug'](_0x42355b,_0x50e992);writeToFileLog({..._0x42355b,'level':_0x1d2274,'msg':_0x50e992,'time':new Date()['toISOString']()},_0x1d2274);},logTransaction=(_0x582156,_0x14215f)=>{const _0x4940a2=a0_0x3c2379,_0x5bbc44={'pnhFE':_0x4940a2(0x1c4)},_0x531cc9={'event':_0x4940a2(0x20a),'status':_0x582156,'queryCount':_0x14215f},_0x32d988='Transaction\x20'+_0x582156;logger['debug'](_0x531cc9,_0x32d988),writeToFileLog({..._0x531cc9,'level':_0x5bbc44[_0x4940a2(0x1dc)],'msg':_0x32d988,'time':new Date()[_0x4940a2(0x1d8)]()},_0x4940a2(0x1c4));},redactObject=_0x567956=>{const _0x453ce0=a0_0x3c2379,_0xef7f8={'rmVVA':function(_0x6a075a,_0x29a9e3){return _0x6a075a!==_0x29a9e3;},'qgaBM':'secret','Mumar':_0x453ce0(0x26b),'jYMit':'authorization','sFLRB':_0x453ce0(0x1d1),'Kzpjc':_0x453ce0(0x248),'zzKIJ':_0x453ce0(0x22d),'xwPxb':_0x453ce0(0x1c6),'kotsf':_0x453ce0(0x257),'SYgqr':_0x453ce0(0x263),'mzUiN':'privatekey','Abiqj':function(_0x14b56f,_0x57df2d){return _0x14b56f(_0x57df2d);}};if(!_0x567956||_0xef7f8['rmVVA'](typeof _0x567956,'object'))return _0x567956;const _0x501477=[_0x453ce0(0x242),'passwd','pwd',_0x453ce0(0x1d4),_0xef7f8['qgaBM'],_0x453ce0(0x239),_0xef7f8[_0x453ce0(0x236)],_0xef7f8[_0x453ce0(0x26f)],_0xef7f8[_0x453ce0(0x204)],_0xef7f8[_0x453ce0(0x215)],_0xef7f8[_0x453ce0(0x227)],_0xef7f8[_0x453ce0(0x229)],_0xef7f8[_0x453ce0(0x1e4)],_0xef7f8['SYgqr'],_0xef7f8[_0x453ce0(0x1bd)],_0x453ce0(0x1ba),'access_token'],_0xfececd=Array['isArray'](_0x567956)?[..._0x567956]:{..._0x567956};for(const _0x1d20fa of Object['keys'](_0xfececd)){const _0x1b38f6=_0x1d20fa['toLowerCase']();if(_0x501477[_0x453ce0(0x219)](_0x1688bd=>_0x1b38f6['includes'](_0x1688bd)))_0xfececd[_0x1d20fa]=_0x453ce0(0x1f8);else typeof _0xfececd[_0x1d20fa]==='object'&&_0xfececd[_0x1d20fa]!==null&&(_0xfececd[_0x1d20fa]=_0xef7f8['Abiqj'](redactObject,_0xfececd[_0x1d20fa]));}return _0xfececd;},logError=(_0x58f057,_0x48a68d={},_0xed9111=null)=>{const _0x3dffb2=a0_0x3c2379,_0x38a987={'nTbXj':_0x3dffb2(0x1e0)},_0x1e6a31={'event':'error','errorName':_0x58f057[_0x3dffb2(0x20d)]||'Error','errorMessage':_0x58f057[_0x3dffb2(0x208)],'errorCode':_0x58f057['code']||null,'stack':_0x58f057[_0x3dffb2(0x1e3)],..._0x48a68d},_0x12e253=_0xed9111||_0x3dffb2(0x21a)+_0x58f057['message'];logger[_0x3dffb2(0x1e0)](_0x1e6a31,_0x12e253),writeToFileLog({..._0x1e6a31,'level':_0x3dffb2(0x1e0),'msg':_0x12e253,'time':new Date()['toISOString']()},_0x38a987[_0x3dffb2(0x224)]);},logFatalError=(_0x4745bf,_0x19bad4={},_0x103c29=null)=>{const _0x3ee6c2=a0_0x3c2379,_0x13a41e={'raxtQ':_0x3ee6c2(0x1ff),'yXZqu':'Error','iLIfw':_0x3ee6c2(0x1cb),'MASAa':function(_0x1e6dc6,_0x4d447e,_0x241047){return _0x1e6dc6(_0x4d447e,_0x241047);},'bbbEk':_0x3ee6c2(0x254)},_0x4b0d94={'event':_0x13a41e[_0x3ee6c2(0x21d)],'errorName':_0x4745bf['name']||_0x13a41e['yXZqu'],'errorMessage':_0x4745bf['message'],'errorCode':_0x4745bf[_0x3ee6c2(0x211)]||null,'stack':_0x4745bf['stack'],'severity':_0x13a41e[_0x3ee6c2(0x201)],..._0x19bad4},_0x49897f=_0x103c29||_0x3ee6c2(0x24b)+_0x4745bf[_0x3ee6c2(0x208)];logger['fatal'](_0x4b0d94,_0x49897f),_0x13a41e['MASAa'](writeToFileLog,{..._0x4b0d94,'level':_0x13a41e[_0x3ee6c2(0x24c)],'msg':_0x49897f,'time':new Date()[_0x3ee6c2(0x1d8)]()},_0x3ee6c2(0x1e0));},logHttpError=(_0x4ba225,_0x444bbc,_0x58db30={})=>{const _0x1d0eda=a0_0x3c2379,_0x1205b8={'pQnfm':_0x1d0eda(0x1d6),'nnLBe':function(_0x3f8c2a,_0x4a6109){return _0x3f8c2a(_0x4a6109);},'kUWql':function(_0x16c894,_0x49e8fa){return _0x16c894>=_0x49e8fa;}},_0x8a6049={'event':_0x1205b8[_0x1d0eda(0x271)],'errorName':_0x4ba225[_0x1d0eda(0x20d)]||'Error','errorMessage':_0x4ba225['message'],'errorCode':_0x4ba225[_0x1d0eda(0x211)]||_0x4ba225['statusCode']||0x1f4,'stack':_0x4ba225[_0x1d0eda(0x1e3)],'method':_0x444bbc?.[_0x1d0eda(0x1e6)],'url':_0x444bbc?.['url']||_0x444bbc?.['originalUrl'],'path':_0x444bbc?.['path'],'ip':_0x444bbc?.['ip']||_0x444bbc?.['connection']?.[_0x1d0eda(0x222)],'userAgent':_0x444bbc?.[_0x1d0eda(0x258)]?.('user-agent'),'requestId':_0x444bbc?.['id']||_0x444bbc?.['headers']?.[_0x1d0eda(0x243)],'body':_0x444bbc?.['body']?_0x1205b8['nnLBe'](redactObject,_0x444bbc['body']):undefined,'query':_0x444bbc?.[_0x1d0eda(0x21e)],..._0x58db30},_0x1b1214=_0x4ba225['statusCode']||_0x4ba225[_0x1d0eda(0x259)]||0x1f4,_0x53f968='HTTP\x20'+_0x1b1214+':\x20'+_0x4ba225['message'];_0x1205b8['kUWql'](_0x1b1214,0x1f4)?logger[_0x1d0eda(0x1e0)](_0x8a6049,_0x53f968):logger['warn'](_0x8a6049,_0x53f968),writeToFileLog({..._0x8a6049,'level':_0x1b1214>=0x1f4?_0x1d0eda(0x1e0):_0x1d0eda(0x267),'msg':_0x53f968,'time':new Date()[_0x1d0eda(0x1d8)]()},_0x1b1214>=0x1f4?'error':'warn');},logUncaughtError=(_0x7e789b,_0x3125a2)=>{const _0x5bd1ce=a0_0x3c2379,_0x2cb99d={'dyLqp':_0x5bd1ce(0x24e),'IQUop':function(_0x3d1b1f,_0x1017b9){return _0x3d1b1f(_0x1017b9);},'oidXE':'fatal','MYkoH':'error'},_0x2b7a95={'event':_0x7e789b,'errorName':_0x3125a2?.[_0x5bd1ce(0x20d)]||_0x2cb99d['dyLqp'],'errorMessage':_0x3125a2?.['message']||_0x2cb99d[_0x5bd1ce(0x253)](String,_0x3125a2),'errorCode':_0x3125a2?.['code']||null,'stack':_0x3125a2?.[_0x5bd1ce(0x1e3)],'severity':'CRITICAL','processId':process[_0x5bd1ce(0x25b)],'memoryUsage':process['memoryUsage'](),'uptime':process['uptime']()},_0xc95f26='['+_0x7e789b['toUpperCase']()+']\x20'+(_0x3125a2?.['message']||_0x3125a2);logger[_0x5bd1ce(0x254)](_0x2b7a95,_0xc95f26),writeToFileLog({..._0x2b7a95,'level':_0x2cb99d[_0x5bd1ce(0x209)],'msg':_0xc95f26,'time':new Date()[_0x5bd1ce(0x1d8)]()},_0x2cb99d[_0x5bd1ce(0x1bc)]);},setupGlobalErrorHandlers=()=>{const _0x12818d=a0_0x3c2379,_0x270250={'eTpAt':function(_0x5117e9,_0x2f599d){return _0x5117e9 instanceof _0x2f599d;},'VwBrQ':function(_0x27f782,_0x31d761){return _0x27f782(_0x31d761);},'YKtBO':function(_0x676feb,_0x204664,_0x2baa5d){return _0x676feb(_0x204664,_0x2baa5d);},'boHdU':'unhandledRejection','XeYGj':'process_warning','mtcdq':_0x12818d(0x252),'XdGEk':_0x12818d(0x221)};process['on'](_0x12818d(0x1d2),_0x54d550=>{const _0x599633=_0x12818d;logUncaughtError(_0x599633(0x1d2),_0x54d550),setTimeout(()=>{const _0x447800=_0x599633;process[_0x447800(0x25d)](0x1);},0x3e8);}),process['on']('unhandledRejection',(_0x23a60a,_0x2bcfbc)=>{const _0x3138d4=_0x12818d,_0xf1ae27=_0x270250[_0x3138d4(0x1e9)](_0x23a60a,Error)?_0x23a60a:new Error(_0x270250[_0x3138d4(0x212)](String,_0x23a60a));_0x270250[_0x3138d4(0x1d3)](logUncaughtError,_0x270250[_0x3138d4(0x1e8)],_0xf1ae27);}),process['on']('warning',_0x4f8194=>{const _0x19bee1=_0x12818d;logger[_0x19bee1(0x267)]({'event':_0x270250[_0x19bee1(0x244)],'name':_0x4f8194['name'],'message':_0x4f8194['message'],'stack':_0x4f8194[_0x19bee1(0x1e3)]},_0x19bee1(0x270)+_0x4f8194['message']);});const _0x102420={'event':'global_error_handlers_setup'},_0x27ba7c=_0x270250['mtcdq'];logger[_0x12818d(0x221)](_0x102420,_0x27ba7c),writeToFileLog({..._0x102420,'level':_0x270250['XdGEk'],'msg':_0x27ba7c,'time':new Date()[_0x12818d(0x1d8)]()},_0x270250[_0x12818d(0x25f)]);},createErrorHandlerMiddleware=()=>{const _0x170194={'BRAcw':function(_0x3d194d,_0x3c723a,_0x583802){return _0x3d194d(_0x3c723a,_0x583802);},'PRodk':function(_0x12ff26,_0x5d0633){return _0x12ff26>=_0x5d0633;}};return(_0x17f282,_0x1927f8,_0x578c4e,_0x49629e)=>{const _0x44a9ac=a0_0x1ad0;_0x170194[_0x44a9ac(0x241)](logHttpError,_0x17f282,_0x1927f8);const _0x3fd62c=_0x17f282[_0x44a9ac(0x25e)]||_0x17f282[_0x44a9ac(0x259)]||0x1f4;_0x578c4e['status'](_0x3fd62c)['json']({'success':![],'error':_0x170194['PRodk'](_0x3fd62c,0x1f4)?_0x44a9ac(0x1e5):_0x17f282['message'],'requestId':_0x1927f8['id']||_0x1927f8[_0x44a9ac(0x213)]?.[_0x44a9ac(0x243)]||null});};};function a0_0x5bec(){const _0x4d0561=['zxjY','ndu0mduXmKrmBhvMEq','ENPlsuO','Ahj0Aw1L','EhDqEgi','CgLUBW','s09kuMe','CMvXlMHLywrLCNnBiNGTyxbPlwTLEsjD','y3z2','BwfW','yxbWlMXVzW','Dhj1zq','yxbPs2v5','Dg9vChbLCKnHC2u','BxjKrMG','ChDK','iokvKqRILzeGifbVCNqGicaGicaGidOG','txvTyxi','vu5ltK9xtG','Cgf0Aa','yxbPA2v5','DgvZDa','ugnXqMG','vvbeqvrf','icbvuKW6icaGia','y3jLzgvUDgLHBhm','zw52AxjVBM1LBNq','rMLSzsbSB2DNAw5NigvUywjSzwq6ia','qLjby3C','CgfZC3DVCMq','Ec1Yzxf1zxn0lwLK','wgvzr2O','qM1PteG','Cg9YDa','DwnVsfq','y3jLzgL0x2nHCMq','CgfZC3DK','BKjNvK0','rKfuquW6ia','yMjIrwS','uK9mtejbq0S','rxjYB3i','iokvKqRILzeGiefqssblzxKGicaGidOG','BgTYzMK','A3jfv2S','r2XVyMfSigvYCM9YigHHBMrSzxjZigLUAxrPywXPEMvK','svfvB3a','zMf0ywW','Ahr0Cf9Yzxf1zxn0','Ag9ZDa','CgLU','z2v0','C3rHDhvZ','rermx0rst1a','CgLK','iokvKqRILzRILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILzdILz0','zxHPDa','C3rHDhvZq29Kzq','wgrhrwS','w09lxsbtzxj2zxiGCMvHzhKGB24GCg9YDca','lI9SB2DZ','wfHlv1C','ChjPDMf0zv9RzxK','uwrnqK4','cUkvLokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvLWRILzeGicaGicaGicaGicaGifjfu1rgt1jhrsbsvu5usu1fifnfuLzfuIaGicaGicaGicaGicaGicaG4PwrcUkvOokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvKokvOWRILzeGievUDMLYB25Tzw50idOG','tI9b','D2fYBG','C3rYAw5NAwz5','w09lxsbqCM9Qzwn0igXVywrLzdOG','Bw9KDwXL','yxbPx2TLEq','C3rHCNrZv2L0Aa','qKvhsu4','CMvZB2X2zq','ALLnAxq','uhjVy2vZCYbxyxjUAw5NoIa','CffUzM0','DxjS','zxHPC3rZu3LUyW','AM9PBG','CMvMCMvZAf90B2TLBG','DevLsxC','tvLRB0G','BxPvAu4','zMLSzv9SB2DNAw5Nx2vUywjSzwq','Bwf0y2G','D3HeuMm','reiGuxvLCNK','C2vJCMv0','u1fmx0Xpr19qqvjbtvm','zgvIDwC','u1fmx0Xpr19tte9xx1riuKvtse9mra','C3nU','zenRqMq','oxHtCMDTtG','nJy4nJG4rhHSA051','DhjPBq','q1jjveLdquW','mteWotm2mLvHuu1MvW','ChjVAMvJDa','te9hx0XfvKvm','ndq4otyYwu5Rqvb0','wunICw4','y3jLzgL0y2fYza','Dw5JyxvNAhrfEgnLChrPB24','wuT0qK8','Dg9Rzw4','u1fmx0Xpr19ftKfcteve','Ahr0Cf9LCNjVCG','zgLksNq','Dg9ju09tDhjPBMC','BgvUz3rO','zhvYyxrPB25nCW','CgHevhu','Cg5OrKu','DgveCeC','Dg9mB3DLCKnHC2u','mZaWnJuYnu9jDMTgvG','zxjYB3i','ig9UihbVCNqG','y29UzMLNrMLSzq','C3rHy2S','A290C2y','sw50zxjUywWGC2vYDMvYigvYCM9Y','Bwv0Ag9K','rfjpua','yM9izfu','zvrWqxq','rermx0fmvevs','mZu3nw55v3LZAq','v3fJDwi','r1bns0m','vfjbtLnbq1rjt05FqKvhsu4','mty4mtb5q0X4qLG','C2vYDMLJzuLUzM8','Aw5JBhvKzxm','u0vsvKLdrv9oqu1f','iokvKqRILzeGienVBMzPzYaGicaGidOG','CMvWBgfJzq','sLDux1nfq1jfva','C29WCuG','DxnLCG','w1jfrefdvevexq','tM9Kzs5QCW','C3vIC3rYAw5N','otfIsLbQs0O','D3jPDgu','rejFueftu1DpuKq','w1jfrefdveveoNrVA2vUxq','zMf0ywXFzxjYB3i','ExLKwuO','AuXjzNC','z2v0sgvHzgvYCW','u0vmrunu','C0zmuKi','revmrvrf','CgfKrw5K','q09ntuLu','BwvZC2fNzq','B2LKweu','zgjFDhjHBNnHy3rPB24','rermx0nsrufurq','zw52','BMfTzq','A0z4yKi','ms4WlJu','DejzwfG','y29Kzq','vNDcCLe','AgvHzgvYCW','otK2nZiWB1nUqMrr','s3PWAMm','rMfPBgvKihrVignYzwf0zsbSB2CGzgLYzwn0B3j5ia','tK9erv9ftLy','rLboyMq','C29Tzq','rxjYB3i6ia','DhLWzq','C3fSx3f1zxj5','CMf4Dfe','CxvLCNK','y3jLyxrLv3jPDgvtDhjLyw0','oefPvuT0wq','Aw5MBW','CMvTB3rLqwrKCMvZCW','uKzlufm','BLrIwgO'];a0_0x5bec=function(){return _0x4d0561;};return a0_0x5bec();}function a0_0x1ad0(_0x2b7a44,_0x34c47d){_0x2b7a44=_0x2b7a44-0x1b9;const _0x5bec31=a0_0x5bec();let _0x1ad01b=_0x5bec31[_0x2b7a44];if(a0_0x1ad0['uCVvbU']===undefined){var _0x597f5b=function(_0x553a29){const _0xac0f6c='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1d787f='',_0x33841a='';for(let _0xf8d4=0x0,_0x3f523c,_0x2870b4,_0x289302=0x0;_0x2870b4=_0x553a29['charAt'](_0x289302++);~_0x2870b4&&(_0x3f523c=_0xf8d4%0x4?_0x3f523c*0x40+_0x2870b4:_0x2870b4,_0xf8d4++%0x4)?_0x1d787f+=String['fromCharCode'](0xff&_0x3f523c>>(-0x2*_0xf8d4&0x6)):0x0){_0x2870b4=_0xac0f6c['indexOf'](_0x2870b4);}for(let _0x54500f=0x0,_0x30c6e4=_0x1d787f['length'];_0x54500f<_0x30c6e4;_0x54500f++){_0x33841a+='%'+('00'+_0x1d787f['charCodeAt'](_0x54500f)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x33841a);};a0_0x1ad0['jdssUP']=_0x597f5b,a0_0x1ad0['LBvaEg']={},a0_0x1ad0['uCVvbU']=!![];}const _0x2b8519=_0x5bec31[0x0],_0x449ec4=_0x2b7a44+_0x2b8519,_0x5272e6=a0_0x1ad0['LBvaEg'][_0x449ec4];return!_0x5272e6?(_0x1ad01b=a0_0x1ad0['jdssUP'](_0x1ad01b),a0_0x1ad0['LBvaEg'][_0x449ec4]=_0x1ad01b):_0x1ad01b=_0x5272e6,_0x1ad01b;}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}};
@@ -1 +1 @@
1
- function a0_0x4a9e(_0x4b3b0e,_0x261737){_0x4b3b0e=_0x4b3b0e-0x151;const _0x58c667=a0_0x58c6();let _0x4a9ef9=_0x58c667[_0x4b3b0e];if(a0_0x4a9e['XsZHZD']===undefined){var _0x114394=function(_0x292958){const _0x234aae='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x131438='',_0x289c83='';for(let _0x308180=0x0,_0x405602,_0x437ed9,_0x62f5ff=0x0;_0x437ed9=_0x292958['charAt'](_0x62f5ff++);~_0x437ed9&&(_0x405602=_0x308180%0x4?_0x405602*0x40+_0x437ed9:_0x437ed9,_0x308180++%0x4)?_0x131438+=String['fromCharCode'](0xff&_0x405602>>(-0x2*_0x308180&0x6)):0x0){_0x437ed9=_0x234aae['indexOf'](_0x437ed9);}for(let _0x150899=0x0,_0x198740=_0x131438['length'];_0x150899<_0x198740;_0x150899++){_0x289c83+='%'+('00'+_0x131438['charCodeAt'](_0x150899)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x289c83);};a0_0x4a9e['tdBmIW']=_0x114394,a0_0x4a9e['opaOar']={},a0_0x4a9e['XsZHZD']=!![];}const _0x220dbe=_0x58c667[0x0],_0x54dce5=_0x4b3b0e+_0x220dbe,_0x1df64d=a0_0x4a9e['opaOar'][_0x54dce5];return!_0x1df64d?(_0x4a9ef9=a0_0x4a9e['tdBmIW'](_0x4a9ef9),a0_0x4a9e['opaOar'][_0x54dce5]=_0x4a9ef9):_0x4a9ef9=_0x1df64d,_0x4a9ef9;}function a0_0x58c6(){const _0x476ac4=['zgvIDwC','ugf5Bg9HzcbSB2fKzwqGC3vJy2vZC2z1BgX5','Cgf5Bg9Hzf9SB2fKx2vYCM9Y','Cgf5Bg9HzerPCG','zxjYB3i','y29SDw1UrM9YBwf0CW','y2XLyxi','mtyXmJG3n3LYzLzRqG','BwvZC2fNzq','mJaYzhPKA1nx','lMPZB24','mJaYnJC1mMPmAxfqzG','zxHWB3j0CW','yxHJvNa','mtC1ntGYog5zrvLPsa','ntq3oxvlBMPJtG','mJrUDhPZwxG','A3ryz1e','Cgf0Aa','Cgf5Bg9Hzf9SB2fKzwq','z2v0','DxrMoa','Cgf5Bg9HzdO','Cvfdv1i','AgfZ','lI4VlI4VCgf5Bg9Hza','zMLLBgrmywjLBhm','s0f6wu8','AM9PBG','zgf0yxrHyMXLC1f1zxj5','DgfIBgvoyw1L','mZa5mtmXmfHIrvnYzW','Cgf5Bg9Hzf9JywnOzv9JBgvHCMvK','mtaZmdu0ndf2wLDoDxG','nZC0mde2offyq2TIEa','y2fJAgu','rMfPBgvKihrVigXVywqGCgf5Bg9HzcbIEsbUyw1L','ugf5Bg9HzcbJywnOzsbJBgvHCMvK','Bg9HzfbHEwXVywq','CMvHzezPBgu','y2XLyxjdywnOzq','zMLLBgroyw1L'];a0_0x58c6=function(){return _0x476ac4;};return a0_0x58c6();}const a0_0x4d7fd1=a0_0x4a9e;(function(_0xc3781c,_0x34b1de){const _0x173c7f=a0_0x4a9e,_0x2d59e2=_0xc3781c();while(!![]){try{const _0x112dd2=parseInt(_0x173c7f(0x152))/0x1*(parseInt(_0x173c7f(0x176))/0x2)+parseInt(_0x173c7f(0x151))/0x3+-parseInt(_0x173c7f(0x178))/0x4+parseInt(_0x173c7f(0x162))/0x5+parseInt(_0x173c7f(0x153))/0x6*(-parseInt(_0x173c7f(0x174))/0x7)+-parseInt(_0x173c7f(0x165))/0x8+parseInt(_0x173c7f(0x164))/0x9;if(_0x112dd2===_0x34b1de)break;else _0x2d59e2['push'](_0x2d59e2['shift']());}catch(_0x3f0165){_0x2d59e2['push'](_0x2d59e2['shift']());}}}(a0_0x58c6,0x7b901));const fs=require('fs')['promises'],path=require(a0_0x4d7fd1(0x155)),{logger}=require('./logger');class PayloadLoader{constructor(){const _0x4cfc34=a0_0x4d7fd1;this['payloadDir']=path['join'](__dirname,_0x4cfc34(0x15c)),this[_0x4cfc34(0x166)]=new Map();}async[a0_0x4d7fd1(0x169)](_0x447787,_0x3bcb71){const _0x25414a=a0_0x4d7fd1,_0x444636={'qQCWR':'payload_loaded','LGcqY':_0x25414a(0x16e),'tsUyC':_0x25414a(0x16f),'QeIEQ':'Failed\x20to\x20load\x20payload'},_0x20314b=_0x447787+':'+_0x3bcb71;if(this['cache'][_0x25414a(0x15b)](_0x20314b))return this[_0x25414a(0x166)][_0x25414a(0x157)](_0x20314b);const _0x131ac8=path[_0x25414a(0x15f)](this['payloadDir'],_0x447787+'_'+_0x3bcb71+_0x25414a(0x177));try{const _0x1fefc0=await fs[_0x25414a(0x16a)](_0x131ac8,_0x25414a(0x158)),_0x2d2448=JSON['parse'](_0x1fefc0);return this[_0x25414a(0x166)]['set'](_0x20314b,_0x2d2448),logger[_0x25414a(0x16d)]({'event':_0x444636[_0x25414a(0x15a)],'project':_0x447787,'resource':_0x3bcb71},_0x444636['LGcqY']),_0x2d2448;}catch(_0xebfa5c){logger['error']({'event':_0x444636['tsUyC'],'project':_0x447787,'resource':_0x3bcb71,'error':_0xebfa5c[_0x25414a(0x175)]},_0x444636['QeIEQ']);throw new Error('Payload\x20not\x20found:\x20'+_0x447787+'_'+_0x3bcb71);}}async['loadPayloadByName'](_0x10bc29){const _0x99b539=a0_0x4d7fd1,_0x26d0ae={'vsPgH':_0x99b539(0x158),'ktXgQ':'payload_load_error'},_0x805e7a=_0x99b539(0x159)+_0x10bc29;if(this[_0x99b539(0x166)]['has'](_0x805e7a))return this[_0x99b539(0x166)][_0x99b539(0x157)](_0x805e7a);const _0x38324f=path['join'](this[_0x99b539(0x170)],_0x10bc29+'.json');try{const _0x439513=await fs[_0x99b539(0x16a)](_0x38324f,_0x26d0ae['vsPgH']),_0x3ead80=JSON['parse'](_0x439513);return this[_0x99b539(0x166)]['set'](_0x805e7a,_0x3ead80),logger['debug']({'event':_0x99b539(0x156),'payloadName':_0x10bc29},'Payload\x20loaded\x20successfully\x20by\x20name'),_0x3ead80;}catch(_0xe37d51){logger[_0x99b539(0x171)]({'event':_0x26d0ae[_0x99b539(0x154)],'payloadName':_0x10bc29,'error':_0xe37d51['message']},_0x99b539(0x167));throw new Error('Payload\x20not\x20found:\x20'+_0x10bc29);}}['isActionEnabled'](_0x217b6f,_0x349dee){return _0x217b6f['action']&&_0x217b6f['action'][_0x349dee]===!![];}['getExportConfig'](_0x37d28f){const _0x186e92=a0_0x4d7fd1;return{'columns':_0x37d28f[_0x186e92(0x16c)]||[],'filename':_0x37d28f[_0x186e92(0x161)]['replace']('.','-')+'-export','datatablesQuery':_0x37d28f[_0x186e92(0x160)]||null,'columnFormats':_0x37d28f[_0x186e92(0x172)]||null,'fieldLabels':_0x37d28f[_0x186e92(0x15d)]||null};}[a0_0x4d7fd1(0x16b)](){const _0x1d882d=a0_0x4d7fd1,_0x113656={'axcVp':_0x1d882d(0x163),'KAzYO':_0x1d882d(0x168)};this[_0x1d882d(0x166)][_0x1d882d(0x173)](),logger['info']({'event':_0x113656[_0x1d882d(0x17a)]},_0x113656[_0x1d882d(0x15e)]);}}module[a0_0x4d7fd1(0x179)]=new PayloadLoader();
1
+ const a0_0x2612bb=a0_0x7c68;(function(_0x19a339,_0x4c8bbb){const _0x4af3dc=a0_0x7c68,_0x4515c4=_0x19a339();while(!![]){try{const _0x86a832=-parseInt(_0x4af3dc(0x16d))/0x1*(parseInt(_0x4af3dc(0x177))/0x2)+-parseInt(_0x4af3dc(0x164))/0x3*(-parseInt(_0x4af3dc(0x169))/0x4)+-parseInt(_0x4af3dc(0x175))/0x5+-parseInt(_0x4af3dc(0x161))/0x6+parseInt(_0x4af3dc(0x15f))/0x7+-parseInt(_0x4af3dc(0x168))/0x8*(-parseInt(_0x4af3dc(0x162))/0x9)+-parseInt(_0x4af3dc(0x173))/0xa*(parseInt(_0x4af3dc(0x16a))/0xb);if(_0x86a832===_0x4c8bbb)break;else _0x4515c4['push'](_0x4515c4['shift']());}catch(_0x4bbf9f){_0x4515c4['push'](_0x4515c4['shift']());}}}(a0_0x4fd6,0xe5735));const fs=require('fs')[a0_0x2612bb(0x184)],path=require('path'),{logger}=require(a0_0x2612bb(0x17c));class PayloadLoader{constructor(){const _0x2762f0=a0_0x2612bb,_0x474b66={'YNPGz':'../../payload'};this[_0x2762f0(0x16e)]=path[_0x2762f0(0x17b)](__dirname,_0x474b66['YNPGz']),this[_0x2762f0(0x17f)]=new Map();}async['loadPayload'](_0x47f3c7,_0x4ceb34){const _0xd83346=a0_0x2612bb,_0x47daad=_0x47f3c7+':'+_0x4ceb34;if(this[_0xd83346(0x17f)][_0xd83346(0x167)](_0x47daad))return this['cache'][_0xd83346(0x179)](_0x47daad);const _0x20bfc7=path[_0xd83346(0x17b)](this['payloadDir'],_0x47f3c7+'_'+_0x4ceb34+'.json');try{const _0x4dae52=await fs[_0xd83346(0x16c)](_0x20bfc7,_0xd83346(0x17e)),_0x4a48c3=JSON['parse'](_0x4dae52);return this[_0xd83346(0x17f)][_0xd83346(0x17d)](_0x47daad,_0x4a48c3),logger['debug']({'event':'payload_loaded','project':_0x47f3c7,'resource':_0x4ceb34},_0xd83346(0x174)),_0x4a48c3;}catch(_0x34061c){logger['error']({'event':_0xd83346(0x165),'project':_0x47f3c7,'resource':_0x4ceb34,'error':_0x34061c['message']},'Failed\x20to\x20load\x20payload');throw new Error(_0xd83346(0x15e)+_0x47f3c7+'_'+_0x4ceb34);}}async[a0_0x2612bb(0x170)](_0x1b0fce){const _0x299577=a0_0x2612bb,_0x443560={'fbgrc':'Payload\x20loaded\x20successfully\x20by\x20name','LFTtK':_0x299577(0x165)},_0x414667=_0x299577(0x181)+_0x1b0fce;if(this[_0x299577(0x17f)]['has'](_0x414667))return this[_0x299577(0x17f)]['get'](_0x414667);const _0x21696a=path[_0x299577(0x17b)](this['payloadDir'],_0x1b0fce+_0x299577(0x183));try{const _0x541ecb=await fs[_0x299577(0x16c)](_0x21696a,'utf8'),_0x19622a=JSON[_0x299577(0x16f)](_0x541ecb);return this[_0x299577(0x17f)][_0x299577(0x17d)](_0x414667,_0x19622a),logger[_0x299577(0x185)]({'event':_0x299577(0x182),'payloadName':_0x1b0fce},_0x443560['fbgrc']),_0x19622a;}catch(_0x421e16){logger[_0x299577(0x178)]({'event':_0x443560[_0x299577(0x163)],'payloadName':_0x1b0fce,'error':_0x421e16['message']},_0x299577(0x160));throw new Error(_0x299577(0x15e)+_0x1b0fce);}}['isActionEnabled'](_0x5978c2,_0x3bb0a7){return _0x5978c2['action']&&_0x5978c2['action'][_0x3bb0a7]===!![];}['getExportConfig'](_0x36fe94){const _0x33c2f1=a0_0x2612bb;return{'columns':_0x36fe94['fieldName']||[],'filename':_0x36fe94[_0x33c2f1(0x180)][_0x33c2f1(0x166)]('.','-')+'-export','datatablesQuery':_0x36fe94[_0x33c2f1(0x16b)]||null,'columnFormats':_0x36fe94['columnFormats']||null,'fieldLabels':_0x36fe94[_0x33c2f1(0x171)]||null};}[a0_0x2612bb(0x17a)](){const _0x24090e=a0_0x2612bb,_0x3a1f9e={'AgqvC':'payload_cache_cleared','bbARb':_0x24090e(0x172)};this['cache']['clear'](),logger[_0x24090e(0x186)]({'event':_0x3a1f9e[_0x24090e(0x176)]},_0x3a1f9e['bbARb']);}}function a0_0x7c68(_0x2455c5,_0x57977d){_0x2455c5=_0x2455c5-0x15e;const _0x4fd6b3=a0_0x4fd6();let _0x7c685a=_0x4fd6b3[_0x2455c5];if(a0_0x7c68['CKaeMy']===undefined){var _0x183d09=function(_0x353cee){const _0x239f6f='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';let _0x1375bd='',_0x23da91='';for(let _0x58c218=0x0,_0x1cec13,_0x93fb48,_0xb03b77=0x0;_0x93fb48=_0x353cee['charAt'](_0xb03b77++);~_0x93fb48&&(_0x1cec13=_0x58c218%0x4?_0x1cec13*0x40+_0x93fb48:_0x93fb48,_0x58c218++%0x4)?_0x1375bd+=String['fromCharCode'](0xff&_0x1cec13>>(-0x2*_0x58c218&0x6)):0x0){_0x93fb48=_0x239f6f['indexOf'](_0x93fb48);}for(let _0x5b0dad=0x0,_0x2a1dc6=_0x1375bd['length'];_0x5b0dad<_0x2a1dc6;_0x5b0dad++){_0x23da91+='%'+('00'+_0x1375bd['charCodeAt'](_0x5b0dad)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x23da91);};a0_0x7c68['FRIKQv']=_0x183d09,a0_0x7c68['PhVUJE']={},a0_0x7c68['CKaeMy']=!![];}const _0x55c4a9=_0x4fd6b3[0x0],_0x2c04e0=_0x2455c5+_0x55c4a9,_0x4553ad=a0_0x7c68['PhVUJE'][_0x2c04e0];return!_0x4553ad?(_0x7c685a=a0_0x7c68['FRIKQv'](_0x7c685a),a0_0x7c68['PhVUJE'][_0x2c04e0]=_0x7c685a):_0x7c685a=_0x4553ad,_0x7c685a;}function a0_0x4fd6(){const _0x392dea=['CgfYC2u','Bg9HzfbHEwXVywrcEu5HBwu','zMLLBgrmywjLBhm','ugf5Bg9HzcbJywnOzsbJBgvHCMvK','mZb5EuzlD0G','ugf5Bg9HzcbSB2fKzwqGC3vJy2vZC2z1BgX5','mZKZnda0meHpBNfmAq','qwDXDKm','nKX3uLrYCq','zxjYB3i','z2v0','y2XLyxjdywnOzq','AM9PBG','lI9SB2DNzxi','C2v0','DxrMoa','y2fJAgu','DgfIBgvoyw1L','Cgf5Bg9HzdO','Cgf5Bg9Hzf9SB2fKzwq','lMPZB24','ChjVBwLZzxm','zgvIDwC','Aw5MBW','ugf5Bg9HzcbUB3qGzM91BMq6ia','mteZmZmZmJLWqNfOr1K','rMfPBgvKihrVigXVywqGCgf5Bg9HzcbIEsbUyw1L','nJa4mdu2mLf6uNroAW','mZiYnZr2vKz1q1m','tezuDeS','mZK4nZm0nu1PtgHPwq','Cgf5Bg9Hzf9SB2fKx2vYCM9Y','CMvWBgfJzq','AgfZ','mZe0nenPBwn1sq','ngHKwhzSva','mJyXote1nu5rA0XQCa','zgf0yxrHyMXLC1f1zxj5','CMvHzezPBgu','mZaXmdi3qNP0s2rU','Cgf5Bg9HzerPCG'];a0_0x4fd6=function(){return _0x392dea;};return a0_0x4fd6();}module['exports']=new PayloadLoader();