@joystick.js/db-canary 0.0.0-canary.2213 → 0.0.0-canary.2217

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 (226) hide show
  1. package/dist/server/index.js +1 -1
  2. package/dist/server/lib/api_key_manager.js +4 -4
  3. package/dist/server/lib/development_mode.js +7 -0
  4. package/dist/server/lib/http_server.js +7 -7
  5. package/package.json +4 -4
  6. package/src/server/index.js +14 -1
  7. package/src/server/lib/api_key_manager.js +71 -5
  8. package/src/server/lib/development_mode.js +60 -0
  9. package/src/server/lib/http_server.js +31 -8
  10. package/{data → test_data_dev_1758048078945_ow5lwnkbj}/data.mdb +0 -0
  11. package/{test_data → test_data_dev_1758048078945_ow5lwnkbj}/lock.mdb +0 -0
  12. package/test_data_dev_1758048695693_jhp72uh09/data.mdb +0 -0
  13. package/{data → test_data_dev_1758048695693_jhp72uh09}/lock.mdb +0 -0
  14. package/tests/server/lib/api_key_manager_development.test.js +163 -0
  15. package/tests/server/lib/development_mode.test.js +106 -0
  16. package/API_KEY +0 -1
  17. package/logs/.013e15b54597d05db4b4b53ecc37b10c92a72927-audit.json +0 -20
  18. package/logs/.02de550a67ea0f5961faa2dfd458a4d06f59ebd1-audit.json +0 -20
  19. package/logs/.03494ba24eb3c72214b4068a77d54b8993bee651-audit.json +0 -20
  20. package/logs/.06309ec60b339be1259a7993dd09c732f8907fbc-audit.json +0 -20
  21. package/logs/.0663a04dcfa17285661e5e1b8cfa51f41523b210-audit.json +0 -20
  22. package/logs/.0f06e6c4c9b824622729e13927587479e5060391-audit.json +0 -20
  23. package/logs/.16ccf58682ecb22b3e3ec63f0da1b7fe9be56528-audit.json +0 -20
  24. package/logs/.1fa1a5d02f496474b1ab473524c65c984146a9ad-audit.json +0 -20
  25. package/logs/.2223c0ae3bea6f0d62c62b1d319cc8634856abb7-audit.json +0 -20
  26. package/logs/.23dc79ffda3e083665e6f5993f59397adcbf4a46-audit.json +0 -20
  27. package/logs/.28104f49b03906b189eefd1cd462cb46c3c0af22-audit.json +0 -20
  28. package/logs/.29cdbf13808abe6a0ce70ee2f2efdd680ce3fd8e-audit.json +0 -20
  29. package/logs/.2a9889afd071f77f41f5170d08703a0afca866b7-audit.json +0 -20
  30. package/logs/.2acec3d1940a2bbed487528b703ee5948959a599-audit.json +0 -20
  31. package/logs/.2fb60ff326338c02bfedbcd0e936444e4a216750-audit.json +0 -20
  32. package/logs/.318fc7a19530d76a345f030f7cad00dda15300e7-audit.json +0 -20
  33. package/logs/.3cf27043e19085f908cedc7701e6d013463208ee-audit.json +0 -25
  34. package/logs/.3d90d785415817fc443402843b7c95f8371adc9b-audit.json +0 -20
  35. package/logs/.4074bca620375f72966fc52dfd439577727671e5-audit.json +0 -20
  36. package/logs/.40eecf018417ea80a70ea8ec7a3cc9406bc6334b-audit.json +0 -20
  37. package/logs/.50e974f1ef7c365fca6a1251b2e2c2252914cb5e-audit.json +0 -20
  38. package/logs/.52cb7d9e4223cf26ba36006ac26b949a97c7923c-audit.json +0 -20
  39. package/logs/.54befcdb84c15aad980705a31bcc9f555c3577ab-audit.json +0 -20
  40. package/logs/.57dfb70e22eddb84db2e3c0ceeefac5c0b9baffa-audit.json +0 -20
  41. package/logs/.5f0b24705a1eaad4eca4968f2d86f91b3f9be683-audit.json +0 -20
  42. package/logs/.61ba98fdda7db58576b382fee07904e5db1169d6-audit.json +0 -20
  43. package/logs/.6235017727ef6b199d569a99d6aa8c8e80a1b475-audit.json +0 -20
  44. package/logs/.63db16193699219489d218a1ddea5dde3750cae4-audit.json +0 -20
  45. package/logs/.64fb67dfe14149c9eef728d79bf30a54da809c60-audit.json +0 -20
  46. package/logs/.669137453368987c1f311b5345342527afb54e50-audit.json +0 -20
  47. package/logs/.7a71f8c89ea28ae266d356aeff6306e876a30fbb-audit.json +0 -20
  48. package/logs/.7afbaa90fe9dc3a7d682676f9bb79f9a1b1fd9a6-audit.json +0 -20
  49. package/logs/.7ca29e322cd05327035de850099e7610864f2347-audit.json +0 -20
  50. package/logs/.83335ab3347e449dae03455a110aaf7f120d4802-audit.json +0 -20
  51. package/logs/.8c2487b5fd445d2c8e5c483c80b9fa99bbf1ca58-audit.json +0 -20
  52. package/logs/.8c8b9dc386922c9f3b4c13251af7052aac1d24c0-audit.json +0 -20
  53. package/logs/.8d6155d94640c4863301ae0fee5e4e7372a21446-audit.json +0 -20
  54. package/logs/.944a3119a243deea7c8270d5d9e582bb1d0eaa10-audit.json +0 -20
  55. package/logs/.9816a845c30fb2909f3b26a23eeb3538ebcad5db-audit.json +0 -20
  56. package/logs/.9dc08784e38b865488177c26d4af5934555e0323-audit.json +0 -20
  57. package/logs/.9dd27d2e0e454ac0a37600206d1cac5493b0d7ee-audit.json +0 -20
  58. package/logs/.a3d486feeac7654c59b547de96600e8849a06d4f-audit.json +0 -20
  59. package/logs/.a5b811f4def22250f86cc18870d7c4573625df22-audit.json +0 -20
  60. package/logs/.a61648eb5f830e0b6f508ac35e4f8f629d2ad4c7-audit.json +0 -20
  61. package/logs/.a89016d507045771b4b5a65656944a9c0f1e528b-audit.json +0 -20
  62. package/logs/.a99bee160a1c590be959af46bacc02724803f691-audit.json +0 -20
  63. package/logs/.ada7906d6243fd7da802f03d86c4ae5dd9df6236-audit.json +0 -20
  64. package/logs/.b518339ee942143b6af983af167f5bbb6983b4de-audit.json +0 -20
  65. package/logs/.b51b124b166d53c9519017856ea610d61d65fabe-audit.json +0 -20
  66. package/logs/.b7a6aee19f58e55633d5e4a3709041c47dfff975-audit.json +0 -20
  67. package/logs/.bd7a8a6ba9c55d557a4867ab53f02e3ec2e1553d-audit.json +0 -20
  68. package/logs/.c1435dafe453b169d6392b25065f3cf4ab6fbb21-audit.json +0 -20
  69. package/logs/.c17e1ce043109f77dc2f0e2aa290a9d1ed842c03-audit.json +0 -20
  70. package/logs/.ca62637ce9540e5a38a2fbedb2115febb6ad308a-audit.json +0 -20
  71. package/logs/.ccee67b9c176967f8977071409a41f5cb5cd6ad4-audit.json +0 -20
  72. package/logs/.db24043417ea79a6f14cd947476399e53930b48d-audit.json +0 -20
  73. package/logs/.e0f12acccb57829f5f33712bb2e2607ecd808147-audit.json +0 -20
  74. package/logs/.e9b6cc33d0bbd2e644c4e2bf44d177f850016557-audit.json +0 -20
  75. package/logs/.f15291d434808e3bdca7963ccd2e73893be027e6-audit.json +0 -20
  76. package/logs/.f4bdf9e21ef84f8a3fae3ffb32bbc39275991351-audit.json +0 -20
  77. package/logs/.fbac3aefac1e81b4230df5aa50667cb90d51024f-audit.json +0 -20
  78. package/logs/.fcfd495c0a9169db243f4a4f21878ee02b76413c-audit.json +0 -20
  79. package/logs/admin-2025-09-12.log +0 -580
  80. package/logs/admin-2025-09-15.log +0 -283
  81. package/logs/admin-error-2025-09-12.log +0 -22
  82. package/logs/admin-error-2025-09-15.log +0 -10
  83. package/logs/api_key_manager-2025-09-12.log +0 -658
  84. package/logs/api_key_manager-2025-09-15.log +0 -295
  85. package/logs/api_key_manager-error-2025-09-12.log +0 -0
  86. package/logs/api_key_manager-error-2025-09-15.log +0 -0
  87. package/logs/auth_manager-2025-09-12.log +0 -4432
  88. package/logs/auth_manager-2025-09-15.log +0 -2000
  89. package/logs/auth_manager-error-2025-09-12.log +0 -11
  90. package/logs/auth_manager-error-2025-09-15.log +0 -5
  91. package/logs/auto_index_manager-2025-09-12.log +0 -84
  92. package/logs/auto_index_manager-2025-09-15.log +0 -45
  93. package/logs/auto_index_manager-error-2025-09-12.log +0 -6
  94. package/logs/auto_index_manager-error-2025-09-15.log +0 -0
  95. package/logs/backup_manager-2025-09-12.log +0 -198
  96. package/logs/backup_manager-2025-09-15.log +0 -90
  97. package/logs/backup_manager-error-2025-09-12.log +0 -198
  98. package/logs/backup_manager-error-2025-09-15.log +0 -90
  99. package/logs/bulk_write-2025-09-12.log +0 -66
  100. package/logs/bulk_write-2025-09-15.log +0 -38
  101. package/logs/bulk_write-error-2025-09-12.log +0 -0
  102. package/logs/bulk_write-error-2025-09-15.log +0 -0
  103. package/logs/connection_manager-2025-09-12.log +0 -2412
  104. package/logs/connection_manager-2025-09-15.log +0 -1132
  105. package/logs/connection_manager-error-2025-09-12.log +0 -0
  106. package/logs/connection_manager-error-2025-09-15.log +0 -0
  107. package/logs/create_index-2025-09-12.log +0 -302
  108. package/logs/create_index-2025-09-15.log +0 -158
  109. package/logs/create_index-error-2025-09-12.log +0 -30
  110. package/logs/create_index-error-2025-09-15.log +0 -13
  111. package/logs/delete_one-2025-09-12.log +0 -73
  112. package/logs/delete_one-2025-09-15.log +0 -43
  113. package/logs/delete_one-error-2025-09-12.log +0 -0
  114. package/logs/delete_one-error-2025-09-15.log +0 -0
  115. package/logs/disk_utils-2025-09-12.log +0 -4954
  116. package/logs/disk_utils-2025-09-15.log +0 -2446
  117. package/logs/disk_utils-error-2025-09-12.log +0 -0
  118. package/logs/disk_utils-error-2025-09-15.log +0 -0
  119. package/logs/drop_index-2025-09-12.log +0 -41
  120. package/logs/drop_index-2025-09-15.log +0 -23
  121. package/logs/drop_index-error-2025-09-12.log +0 -11
  122. package/logs/drop_index-error-2025-09-15.log +0 -5
  123. package/logs/find-2025-09-12.log +0 -1050
  124. package/logs/find-2025-09-15.log +0 -592
  125. package/logs/find-error-2025-09-12.log +0 -1
  126. package/logs/find-error-2025-09-15.log +0 -0
  127. package/logs/find_one-2025-09-12.log +0 -425
  128. package/logs/find_one-2025-09-15.log +0 -264
  129. package/logs/find_one-error-2025-09-12.log +0 -5
  130. package/logs/find_one-error-2025-09-15.log +0 -0
  131. package/logs/get_indexes-2025-09-12.log +0 -84
  132. package/logs/get_indexes-2025-09-15.log +0 -56
  133. package/logs/get_indexes-error-2025-09-12.log +0 -6
  134. package/logs/get_indexes-error-2025-09-15.log +0 -0
  135. package/logs/http_server-2025-09-12.log +0 -2772
  136. package/logs/http_server-2025-09-15.log +0 -1276
  137. package/logs/http_server-error-2025-09-12.log +0 -212
  138. package/logs/http_server-error-2025-09-15.log +0 -44
  139. package/logs/index_manager-2025-09-12.log +0 -5031
  140. package/logs/index_manager-2025-09-15.log +0 -2909
  141. package/logs/index_manager-error-2025-09-12.log +0 -80
  142. package/logs/index_manager-error-2025-09-15.log +0 -38
  143. package/logs/insert_one-2025-09-12.log +0 -2181
  144. package/logs/insert_one-2025-09-15.log +0 -1293
  145. package/logs/insert_one-error-2025-09-12.log +0 -0
  146. package/logs/insert_one-error-2025-09-15.log +0 -0
  147. package/logs/master-2025-09-12.log +0 -1882
  148. package/logs/master-2025-09-15.log +0 -910
  149. package/logs/master-error-2025-09-12.log +0 -80
  150. package/logs/master-error-2025-09-15.log +0 -0
  151. package/logs/operation_dispatcher-2025-09-12.log +0 -751
  152. package/logs/operation_dispatcher-2025-09-15.log +0 -359
  153. package/logs/operation_dispatcher-error-2025-09-12.log +0 -33
  154. package/logs/operation_dispatcher-error-2025-09-15.log +0 -11
  155. package/logs/performance_monitor-2025-09-12.log +0 -14889
  156. package/logs/performance_monitor-2025-09-15.log +0 -6803
  157. package/logs/performance_monitor-error-2025-09-12.log +0 -0
  158. package/logs/performance_monitor-error-2025-09-15.log +0 -0
  159. package/logs/query_engine-2025-09-12.log +0 -5310
  160. package/logs/query_engine-2025-09-15.log +0 -2639
  161. package/logs/query_engine-error-2025-09-12.log +0 -0
  162. package/logs/query_engine-error-2025-09-15.log +0 -0
  163. package/logs/recovery_manager-2025-09-12.log +0 -462
  164. package/logs/recovery_manager-2025-09-15.log +0 -210
  165. package/logs/recovery_manager-error-2025-09-12.log +0 -22
  166. package/logs/recovery_manager-error-2025-09-15.log +0 -10
  167. package/logs/replication-2025-09-12.log +0 -1923
  168. package/logs/replication-2025-09-15.log +0 -917
  169. package/logs/replication-error-2025-09-12.log +0 -33
  170. package/logs/replication-error-2025-09-15.log +0 -15
  171. package/logs/server-2025-09-12.log +0 -2601
  172. package/logs/server-2025-09-15.log +0 -1191
  173. package/logs/server-error-2025-09-12.log +0 -0
  174. package/logs/server-error-2025-09-15.log +0 -0
  175. package/logs/tcp_protocol-2025-09-12.log +0 -22
  176. package/logs/tcp_protocol-2025-09-15.log +0 -10
  177. package/logs/tcp_protocol-error-2025-09-12.log +0 -22
  178. package/logs/tcp_protocol-error-2025-09-15.log +0 -10
  179. package/logs/test-2025-09-12.log +0 -0
  180. package/logs/test-2025-09-15.log +0 -0
  181. package/logs/test-error-2025-09-12.log +0 -0
  182. package/logs/test-error-2025-09-15.log +0 -0
  183. package/logs/update_one-2025-09-12.log +0 -173
  184. package/logs/update_one-2025-09-15.log +0 -118
  185. package/logs/update_one-error-2025-09-12.log +0 -0
  186. package/logs/update_one-error-2025-09-15.log +0 -0
  187. package/logs/worker-2025-09-12.log +0 -1457
  188. package/logs/worker-2025-09-15.log +0 -695
  189. package/logs/worker-error-2025-09-12.log +0 -0
  190. package/logs/worker-error-2025-09-15.log +0 -0
  191. package/logs/write_forwarder-2025-09-12.log +0 -1956
  192. package/logs/write_forwarder-2025-09-15.log +0 -932
  193. package/logs/write_forwarder-error-2025-09-12.log +0 -66
  194. package/logs/write_forwarder-error-2025-09-15.log +0 -30
  195. package/logs/write_queue-2025-09-12.log +0 -612
  196. package/logs/write_queue-2025-09-15.log +0 -301
  197. package/logs/write_queue-error-2025-09-12.log +0 -184
  198. package/logs/write_queue-error-2025-09-15.log +0 -83
  199. package/prompts/01-core-infrastructure.md +0 -56
  200. package/prompts/02-secondary-indexing.md +0 -65
  201. package/prompts/03-write-serialization.md +0 -63
  202. package/prompts/04-enhanced-authentication.md +0 -75
  203. package/prompts/05-comprehensive-admin-operations.md +0 -75
  204. package/prompts/06-backup-and-restore-system.md +0 -106
  205. package/prompts/07-production-safety-features.md +0 -107
  206. package/prompts/08-tcp-client-library.md +0 -121
  207. package/prompts/09-api-method-chaining.md +0 -134
  208. package/prompts/10-automatic-index-creation.md +0 -223
  209. package/prompts/11-operation-naming-consistency.md +0 -268
  210. package/prompts/12-tcp-replication-system.md +0 -333
  211. package/prompts/13-master-read-write-operations.md +0 -57
  212. package/prompts/14-index-upsert-operations.md +0 -68
  213. package/prompts/15-client-api-return-types.md +0 -81
  214. package/prompts/16-server-setup-ui.md +0 -97
  215. package/prompts/17-emergency-password-change.md +0 -108
  216. package/prompts/18-joystick-framework-integration.md +0 -116
  217. package/prompts/19-api-key-authentication-system.md +0 -137
  218. package/prompts/20-configurable-server-port.md +0 -105
  219. package/prompts/21-multi-database-support.md +0 -161
  220. package/prompts/22-build-script-integration.md +0 -129
  221. package/prompts/23-cli-integration.md +0 -268
  222. package/prompts/FULL_TEXT_SEARCH.md +0 -293
  223. package/prompts/PROMPTS.md +0 -158
  224. package/prompts/README.md +0 -221
  225. package/prompts/TYPESCRIPT_GENERATION.md +0 -179
  226. package/test_data/data.mdb +0 -0
