@profoundlogic/coderflow-server 0.5.2 → 0.5.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 (177) hide show
  1. package/dist/coder-server.js +1 -1
  2. package/dist/config.js +1 -1
  3. package/dist/lib/agent-keepalive.js +1 -1
  4. package/dist/lib/agent-models.js +1 -1
  5. package/dist/lib/api-keys.js +1 -1
  6. package/dist/lib/apiKeys.js +1 -1
  7. package/dist/lib/app-server-ports.js +1 -1
  8. package/dist/lib/auto-judge.js +1 -1
  9. package/dist/lib/automation-service.js +1 -1
  10. package/dist/lib/basic-auth.js +1 -1
  11. package/dist/lib/bindings.js +1 -1
  12. package/dist/lib/build-history.js +1 -1
  13. package/dist/lib/build-output-service.js +1 -1
  14. package/dist/lib/build-scheduler.js +1 -1
  15. package/dist/lib/build-service.js +1 -1
  16. package/dist/lib/ca-certificates.js +1 -1
  17. package/dist/lib/claude-oauth-refresh.js +1 -1
  18. package/dist/lib/cli/build.js +1 -1
  19. package/dist/lib/cli/cleanup-users.js +1 -1
  20. package/dist/lib/cli/config-command.js +1 -1
  21. package/dist/lib/cli/config.js +1 -1
  22. package/dist/lib/cli/create-user.js +1 -1
  23. package/dist/lib/cli/grant-admin.js +1 -1
  24. package/dist/lib/cli/init.js +1 -1
  25. package/dist/lib/cli/jira.js +1 -1
  26. package/dist/lib/cli/license.js +1 -1
  27. package/dist/lib/cli/list-roles.js +1 -1
  28. package/dist/lib/cli/list-users.js +1 -1
  29. package/dist/lib/cli/server-manager.js +1 -1
  30. package/dist/lib/cli/set-password.js +1 -1
  31. package/dist/lib/config-migration.js +1 -1
  32. package/dist/lib/container-credential-sync.js +1 -1
  33. package/dist/lib/container-tokens.js +1 -1
  34. package/dist/lib/data-dir.js +1 -1
  35. package/dist/lib/deployment-history.js +1 -1
  36. package/dist/lib/deployment-service.js +1 -1
  37. package/dist/lib/docker-utils.js +1 -1
  38. package/dist/lib/email.js +1 -1
  39. package/dist/lib/emailTemplates.js +1 -1
  40. package/dist/lib/entitlement.js +1 -1
  41. package/dist/lib/external-connections.js +1 -1
  42. package/dist/lib/fetch-utils.js +1 -1
  43. package/dist/lib/git-commit-details-route.js +1 -1
  44. package/dist/lib/git-history-diff-guardrails.js +1 -1
  45. package/dist/lib/git-provider-service.js +1 -1
  46. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  47. package/dist/lib/git-provider-setup/index.js +1 -1
  48. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  50. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  51. package/dist/lib/git-providers/github-app-provider.js +1 -1
  52. package/dist/lib/git-providers/index.js +1 -1
  53. package/dist/lib/git-providers/provider-factory.js +1 -1
  54. package/dist/lib/git-providers/provider-interface.js +1 -1
  55. package/dist/lib/github-urls.js +1 -1
  56. package/dist/lib/group-objective-linking.js +1 -1
  57. package/dist/lib/ibmi-sync.js +1 -1
  58. package/dist/lib/jira-client.js +1 -1
  59. package/dist/lib/judge-blinding.js +1 -1
  60. package/dist/lib/logger.js +1 -1
  61. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  62. package/dist/lib/model-fetcher.js +1 -1
  63. package/dist/lib/notifications.js +1 -1
  64. package/dist/lib/objective-context.js +1 -1
  65. package/dist/lib/oidc-auth.js +1 -1
  66. package/dist/lib/oidc-device-flow.js +1 -1
  67. package/dist/lib/passwordTokens.js +1 -1
  68. package/dist/lib/permission-resolver.js +1 -1
  69. package/dist/lib/pin-cascade.js +1 -1
  70. package/dist/lib/provider-accounts.js +1 -1
  71. package/dist/lib/provider-oauth.js +1 -1
  72. package/dist/lib/provider-profile.js +1 -1
  73. package/dist/lib/provider-token-refresh.js +1 -1
  74. package/dist/lib/rbac-user-state.js +1 -1
  75. package/dist/lib/request-url.js +1 -1
  76. package/dist/lib/rewind.js +1 -1
  77. package/dist/lib/role-definitions.js +1 -1
  78. package/dist/lib/roles.js +1 -1
  79. package/dist/lib/secrets.js +1 -1
  80. package/dist/lib/setup-repo-git-auth.js +1 -1
  81. package/dist/lib/state-capture.js +1 -1
  82. package/dist/lib/static-files.js +1 -1
  83. package/dist/lib/task-name-format.js +1 -1
  84. package/dist/lib/task-name-generator.js +1 -1
  85. package/dist/lib/task-source-metadata.js +1 -1
  86. package/dist/lib/teams.js +1 -1
  87. package/dist/lib/user-git-oauth.js +1 -1
  88. package/dist/lib/user-git-tokens.js +1 -1
  89. package/dist/lib/users.js +1 -1
  90. package/dist/middleware/requireAuth.js +1 -1
  91. package/dist/middleware/requireInit.js +1 -1
  92. package/dist/middleware/requirePermission.js +1 -1
  93. package/dist/package.json +1 -1
  94. package/dist/playwright.config.js +1 -1
  95. package/dist/routes/apiKeys.js +1 -1
  96. package/dist/routes/auth-oidc.js +1 -1
  97. package/dist/routes/auth.js +1 -1
  98. package/dist/routes/automations.js +1 -1
  99. package/dist/routes/bindings.js +1 -1
  100. package/dist/routes/build.js +1 -1
  101. package/dist/routes/containers.js +1 -1
  102. package/dist/routes/deploy-task.js +1 -1
  103. package/dist/routes/environment-management.js +1 -1
  104. package/dist/routes/environments.js +1 -1
  105. package/dist/routes/external-skills.js +1 -1
  106. package/dist/routes/git-credentials.js +1 -1
  107. package/dist/routes/git-oauth.js +1 -1
  108. package/dist/routes/git-provider-setup.js +1 -1
  109. package/dist/routes/health.js +1 -1
  110. package/dist/routes/jira.js +1 -1
  111. package/dist/routes/objective-management.js +1 -1
  112. package/dist/routes/password.js +1 -1
  113. package/dist/routes/prompt.js +1 -1
  114. package/dist/routes/provider-auth.js +1 -1
  115. package/dist/routes/qa.js +1 -1
  116. package/dist/routes/roles.js +1 -1
  117. package/dist/routes/settings.js +1 -1
  118. package/dist/routes/skill-management.js +1 -1
  119. package/dist/routes/skills.js +1 -1
  120. package/dist/routes/tasks.js +1 -1
  121. package/dist/routes/teams.js +1 -1
  122. package/dist/routes/templates.js +1 -1
  123. package/dist/routes/test-task.js +1 -1
  124. package/dist/routes/test.js +1 -1
  125. package/dist/routes/users.js +1 -1
  126. package/dist/routes/visualizations.js +1 -1
  127. package/dist/scripts/create-user.js +1 -1
  128. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  129. package/dist/start.js +1 -1
  130. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  131. package/dist/web-ui/public/activity-feed.js +1 -1
  132. package/dist/web-ui/public/activity-formatters.js +1 -1
  133. package/dist/web-ui/public/agent-event-parser.js +1 -1
  134. package/dist/web-ui/public/app.js +1 -1
  135. package/dist/web-ui/public/approve-dialog.js +1 -1
  136. package/dist/web-ui/public/automation-links.js +1 -1
  137. package/dist/web-ui/public/automation-schedule.js +1 -1
  138. package/dist/web-ui/public/comments-widget.js +1 -1
  139. package/dist/web-ui/public/diff-utils.js +1 -1
  140. package/dist/web-ui/public/environments.html +6 -6
  141. package/dist/web-ui/public/environments.js +1 -1
  142. package/dist/web-ui/public/feedback-widget.js +1 -1
  143. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  144. package/dist/web-ui/public/git-history.html +4 -4
  145. package/dist/web-ui/public/git-history.js +1 -1
  146. package/dist/web-ui/public/git-status.js +1 -1
  147. package/dist/web-ui/public/index.html +4 -4
  148. package/dist/web-ui/public/index.js +1 -1
  149. package/dist/web-ui/public/login.html +2 -2
  150. package/dist/web-ui/public/login.js +1 -1
  151. package/dist/web-ui/public/markdown-editor.js +1 -1
  152. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  153. package/dist/web-ui/public/modal-maximize.js +1 -1
  154. package/dist/web-ui/public/notifications.js +1 -1
  155. package/dist/web-ui/public/pr-dialog.js +1 -1
  156. package/dist/web-ui/public/roles.html +1 -1
  157. package/dist/web-ui/public/roles.js +1 -1
  158. package/dist/web-ui/public/server-health.js +1 -1
  159. package/dist/web-ui/public/settings.html +4 -4
  160. package/dist/web-ui/public/settings.js +1 -1
  161. package/dist/web-ui/public/setup-password.html +2 -2
  162. package/dist/web-ui/public/setup-password.js +1 -1
  163. package/dist/web-ui/public/skills.html +6 -6
  164. package/dist/web-ui/public/skills.js +1 -1
  165. package/dist/web-ui/public/sse-client.js +1 -1
  166. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  167. package/dist/web-ui/public/task.html +5 -5
  168. package/dist/web-ui/public/task.js +1 -1
  169. package/dist/web-ui/public/teams.html +1 -1
  170. package/dist/web-ui/public/teams.js +1 -1
  171. package/dist/web-ui/public/terminal.html +2 -2
  172. package/dist/web-ui/public/terminal.js +1 -1
  173. package/dist/web-ui/public/theme.js +1 -1
  174. package/dist/web-ui/public/users.html +2 -2
  175. package/dist/web-ui/public/users.js +1 -1
  176. package/dist/web-ui/public/variant-grouping.js +1 -1
  177. package/package.json +1 -1