@@ -1,210 +0,0 @@
1
- {"context":{"expires_at":"2025-09-15T16:53:00.118Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.118-05:00"}
2
- {"context":{"expires_at":"2025-09-15T16:53:00.120Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.120-05:00"}
3
- {"context":{"expires_at":"2025-09-15T16:53:00.120Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.120-05:00"}
4
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:00.120-05:00"}
5
- {"context":{"expires_at":"2025-09-15T16:53:00.121Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.121-05:00"}
6
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:00.121-05:00"}
7
- {"context":{"expires_at":"2025-09-15T16:53:00.121Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.122-05:00"}
8
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:00.122-05:00"}
9
- {"context":{"expires_at":"2025-09-15T16:53:00.122Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.122-05:00"}
10
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.122-05:00"}
11
- {"context":{"expires_at":"2025-09-15T16:53:00.123Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.123-05:00"}
12
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
13
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
14
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
15
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T17:13:00.123Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T11:43:00.123-05:00"}
16
- {"context":{"expires_at":"2025-09-15T16:53:00.123Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:00.123-05:00"}
17
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
18
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
19
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:00.123-05:00"}
20
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T17:13:00.123Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T11:43:00.123-05:00"}
21
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:00.123-05:00"}
22
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T11:43:00.370-05:00"}
23
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T11:43:00.370-05:00"}
24
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T16:43:00.864Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T11:43:00.864-05:00"}
25
- {"context":{},"level":"info","message":"All existing connections terminated due to password change","timestamp":"2025-09-15T11:43:01.882-05:00"}
26
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T16:43:01.882Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T11:43:01.882-05:00"}
27
- {"context":{"expires_at":"2025-09-15T16:53:01.882Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:01.883-05:00"}
28
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T16:43:02.396Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T11:43:02.396-05:00"}
29
- {"context":{"expires_at":"2025-09-15T16:53:02.396Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:02.396-05:00"}
30
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:02.397-05:00"}
31
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.397-05:00"}
32
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.397-05:00"}
33
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.397-05:00"}
34
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.397-05:00"}
35
- {"context":{"expires_at":"2025-09-15T16:53:02.397Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:02.398-05:00"}
36
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T11:43:02.398-05:00"}
37
- {"context":{"expires_at":"2025-09-15T16:53:02.398Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:02.398-05:00"}
38
- {"context":{"expires_at":"2025-09-15T16:53:02.398Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:02.398-05:00"}
39
- {"context":{"expires_at":"2025-09-15T16:53:02.398Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T11:43:02.398-05:00"}
40
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.398-05:00"}
41
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T11:43:02.398-05:00"}
42
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T16:43:02.909Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T11:43:02.909-05:00"}
43
- {"context":{"expires_at":"2025-09-15T18:17:08.151Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.152-05:00"}
44
- {"context":{"expires_at":"2025-09-15T18:17:08.154Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.154-05:00"}
45
- {"context":{"expires_at":"2025-09-15T18:17:08.154Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.154-05:00"}
46
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:08.155-05:00"}
47
- {"context":{"expires_at":"2025-09-15T18:17:08.155Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.155-05:00"}
48
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:08.155-05:00"}
49
- {"context":{"expires_at":"2025-09-15T18:17:08.156Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.156-05:00"}
50
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:08.156-05:00"}
51
- {"context":{"expires_at":"2025-09-15T18:17:08.156Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.156-05:00"}
52
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.157-05:00"}
53
- {"context":{"expires_at":"2025-09-15T18:17:08.157Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.157-05:00"}
54
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.158-05:00"}
55
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.158-05:00"}
56
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.158-05:00"}
57
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T18:37:08.158Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T13:07:08.158-05:00"}
58
- {"context":{"expires_at":"2025-09-15T18:17:08.158Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:08.158-05:00"}
59
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.158-05:00"}
60
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.158-05:00"}
61
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:08.159-05:00"}
62
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T18:37:08.159Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T13:07:08.159-05:00"}
63
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:08.159-05:00"}
64
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:07:08.459-05:00"}
65
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:07:08.459-05:00"}
66
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:07:09.029Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:07:09.029-05:00"}
67
- {"context":{},"level":"info","message":"All existing connections terminated due to password change","timestamp":"2025-09-15T13:07:10.135-05:00"}
68
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:07:10.135Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:07:10.135-05:00"}
69
- {"context":{"expires_at":"2025-09-15T18:17:10.136Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.136-05:00"}
70
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:07:10.767Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:07:10.767-05:00"}
71
- {"context":{"expires_at":"2025-09-15T18:17:10.768Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.768-05:00"}
72
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:10.768-05:00"}
73
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.769-05:00"}
74
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.769-05:00"}
75
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.769-05:00"}
76
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.769-05:00"}
77
- {"context":{"expires_at":"2025-09-15T18:17:10.769Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.769-05:00"}
78
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:07:10.769-05:00"}
79
- {"context":{"expires_at":"2025-09-15T18:17:10.770Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.770-05:00"}
80
- {"context":{"expires_at":"2025-09-15T18:17:10.770Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.770-05:00"}
81
- {"context":{"expires_at":"2025-09-15T18:17:10.770Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:07:10.770-05:00"}
82
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.770-05:00"}
83
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:07:10.770-05:00"}
84
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:07:11.453Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:07:11.454-05:00"}
85
- {"context":{"expires_at":"2025-09-15T18:44:21.915Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.915-05:00"}
86
- {"context":{"expires_at":"2025-09-15T18:44:21.917Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.917-05:00"}
87
- {"context":{"expires_at":"2025-09-15T18:44:21.918Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.918-05:00"}
88
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:21.918-05:00"}
89
- {"context":{"expires_at":"2025-09-15T18:44:21.919Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.919-05:00"}
90
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:21.919-05:00"}
91
- {"context":{"expires_at":"2025-09-15T18:44:21.919Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.919-05:00"}
92
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:21.920-05:00"}
93
- {"context":{"expires_at":"2025-09-15T18:44:21.920Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.920-05:00"}
94
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.920-05:00"}
95
- {"context":{"expires_at":"2025-09-15T18:44:21.921Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.921-05:00"}
96
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.921-05:00"}
97
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.921-05:00"}
98
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.921-05:00"}
99
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T19:04:21.921Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T13:34:21.921-05:00"}
100
- {"context":{"expires_at":"2025-09-15T18:44:21.921Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:21.921-05:00"}
101
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.921-05:00"}
102
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.922-05:00"}
103
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:21.922-05:00"}
104
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T19:04:21.922Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T13:34:21.922-05:00"}
105
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:21.922-05:00"}
106
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:34:22.234-05:00"}
107
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:34:22.234-05:00"}
108
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:34:22.830Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:34:22.830-05:00"}
109
- {"context":{},"level":"info","message":"All existing connections terminated due to password change","timestamp":"2025-09-15T13:34:23.992-05:00"}
110
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:34:23.992Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:34:23.992-05:00"}
111
- {"context":{"expires_at":"2025-09-15T18:44:23.993Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:23.993-05:00"}
112
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:34:24.549Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:34:24.549-05:00"}
113
- {"context":{"expires_at":"2025-09-15T18:44:24.550Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:24.550-05:00"}
114
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:24.550-05:00"}
115
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.550-05:00"}
116
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.550-05:00"}
117
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.551-05:00"}
118
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.551-05:00"}
119
- {"context":{"expires_at":"2025-09-15T18:44:24.551Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:24.551-05:00"}
120
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T13:34:24.551-05:00"}
121
- {"context":{"expires_at":"2025-09-15T18:44:24.552Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:24.552-05:00"}
122
- {"context":{"expires_at":"2025-09-15T18:44:24.552Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:24.552-05:00"}
123
- {"context":{"expires_at":"2025-09-15T18:44:24.552Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T13:34:24.552-05:00"}
124
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.552-05:00"}
125
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T13:34:24.552-05:00"}
126
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T18:34:25.148Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T13:34:25.148-05:00"}
127
- {"context":{"expires_at":"2025-09-15T19:42:41.965Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.965-05:00"}
128
- {"context":{"expires_at":"2025-09-15T19:42:41.967Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.967-05:00"}
129
- {"context":{"expires_at":"2025-09-15T19:42:41.968Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.968-05:00"}
130
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:41.968-05:00"}
131
- {"context":{"expires_at":"2025-09-15T19:42:41.969Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.969-05:00"}
132
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:41.969-05:00"}
133
- {"context":{"expires_at":"2025-09-15T19:42:41.969Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.970-05:00"}
134
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:41.970-05:00"}
135
- {"context":{"expires_at":"2025-09-15T19:42:41.970Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.970-05:00"}
136
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.971-05:00"}
137
- {"context":{"expires_at":"2025-09-15T19:42:41.971Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.971-05:00"}
138
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.971-05:00"}
139
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.972-05:00"}
140
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.972-05:00"}
141
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T20:02:41.972Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T14:32:41.972-05:00"}
142
- {"context":{"expires_at":"2025-09-15T19:42:41.972Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:41.972-05:00"}
143
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.972-05:00"}
144
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.972-05:00"}
145
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:41.972-05:00"}
146
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T20:02:41.972Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T14:32:41.972-05:00"}
147
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:41.973-05:00"}
148
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:32:42.304-05:00"}
149
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:32:42.304-05:00"}
150
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:32:42.940Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:32:42.940-05:00"}
151
- {"context":{},"level":"info","message":"All existing connections terminated due to password change","timestamp":"2025-09-15T14:32:44.153-05:00"}
152
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:32:44.153Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:32:44.153-05:00"}
153
- {"context":{"expires_at":"2025-09-15T19:42:44.153Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.154-05:00"}
154
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:32:44.761Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:32:44.761-05:00"}
155
- {"context":{"expires_at":"2025-09-15T19:42:44.761Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.762-05:00"}
156
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:44.762-05:00"}
157
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.762-05:00"}
158
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.762-05:00"}
159
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.762-05:00"}
160
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.763-05:00"}
161
- {"context":{"expires_at":"2025-09-15T19:42:44.763Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.763-05:00"}
162
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:32:44.763-05:00"}
163
- {"context":{"expires_at":"2025-09-15T19:42:44.763Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.763-05:00"}
164
- {"context":{"expires_at":"2025-09-15T19:42:44.764Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.764-05:00"}
165
- {"context":{"expires_at":"2025-09-15T19:42:44.764Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:32:44.764-05:00"}
166
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.764-05:00"}
167
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:32:44.764-05:00"}
168
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:32:45.403Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:32:45.403-05:00"}
169
- {"context":{"expires_at":"2025-09-15T19:49:31.334Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.334-05:00"}
170
- {"context":{"expires_at":"2025-09-15T19:49:31.336Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.336-05:00"}
171
- {"context":{"expires_at":"2025-09-15T19:49:31.336Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.336-05:00"}
172
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:31.337-05:00"}
173
- {"context":{"expires_at":"2025-09-15T19:49:31.337Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.338-05:00"}
174
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:31.338-05:00"}
175
- {"context":{"expires_at":"2025-09-15T19:49:31.338Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.338-05:00"}
176
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:31.339-05:00"}
177
- {"context":{"expires_at":"2025-09-15T19:49:31.339Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.339-05:00"}
178
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.339-05:00"}
179
- {"context":{"expires_at":"2025-09-15T19:49:31.340Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.340-05:00"}
180
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.340-05:00"}
181
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.341-05:00"}
182
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.341-05:00"}
183
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T20:09:31.341Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T14:39:31.341-05:00"}
184
- {"context":{"expires_at":"2025-09-15T19:49:31.341Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:31.341-05:00"}
185
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.341-05:00"}
186
- {"context":{"attempt_count":2,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.341-05:00"}
187
- {"context":{"attempt_count":3,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:31.341-05:00"}
188
- {"context":{"ip":"192.168.1.100","locked_until":"2025-09-15T20:09:31.341Z"},"level":"warn","message":"Recovery locked due to too many failed attempts","timestamp":"2025-09-15T14:39:31.341-05:00"}
189
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:31.342-05:00"}
190
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:39:31.651-05:00"}
191
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:39:31.651-05:00"}
192
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:39:32.252Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:39:32.252-05:00"}
193
- {"context":{},"level":"info","message":"All existing connections terminated due to password change","timestamp":"2025-09-15T14:39:33.421-05:00"}
194
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:39:33.421Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:39:33.421-05:00"}
195
- {"context":{"expires_at":"2025-09-15T19:49:33.422Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.422-05:00"}
196
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:39:33.993Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:39:33.993-05:00"}
197
- {"context":{"expires_at":"2025-09-15T19:49:33.994Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.994-05:00"}
198
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:33.994-05:00"}
199
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.994-05:00"}
200
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.994-05:00"}
201
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.995-05:00"}
202
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.995-05:00"}
203
- {"context":{"expires_at":"2025-09-15T19:49:33.995Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.995-05:00"}
204
- {"context":{"attempt_count":1,"ip":"192.168.1.100"},"level":"warn","message":"Failed recovery attempt","timestamp":"2025-09-15T14:39:33.995-05:00"}
205
- {"context":{"expires_at":"2025-09-15T19:49:33.995Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.995-05:00"}
206
- {"context":{"expires_at":"2025-09-15T19:49:33.995Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.996-05:00"}
207
- {"context":{"expires_at":"2025-09-15T19:49:33.996Z"},"level":"info","message":"Recovery token generated","timestamp":"2025-09-15T14:39:33.996-05:00"}
208
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.996-05:00"}
209
- {"context":{},"level":"info","message":"Recovery state loaded","timestamp":"2025-09-15T14:39:33.996-05:00"}
210
- {"context":{"client_ip":"192.168.1.100","timestamp":"2025-09-15T19:39:34.564Z"},"level":"info","message":"Emergency password change completed","timestamp":"2025-09-15T14:39:34.564-05:00"}
@@ -1,22 +0,0 @@
1
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T10:56:38.029-05:00"}
2
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T10:56:38.030-05:00"}
3
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T15:24:43.190-05:00"}
4
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T15:24:43.190-05:00"}
5
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T17:40:49.817-05:00"}
6
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T17:40:49.817-05:00"}
7
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:15:59.289-05:00"}
8
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:15:59.289-05:00"}
9
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:29:00.430-05:00"}
10
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:29:00.430-05:00"}
11
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:46:30.349-05:00"}
12
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T19:46:30.349-05:00"}
13
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:00:09.863-05:00"}
14
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:00:09.864-05:00"}
15
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:09:26.908-05:00"}
16
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:09:26.908-05:00"}
17
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:29:16.996-05:00"}
18
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T20:29:16.997-05:00"}
19
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T21:39:52.484-05:00"}
20
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T21:39:52.485-05:00"}
21
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T21:54:53.301-05:00"}
22
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-12T21:54:53.302-05:00"}
@@ -1,10 +0,0 @@
1
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T11:43:00.370-05:00"}
2
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T11:43:00.370-05:00"}
3
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:07:08.459-05:00"}
4
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:07:08.459-05:00"}
5
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:34:22.234-05:00"}
6
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T13:34:22.234-05:00"}
7
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:32:42.304-05:00"}
8
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:32:42.304-05:00"}
9
- {"context":{"client_ip":"192.168.1.100","error":"JOYSTICK_DB_SETTINGS environment variable not found"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:39:31.651-05:00"}
10
- {"context":{"client_ip":"192.168.1.100","error":"Authentication not configured"},"level":"error","message":"Emergency password change failed","timestamp":"2025-09-15T14:39:31.651-05:00"}