@@ -1 +1 @@
1
- function isSharedWorkerSupported(){return typeof SharedWorker!=='undefined';}function eventTypeToHandler(_0x1f13e1){if(_0x1f13e1==='connected')return'onConnected';if(_0x1f13e1==='error')return'onError';return'on'+_0x1f13e1['split']('-')['map'](_0x3ef852=>_0x3ef852['charAt'](0x0)['toUpperCase']()+_0x3ef852['slice'](0x1))['join']('');}const TASK_STREAM_EVENTS=['activity','logs','metadata','summary','changed-files','app-server-status','complete'];export class TaskUpdatesClient{constructor(){this['listeners']=new Map(),this['worker']=null,this['port']=null,this['eventSource']=null,this['userId']=null,this['reconnectTimeout']=null,this['reconnectAttempts']=0x0,this['useSharedWorker']=isSharedWorkerSupported(),this['connected']=![],this['_taskSubscriptions']=new Map(),this['_taskSubIdCounter']=0x0,this['_handleWorkerMessage']=this['_handleWorkerMessage']['bind'](this),this['_handleDirectSSE']=this['_handleDirectSSE']['bind'](this);}['on'](_0x490f42,_0x2f80b1){return!this['listeners']['has'](_0x490f42)&&this['listeners']['set'](_0x490f42,new Set()),this['listeners']['get'](_0x490f42)['add'](_0x2f80b1),this;}['off'](_0x316541,_0x3f01c9){return this['listeners']['has'](_0x316541)&&this['listeners']['get'](_0x316541)['delete'](_0x3f01c9),this;}['_emit'](_0x27ad80,_0xbdaaaa){this['listeners']['has'](_0x27ad80)&&this['listeners']['get'](_0x27ad80)['forEach'](_0x497a01=>{try{_0x497a01(_0xbdaaaa);}catch(_0x568019){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x27ad80+'\x20listener:',_0x568019);}});}['connect'](_0x15027c='me'){this['userId']=_0x15027c,this['useSharedWorker']?this['_connectViaWorker'](_0x15027c):this['_connectDirect'](_0x15027c);}['_connectViaWorker'](_0x125c6e){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0x125c6e});}catch(_0xc6ff28){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0xc6ff28),this['useSharedWorker']=![],this['_connectDirect'](_0x125c6e);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x4b05e5=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x4b05e5),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0x126e6d){const _0x3b5bf4=_0x126e6d['data'];if(_0x3b5bf4['type']&&_0x3b5bf4['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x3b5bf4);return;}switch(_0x3b5bf4['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0x50b666=JSON['parse'](_0x3b5bf4['data']);this['_emit'](_0x3b5bf4['type'],_0x50b666);}catch(_0x307925){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x3b5bf4['type']+'\x20data:',_0x307925);}break;case'error':this['connected']=![],this['_emit']('error',_0x3b5bf4);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x3b5bf4['type']);}}['_handleTaskStreamMessage'](_0x580558){const {taskId:_0x2b3ebf,type:_0x54e256,data:_0x472447}=_0x580558,_0x4d3746=this['_taskSubscriptions']['get'](_0x2b3ebf);if(!_0x4d3746||_0x4d3746['size']===0x0)return;const _0x1b06ef=_0x54e256['replace']('task:',''),_0x507e70=eventTypeToHandler(_0x1b06ef);_0x4d3746['forEach'](_0x2a13ea=>{if(_0x2a13ea['handlers'][_0x507e70])try{const _0x32cd74=typeof _0x472447==='string'?JSON['parse'](_0x472447):_0x472447;_0x2a13ea['handlers'][_0x507e70](_0x32cd74);}catch(_0xf8bbc2){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x1b06ef+'\x20handler:',_0xf8bbc2);}});}['_connectDirect'](_0x49000e){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0x3704c8=_0x49000e&&_0x49000e!=='me'?'?userId='+_0x49000e:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0x3704c8),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x4df21e=>{this['_handleDirectSSE']('snapshot',_0x4df21e),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x46ee75=>{this['_handleDirectSSE']('activity',_0x46ee75);}),this['eventSource']['addEventListener']('status',_0xff008f=>{this['_handleDirectSSE']('status',_0xff008f);}),this['eventSource']['addEventListener']('new-task',_0x232868=>{this['_handleDirectSSE']('new-task',_0x232868);}),this['eventSource']['addEventListener']('queue-position',_0x330006=>{this['_handleDirectSSE']('queue-position',_0x330006);}),this['eventSource']['addEventListener']('error',_0x4c3359=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0x4c3359),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0x40793e){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0x40793e),this['_emit']('error',{'error':_0x40793e['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0x35d446,_0x13a2db){try{const _0x5865e1=JSON['parse'](_0x13a2db['data']);this['_emit'](_0x35d446,_0x5865e1);}catch(_0x116eda){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x35d446+'\x20data:',_0x116eda);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x25b92d=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x25b92d+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x25b92d);}['changeFilter'](_0x498aa1){if(_0x498aa1===this['userId'])return;this['userId']=_0x498aa1;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x498aa1});else this['eventSource']&&this['_connectDirect'](_0x498aa1);}['subscribeTask'](_0x120b3c,_0x54f593){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x120b3c,_0x54f593):this['_subscribeTaskDirect'](_0x120b3c,_0x54f593);}['unsubscribeTask'](_0x16ee88){if(!_0x16ee88)return;_0x16ee88['type']==='worker'?this['_unsubscribeTaskWorker'](_0x16ee88):this['_unsubscribeTaskDirect'](_0x16ee88);}['_subscribeTaskViaWorker'](_0x3ee842,_0x26fa46){try{this['_ensureWorker']();}catch(_0x3e880c){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x3e880c),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0x3ee842,_0x26fa46);}const _0x52c200=++this['_taskSubIdCounter'],_0x56c8a5={'type':'worker','taskId':_0x3ee842,'handlers':_0x26fa46,'id':_0x52c200};return!this['_taskSubscriptions']['has'](_0x3ee842)&&(this['_taskSubscriptions']['set'](_0x3ee842,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0x3ee842})),this['_taskSubscriptions']['get'](_0x3ee842)['add'](_0x56c8a5),_0x56c8a5;}['_unsubscribeTaskWorker'](_0x5f0e01){const {taskId:_0x333fda}=_0x5f0e01,_0x4d72fa=this['_taskSubscriptions']['get'](_0x333fda);if(_0x4d72fa){_0x4d72fa['delete'](_0x5f0e01);if(_0x4d72fa['size']===0x0){this['_taskSubscriptions']['delete'](_0x333fda);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x333fda});}catch(_0x3ccb4d){}}}}['_subscribeTaskDirect'](_0x20d4bf,_0x213108){const _0x2f2ed8=++this['_taskSubIdCounter'],_0x39f702=new EventSource('/tasks/'+_0x20d4bf+'/stream'),_0x5d6c92={'type':'direct','taskId':_0x20d4bf,'handlers':_0x213108,'id':_0x2f2ed8,'eventSource':_0x39f702};!this['_taskSubscriptions']['has'](_0x20d4bf)&&this['_taskSubscriptions']['set'](_0x20d4bf,new Set());this['_taskSubscriptions']['get'](_0x20d4bf)['add'](_0x5d6c92);for(const _0x4e29a9 of TASK_STREAM_EVENTS){const _0x150997=eventTypeToHandler(_0x4e29a9);_0x39f702['addEventListener'](_0x4e29a9,_0x21aaeb=>{if(_0x213108[_0x150997])try{const _0x5a3a41=JSON['parse'](_0x21aaeb['data']);_0x213108[_0x150997](_0x5a3a41);}catch(_0x4db8ab){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x4e29a9+':',_0x4db8ab);}});}return _0x39f702['addEventListener']('open',()=>{if(_0x213108['onConnected'])_0x213108['onConnected']();}),_0x39f702['addEventListener']('error',()=>{if(_0x213108['onError'])_0x213108['onError']({'error':'Connection\x20error'});}),_0x5d6c92;}['_unsubscribeTaskDirect'](_0x2a1511){_0x2a1511['eventSource']&&(_0x2a1511['eventSource']['close'](),_0x2a1511['eventSource']=null);const _0x22f3f7=this['_taskSubscriptions']['get'](_0x2a1511['taskId']);_0x22f3f7&&(_0x22f3f7['delete'](_0x2a1511),_0x22f3f7['size']===0x0&&this['_taskSubscriptions']['delete'](_0x2a1511['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x54cfad,_0x1f5d74)=>{_0x54cfad['forEach'](_0x3be74c=>{_0x3be74c['type']==='direct'&&_0x3be74c['eventSource']&&_0x3be74c['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0x1e4f12){}this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['connected']=![];}['isConnected'](){return this['connected'];}['isUsingSharedWorker'](){return this['useSharedWorker'];}}let globalClient=null;export function getTaskUpdatesClient(){return!globalClient&&(globalClient=new TaskUpdatesClient()),globalClient;}
1
+ function isSharedWorkerSupported(){return typeof SharedWorker!=='undefined';}function eventTypeToHandler(_0x551246){if(_0x551246==='connected')return'onConnected';if(_0x551246==='error')return'onError';return'on'+_0x551246['split']('-')['map'](_0x28c773=>_0x28c773['charAt'](0x0)['toUpperCase']()+_0x28c773['slice'](0x1))['join']('');}const TASK_STREAM_EVENTS=['activity','logs','metadata','summary','changed-files','app-server-status','complete'];export class TaskUpdatesClient{constructor(){this['listeners']=new Map(),this['worker']=null,this['port']=null,this['eventSource']=null,this['userId']=null,this['reconnectTimeout']=null,this['reconnectAttempts']=0x0,this['useSharedWorker']=isSharedWorkerSupported(),this['connected']=![],this['_taskSubscriptions']=new Map(),this['_taskSubIdCounter']=0x0,this['_handleWorkerMessage']=this['_handleWorkerMessage']['bind'](this),this['_handleDirectSSE']=this['_handleDirectSSE']['bind'](this);}['on'](_0x4435ce,_0x21169b){return!this['listeners']['has'](_0x4435ce)&&this['listeners']['set'](_0x4435ce,new Set()),this['listeners']['get'](_0x4435ce)['add'](_0x21169b),this;}['off'](_0x6330a1,_0x5235fb){return this['listeners']['has'](_0x6330a1)&&this['listeners']['get'](_0x6330a1)['delete'](_0x5235fb),this;}['_emit'](_0x470aa4,_0x446ee3){this['listeners']['has'](_0x470aa4)&&this['listeners']['get'](_0x470aa4)['forEach'](_0x5de0a5=>{try{_0x5de0a5(_0x446ee3);}catch(_0x12cb35){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x470aa4+'\x20listener:',_0x12cb35);}});}['connect'](_0x38029e='me'){this['userId']=_0x38029e,this['useSharedWorker']?this['_connectViaWorker'](_0x38029e):this['_connectDirect'](_0x38029e);}['_connectViaWorker'](_0x3cf0b8){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0x3cf0b8});}catch(_0xe09599){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0xe09599),this['useSharedWorker']=![],this['_connectDirect'](_0x3cf0b8);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x4eb265=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x4eb265),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0xd3957b){const _0x2a038f=_0xd3957b['data'];if(_0x2a038f['type']&&_0x2a038f['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x2a038f);return;}switch(_0x2a038f['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0x14d9b3=JSON['parse'](_0x2a038f['data']);this['_emit'](_0x2a038f['type'],_0x14d9b3);}catch(_0x3b4d4e){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x2a038f['type']+'\x20data:',_0x3b4d4e);}break;case'error':this['connected']=![],this['_emit']('error',_0x2a038f);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x2a038f['type']);}}['_handleTaskStreamMessage'](_0x1cd6c0){const {taskId:_0x357466,type:_0x27d6db,data:_0x38d17d}=_0x1cd6c0,_0x8e16db=this['_taskSubscriptions']['get'](_0x357466);if(!_0x8e16db||_0x8e16db['size']===0x0)return;const _0x12a739=_0x27d6db['replace']('task:',''),_0x57790b=eventTypeToHandler(_0x12a739);_0x8e16db['forEach'](_0x33d248=>{if(_0x33d248['handlers'][_0x57790b])try{const _0x5d0ad3=typeof _0x38d17d==='string'?JSON['parse'](_0x38d17d):_0x38d17d;_0x33d248['handlers'][_0x57790b](_0x5d0ad3);}catch(_0x522fd0){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x12a739+'\x20handler:',_0x522fd0);}});}['_connectDirect'](_0x232fb7){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0x3dd1e0=_0x232fb7&&_0x232fb7!=='me'?'?userId='+_0x232fb7:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0x3dd1e0),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x359e51=>{this['_handleDirectSSE']('snapshot',_0x359e51),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x868166=>{this['_handleDirectSSE']('activity',_0x868166);}),this['eventSource']['addEventListener']('status',_0x2dab8c=>{this['_handleDirectSSE']('status',_0x2dab8c);}),this['eventSource']['addEventListener']('new-task',_0x1dbc8a=>{this['_handleDirectSSE']('new-task',_0x1dbc8a);}),this['eventSource']['addEventListener']('queue-position',_0x4b2804=>{this['_handleDirectSSE']('queue-position',_0x4b2804);}),this['eventSource']['addEventListener']('error',_0xa3ed09=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0xa3ed09),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0xf5db7f){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0xf5db7f),this['_emit']('error',{'error':_0xf5db7f['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0xee9a7f,_0x2c7eca){try{const _0x1c17fb=JSON['parse'](_0x2c7eca['data']);this['_emit'](_0xee9a7f,_0x1c17fb);}catch(_0x257a1a){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0xee9a7f+'\x20data:',_0x257a1a);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x2cec92=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x2cec92+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x2cec92);}['changeFilter'](_0x541bd1){if(_0x541bd1===this['userId'])return;this['userId']=_0x541bd1;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x541bd1});else this['eventSource']&&this['_connectDirect'](_0x541bd1);}['subscribeTask'](_0x24081c,_0x1085c0){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x24081c,_0x1085c0):this['_subscribeTaskDirect'](_0x24081c,_0x1085c0);}['unsubscribeTask'](_0x5b4077){if(!_0x5b4077)return;_0x5b4077['type']==='worker'?this['_unsubscribeTaskWorker'](_0x5b4077):this['_unsubscribeTaskDirect'](_0x5b4077);}['_subscribeTaskViaWorker'](_0x6d8b50,_0x29c2df){try{this['_ensureWorker']();}catch(_0x3bddbb){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x3bddbb),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0x6d8b50,_0x29c2df);}const _0x566e01=++this['_taskSubIdCounter'],_0xc9ee51={'type':'worker','taskId':_0x6d8b50,'handlers':_0x29c2df,'id':_0x566e01};return!this['_taskSubscriptions']['has'](_0x6d8b50)&&(this['_taskSubscriptions']['set'](_0x6d8b50,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0x6d8b50})),this['_taskSubscriptions']['get'](_0x6d8b50)['add'](_0xc9ee51),_0xc9ee51;}['_unsubscribeTaskWorker'](_0xba0324){const {taskId:_0x4737cb}=_0xba0324,_0x4b9519=this['_taskSubscriptions']['get'](_0x4737cb);if(_0x4b9519){_0x4b9519['delete'](_0xba0324);if(_0x4b9519['size']===0x0){this['_taskSubscriptions']['delete'](_0x4737cb);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x4737cb});}catch(_0x55dcde){}}}}['_subscribeTaskDirect'](_0x3218ca,_0x5798c0){const _0x15c258=++this['_taskSubIdCounter'],_0x404dc5=new EventSource('/tasks/'+_0x3218ca+'/stream'),_0x5deeb6={'type':'direct','taskId':_0x3218ca,'handlers':_0x5798c0,'id':_0x15c258,'eventSource':_0x404dc5};!this['_taskSubscriptions']['has'](_0x3218ca)&&this['_taskSubscriptions']['set'](_0x3218ca,new Set());this['_taskSubscriptions']['get'](_0x3218ca)['add'](_0x5deeb6);for(const _0x504d40 of TASK_STREAM_EVENTS){const _0x125c04=eventTypeToHandler(_0x504d40);_0x404dc5['addEventListener'](_0x504d40,_0x47b800=>{if(_0x5798c0[_0x125c04])try{const _0xff76ef=JSON['parse'](_0x47b800['data']);_0x5798c0[_0x125c04](_0xff76ef);}catch(_0x46c324){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x504d40+':',_0x46c324);}});}return _0x404dc5['addEventListener']('open',()=>{if(_0x5798c0['onConnected'])_0x5798c0['onConnected']();}),_0x404dc5['addEventListener']('error',()=>{if(_0x5798c0['onError'])_0x5798c0['onError']({'error':'Connection\x20error'});}),_0x5deeb6;}['_unsubscribeTaskDirect'](_0x5f2789){_0x5f2789['eventSource']&&(_0x5f2789['eventSource']['close'](),_0x5f2789['eventSource']=null);const _0x381836=this['_taskSubscriptions']['get'](_0x5f2789['taskId']);_0x381836&&(_0x381836['delete'](_0x5f2789),_0x381836['size']===0x0&&this['_taskSubscriptions']['delete'](_0x5f2789['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x5e63d2,_0x5f3021)=>{_0x5e63d2['forEach'](_0x91f0d0=>{_0x91f0d0['type']==='direct'&&_0x91f0d0['eventSource']&&_0x91f0d0['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0x4ce07f){}this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['connected']=![];}['isConnected'](){return this['connected'];}['isUsingSharedWorker'](){return this['useSharedWorker'];}}let globalClient=null;export function getTaskUpdatesClient(){return!globalClient&&(globalClient=new TaskUpdatesClient()),globalClient;}
@@ -1 +1 @@
1
- const ports=new Set();let eventSource=null,currentUserId=null,reconnectTimeout=null,reconnectAttempts=0x0;const MAX_RECONNECT_DELAY=0x7530,taskStreams=new Map(),TASK_STREAM_EVENTS=['activity','logs','metadata','summary','changed-files','app-server-status','complete'];function connect(_0x1b334a){eventSource&&currentUserId!==_0x1b334a&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0x1b334a;const _0x2101a2=_0x1b334a&&_0x1b334a!=='me'?'?userId='+_0x1b334a:'';try{eventSource=new EventSource('/tasks/updates'+_0x2101a2),eventSource['addEventListener']('snapshot',_0x5626a6=>{broadcast({'type':'snapshot','data':_0x5626a6['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x46f5c9=>{broadcast({'type':'activity','data':_0x46f5c9['data']});}),eventSource['addEventListener']('status',_0x311d1a=>{broadcast({'type':'status','data':_0x311d1a['data']});}),eventSource['addEventListener']('new-task',_0x51f36b=>{broadcast({'type':'new-task','data':_0x51f36b['data']});}),eventSource['addEventListener']('queue-position',_0x1e20ed=>{broadcast({'type':'queue-position','data':_0x1e20ed['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0x2c9c34=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0x2c9c34),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0x4ac998){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0x4ac998),broadcast({'type':'error','error':_0x4ac998['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x51a1d0=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x51a1d0+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x51a1d0);}function broadcast(_0x54bf6e){const _0x49af10=[];ports['forEach'](_0x57c096=>{try{_0x57c096['postMessage'](_0x54bf6e);}catch(_0x40102c){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x40102c),_0x49af10['push'](_0x57c096);}}),_0x49af10['length']>0x0&&cleanUpDeadPorts(_0x49af10),ports['size']===0x0&&eventSource&&(console['log']('[SSE\x20Worker]\x20No\x20more\x20connected\x20ports,\x20closing\x20SSE'),eventSource['close'](),eventSource=null,reconnectTimeout&&(clearTimeout(reconnectTimeout),reconnectTimeout=null));}function subscribeTask(_0x12657f,_0xf167c5){let _0x4ca334=taskStreams['get'](_0xf167c5);!_0x4ca334&&(_0x4ca334={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0xf167c5,_0x4ca334));_0x4ca334['subscribedPorts']['add'](_0x12657f);if(!_0x4ca334['eventSource']||_0x4ca334['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0xf167c5);else{if(_0x4ca334['eventSource']['readyState']===EventSource['OPEN'])try{_0x12657f['postMessage']({'type':'task:connected','taskId':_0xf167c5});}catch(_0x488347){}}}function unsubscribeTask(_0xd4e6e6,_0x8e6292){const _0x2744f9=taskStreams['get'](_0x8e6292);if(!_0x2744f9)return;_0x2744f9['subscribedPorts']['delete'](_0xd4e6e6),_0x2744f9['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x8e6292);}function connectTaskStream(_0x47f2fd){const _0x3476ac=taskStreams['get'](_0x47f2fd);if(!_0x3476ac)return;_0x3476ac['eventSource']&&(_0x3476ac['eventSource']['close'](),_0x3476ac['eventSource']=null);try{_0x3476ac['eventSource']=new EventSource('/tasks/'+_0x47f2fd+'/stream');for(const _0x598ddb of TASK_STREAM_EVENTS){_0x3476ac['eventSource']['addEventListener'](_0x598ddb,_0x2fc395=>{broadcastToTask(_0x47f2fd,'task:'+_0x598ddb,_0x2fc395['data']),_0x3476ac['reconnectAttempts']=0x0;});}_0x3476ac['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x47f2fd,'task:connected','{}'),_0x3476ac['reconnectAttempts']=0x0;}),_0x3476ac['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x47f2fd,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0x3476ac['eventSource']&&(_0x3476ac['eventSource']['close'](),_0x3476ac['eventSource']=null),scheduleTaskReconnect(_0x47f2fd);});}catch(_0x42ffbc){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x47f2fd+':',_0x42ffbc),broadcastToTask(_0x47f2fd,'task:error',JSON['stringify']({'error':_0x42ffbc['message']})),scheduleTaskReconnect(_0x47f2fd);}}function broadcastToTask(_0x2ef8b2,_0x34973e,_0x2a9063){const _0x5e0e64=taskStreams['get'](_0x2ef8b2);if(!_0x5e0e64)return;const _0x571539=[];_0x5e0e64['subscribedPorts']['forEach'](_0x5072e7=>{try{_0x5072e7['postMessage']({'type':_0x34973e,'taskId':_0x2ef8b2,'data':_0x2a9063});}catch(_0x235e7b){_0x571539['push'](_0x5072e7);}}),_0x571539['length']>0x0&&(_0x571539['forEach'](_0x690bbb=>_0x5e0e64['subscribedPorts']['delete'](_0x690bbb)),cleanUpDeadPorts(_0x571539),_0x5e0e64['subscribedPorts']['size']===0x0&&closeTaskStream(_0x2ef8b2));}function closeTaskStream(_0x21c9d2){const _0x4b6241=taskStreams['get'](_0x21c9d2);if(!_0x4b6241)return;_0x4b6241['eventSource']&&_0x4b6241['eventSource']['close'](),_0x4b6241['reconnectTimeout']&&clearTimeout(_0x4b6241['reconnectTimeout']),taskStreams['delete'](_0x21c9d2);}function deferredCloseTaskStream(_0x182f86){setTimeout(()=>{const _0x3087bb=taskStreams['get'](_0x182f86);_0x3087bb&&_0x3087bb['subscribedPorts']['size']===0x0&&closeTaskStream(_0x182f86);},0x0);}function scheduleTaskReconnect(_0x1034d6){const _0x1e63a1=taskStreams['get'](_0x1034d6);if(!_0x1e63a1||_0x1e63a1['subscribedPorts']['size']===0x0)return;_0x1e63a1['reconnectTimeout']&&clearTimeout(_0x1e63a1['reconnectTimeout']);const _0xa123c7=Math['min'](0x3e8*Math['pow'](0x2,_0x1e63a1['reconnectAttempts']),MAX_RECONNECT_DELAY);_0x1e63a1['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x1034d6+'\x20in\x20'+_0xa123c7+'ms'),_0x1e63a1['reconnectTimeout']=setTimeout(()=>{_0x1e63a1['subscribedPorts']['size']>0x0&&connectTaskStream(_0x1034d6);},_0xa123c7);}function cleanUpDeadPorts(_0x45cbb0){for(const _0x2df3b7 of _0x45cbb0){ports['delete'](_0x2df3b7),taskStreams['forEach']((_0x36ef2d,_0xd6408f)=>{_0x36ef2d['subscribedPorts']['delete'](_0x2df3b7),_0x36ef2d['subscribedPorts']['size']===0x0&&closeTaskStream(_0xd6408f);});}}function removePortFromAllTasks(_0x456373){taskStreams['forEach']((_0x4ee93a,_0x22e7c0)=>{_0x4ee93a['subscribedPorts']['has'](_0x456373)&&(_0x4ee93a['subscribedPorts']['delete'](_0x456373),_0x4ee93a['subscribedPorts']['size']===0x0&&closeTaskStream(_0x22e7c0));});}self['onconnect']=function(_0x45b6dc){const _0x818a78=_0x45b6dc['ports'][0x0];ports['add'](_0x818a78),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0x818a78['onmessage']=function(_0x32e0e7){const {action:_0x31fd9a,userId:_0xe814ba,taskId:_0x5e836b}=_0x32e0e7['data'];switch(_0x31fd9a){case'connect':connect(_0xe814ba);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0x818a78['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0x818a78),removePortFromAllTasks(_0x818a78),console['log']('[SSE\x20Worker]\x20Port\x20disconnected.\x20Total\x20ports:\x20'+ports['size']);ports['size']===0x0&&eventSource&&(eventSource['close'](),eventSource=null,reconnectTimeout&&(clearTimeout(reconnectTimeout),reconnectTimeout=null));break;case'changeFilter':_0xe814ba!==currentUserId&&connect(_0xe814ba);break;case'subscribeTask':subscribeTask(_0x818a78,_0x5e836b);break;case'unsubscribeTask':unsubscribeTask(_0x818a78,_0x5e836b);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0x31fd9a);}},_0x818a78['onmessageerror']=function(_0x59792f){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x59792f),ports['delete'](_0x818a78),removePortFromAllTasks(_0x818a78);},_0x818a78['start']();};
1
+ const ports=new Set();let eventSource=null,currentUserId=null,reconnectTimeout=null,reconnectAttempts=0x0;const MAX_RECONNECT_DELAY=0x7530,taskStreams=new Map(),TASK_STREAM_EVENTS=['activity','logs','metadata','summary','changed-files','app-server-status','complete'];function connect(_0x1a2ecf){eventSource&&currentUserId!==_0x1a2ecf&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0x1a2ecf;const _0x5aae88=_0x1a2ecf&&_0x1a2ecf!=='me'?'?userId='+_0x1a2ecf:'';try{eventSource=new EventSource('/tasks/updates'+_0x5aae88),eventSource['addEventListener']('snapshot',_0x1f7f97=>{broadcast({'type':'snapshot','data':_0x1f7f97['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x28ed0b=>{broadcast({'type':'activity','data':_0x28ed0b['data']});}),eventSource['addEventListener']('status',_0x55b499=>{broadcast({'type':'status','data':_0x55b499['data']});}),eventSource['addEventListener']('new-task',_0x3f3818=>{broadcast({'type':'new-task','data':_0x3f3818['data']});}),eventSource['addEventListener']('queue-position',_0x396954=>{broadcast({'type':'queue-position','data':_0x396954['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0x32c073=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0x32c073),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0x1ea528){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0x1ea528),broadcast({'type':'error','error':_0x1ea528['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x513907=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x513907+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x513907);}function broadcast(_0x56a96c){const _0x46e3ca=[];ports['forEach'](_0x55a9c0=>{try{_0x55a9c0['postMessage'](_0x56a96c);}catch(_0x52aa2f){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x52aa2f),_0x46e3ca['push'](_0x55a9c0);}}),_0x46e3ca['length']>0x0&&cleanUpDeadPorts(_0x46e3ca),ports['size']===0x0&&eventSource&&(console['log']('[SSE\x20Worker]\x20No\x20more\x20connected\x20ports,\x20closing\x20SSE'),eventSource['close'](),eventSource=null,reconnectTimeout&&(clearTimeout(reconnectTimeout),reconnectTimeout=null));}function subscribeTask(_0xbacf6a,_0x1693c9){let _0x2d36a4=taskStreams['get'](_0x1693c9);!_0x2d36a4&&(_0x2d36a4={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0x1693c9,_0x2d36a4));_0x2d36a4['subscribedPorts']['add'](_0xbacf6a);if(!_0x2d36a4['eventSource']||_0x2d36a4['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0x1693c9);else{if(_0x2d36a4['eventSource']['readyState']===EventSource['OPEN'])try{_0xbacf6a['postMessage']({'type':'task:connected','taskId':_0x1693c9});}catch(_0x439893){}}}function unsubscribeTask(_0x3bd5d6,_0x227164){const _0x6314f0=taskStreams['get'](_0x227164);if(!_0x6314f0)return;_0x6314f0['subscribedPorts']['delete'](_0x3bd5d6),_0x6314f0['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x227164);}function connectTaskStream(_0x4889f4){const _0xd01d5a=taskStreams['get'](_0x4889f4);if(!_0xd01d5a)return;_0xd01d5a['eventSource']&&(_0xd01d5a['eventSource']['close'](),_0xd01d5a['eventSource']=null);try{_0xd01d5a['eventSource']=new EventSource('/tasks/'+_0x4889f4+'/stream');for(const _0x39394d of TASK_STREAM_EVENTS){_0xd01d5a['eventSource']['addEventListener'](_0x39394d,_0xf6a2a0=>{broadcastToTask(_0x4889f4,'task:'+_0x39394d,_0xf6a2a0['data']),_0xd01d5a['reconnectAttempts']=0x0;});}_0xd01d5a['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x4889f4,'task:connected','{}'),_0xd01d5a['reconnectAttempts']=0x0;}),_0xd01d5a['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x4889f4,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0xd01d5a['eventSource']&&(_0xd01d5a['eventSource']['close'](),_0xd01d5a['eventSource']=null),scheduleTaskReconnect(_0x4889f4);});}catch(_0x264f88){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x4889f4+':',_0x264f88),broadcastToTask(_0x4889f4,'task:error',JSON['stringify']({'error':_0x264f88['message']})),scheduleTaskReconnect(_0x4889f4);}}function broadcastToTask(_0x23367a,_0x32eeb3,_0x9d5fe2){const _0x4f30c8=taskStreams['get'](_0x23367a);if(!_0x4f30c8)return;const _0x197a67=[];_0x4f30c8['subscribedPorts']['forEach'](_0x4ff76d=>{try{_0x4ff76d['postMessage']({'type':_0x32eeb3,'taskId':_0x23367a,'data':_0x9d5fe2});}catch(_0x3e2c37){_0x197a67['push'](_0x4ff76d);}}),_0x197a67['length']>0x0&&(_0x197a67['forEach'](_0x4752ba=>_0x4f30c8['subscribedPorts']['delete'](_0x4752ba)),cleanUpDeadPorts(_0x197a67),_0x4f30c8['subscribedPorts']['size']===0x0&&closeTaskStream(_0x23367a));}function closeTaskStream(_0x5d9c77){const _0x516153=taskStreams['get'](_0x5d9c77);if(!_0x516153)return;_0x516153['eventSource']&&_0x516153['eventSource']['close'](),_0x516153['reconnectTimeout']&&clearTimeout(_0x516153['reconnectTimeout']),taskStreams['delete'](_0x5d9c77);}function deferredCloseTaskStream(_0x45d60a){setTimeout(()=>{const _0x74a010=taskStreams['get'](_0x45d60a);_0x74a010&&_0x74a010['subscribedPorts']['size']===0x0&&closeTaskStream(_0x45d60a);},0x0);}function scheduleTaskReconnect(_0x30e4bd){const _0x12b41b=taskStreams['get'](_0x30e4bd);if(!_0x12b41b||_0x12b41b['subscribedPorts']['size']===0x0)return;_0x12b41b['reconnectTimeout']&&clearTimeout(_0x12b41b['reconnectTimeout']);const _0xb82a4c=Math['min'](0x3e8*Math['pow'](0x2,_0x12b41b['reconnectAttempts']),MAX_RECONNECT_DELAY);_0x12b41b['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x30e4bd+'\x20in\x20'+_0xb82a4c+'ms'),_0x12b41b['reconnectTimeout']=setTimeout(()=>{_0x12b41b['subscribedPorts']['size']>0x0&&connectTaskStream(_0x30e4bd);},_0xb82a4c);}function cleanUpDeadPorts(_0x932539){for(const _0xd395 of _0x932539){ports['delete'](_0xd395),taskStreams['forEach']((_0x21c6be,_0x272e3e)=>{_0x21c6be['subscribedPorts']['delete'](_0xd395),_0x21c6be['subscribedPorts']['size']===0x0&&closeTaskStream(_0x272e3e);});}}function removePortFromAllTasks(_0x246e55){taskStreams['forEach']((_0x59f3a0,_0x5f1302)=>{_0x59f3a0['subscribedPorts']['has'](_0x246e55)&&(_0x59f3a0['subscribedPorts']['delete'](_0x246e55),_0x59f3a0['subscribedPorts']['size']===0x0&&closeTaskStream(_0x5f1302));});}self['onconnect']=function(_0x51ce41){const _0x3ab2ac=_0x51ce41['ports'][0x0];ports['add'](_0x3ab2ac),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0x3ab2ac['onmessage']=function(_0x4428e5){const {action:_0x1db2ce,userId:_0x3e4efe,taskId:_0x514924}=_0x4428e5['data'];switch(_0x1db2ce){case'connect':connect(_0x3e4efe);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0x3ab2ac['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0x3ab2ac),removePortFromAllTasks(_0x3ab2ac),console['log']('[SSE\x20Worker]\x20Port\x20disconnected.\x20Total\x20ports:\x20'+ports['size']);ports['size']===0x0&&eventSource&&(eventSource['close'](),eventSource=null,reconnectTimeout&&(clearTimeout(reconnectTimeout),reconnectTimeout=null));break;case'changeFilter':_0x3e4efe!==currentUserId&&connect(_0x3e4efe);break;case'subscribeTask':subscribeTask(_0x3ab2ac,_0x514924);break;case'unsubscribeTask':unsubscribeTask(_0x3ab2ac,_0x514924);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0x1db2ce);}},_0x3ab2ac['onmessageerror']=function(_0x48ee2c){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x48ee2c),ports['delete'](_0x3ab2ac),removePortFromAllTasks(_0x3ab2ac);},_0x3ab2ac['start']();};
@@ -22,7 +22,7 @@
22
22
  }
23
23
  })();
24
24
  </script>
25
- <link rel="stylesheet" href="styles.css?v=92">
25
+ <link rel="stylesheet" href="styles.css?v=93">
26
26
  <!-- Syntax highlighting -->
27
27
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css">
28
28
  <!-- Load libraries before modules (blocking) -->
@@ -35,10 +35,10 @@
35
35
  <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/5.3.0/fabric.min.js"></script>
36
36
  <script src="https://uicdn.toast.com/tui-color-picker/latest/tui-color-picker.js"></script>
37
37
  <script src="https://uicdn.toast.com/tui-image-editor/latest/tui-image-editor.js"></script>
38
- <script type="module" src="markdown-editor.js?v=1"></script>
39
- <script src="markdown-file-editor.js?v=1"></script>
40
- <script type="module" src="comments-widget.js?v=1"></script>
41
- <script type="module" src="task.js?v=71"></script>
38
+ <script type="module" src="markdown-editor.js?v=2"></script>
39
+ <script src="markdown-file-editor.js?v=2"></script>
40
+ <script type="module" src="comments-widget.js?v=2"></script>
41
+ <script type="module" src="task.js?v=72"></script>
42
42
  <!-- Dev QA shortcut: Ctrl+Shift+Q to launch current page in QA mode -->
43
43
  </head>
44
44
  <body>