@profoundlogic/coderflow-server 0.6.5 → 0.6.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (178) hide show
  1. package/dist/base-image/agent-wrapper.sh +1 -1
  2. package/dist/base-image/sync-repos.sh +7 -1
  3. package/dist/coder-server.js +1 -1
  4. package/dist/config/cli-models.json +0 -12
  5. package/dist/config.js +1 -1
  6. package/dist/lib/agent-keepalive.js +1 -1
  7. package/dist/lib/agent-models.js +1 -1
  8. package/dist/lib/api-keys.js +1 -1
  9. package/dist/lib/apiKeys.js +1 -1
  10. package/dist/lib/app-server-ports.js +1 -1
  11. package/dist/lib/auto-judge.js +1 -1
  12. package/dist/lib/automation-service.js +1 -1
  13. package/dist/lib/basic-auth.js +1 -1
  14. package/dist/lib/bindings.js +1 -1
  15. package/dist/lib/build-history.js +1 -1
  16. package/dist/lib/build-output-service.js +1 -1
  17. package/dist/lib/build-scheduler.js +1 -1
  18. package/dist/lib/build-service.js +1 -1
  19. package/dist/lib/ca-certificates.js +1 -1
  20. package/dist/lib/claude-oauth-refresh.js +1 -1
  21. package/dist/lib/cli/build.js +1 -1
  22. package/dist/lib/cli/cleanup-users.js +1 -1
  23. package/dist/lib/cli/config-command.js +1 -1
  24. package/dist/lib/cli/config.js +1 -1
  25. package/dist/lib/cli/create-user.js +1 -1
  26. package/dist/lib/cli/grant-admin.js +1 -1
  27. package/dist/lib/cli/init.js +1 -1
  28. package/dist/lib/cli/jira.js +1 -1
  29. package/dist/lib/cli/license.js +1 -1
  30. package/dist/lib/cli/list-roles.js +1 -1
  31. package/dist/lib/cli/list-users.js +1 -1
  32. package/dist/lib/cli/server-manager.js +1 -1
  33. package/dist/lib/cli/set-password.js +1 -1
  34. package/dist/lib/config-migration.js +1 -1
  35. package/dist/lib/container-credential-sync.js +1 -1
  36. package/dist/lib/container-tokens.js +1 -1
  37. package/dist/lib/data-dir.js +1 -1
  38. package/dist/lib/deployment-history.js +1 -1
  39. package/dist/lib/deployment-service.js +1 -1
  40. package/dist/lib/docker-utils.js +1 -1
  41. package/dist/lib/email.js +1 -1
  42. package/dist/lib/emailTemplates.js +1 -1
  43. package/dist/lib/entitlement.js +1 -1
  44. package/dist/lib/external-connections.js +1 -1
  45. package/dist/lib/fetch-utils.js +1 -1
  46. package/dist/lib/git-commit-details-route.js +1 -1
  47. package/dist/lib/git-history-diff-guardrails.js +1 -1
  48. package/dist/lib/git-provider-service.js +1 -1
  49. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  50. package/dist/lib/git-provider-setup/index.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  53. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  54. package/dist/lib/git-providers/github-app-provider.js +1 -1
  55. package/dist/lib/git-providers/index.js +1 -1
  56. package/dist/lib/git-providers/provider-factory.js +1 -1
  57. package/dist/lib/git-providers/provider-interface.js +1 -1
  58. package/dist/lib/github-urls.js +1 -1
  59. package/dist/lib/group-objective-linking.js +1 -1
  60. package/dist/lib/ibmi-sync.js +1 -1
  61. package/dist/lib/jira-client.js +1 -1
  62. package/dist/lib/judge-blinding.js +1 -1
  63. package/dist/lib/logger.js +1 -1
  64. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  65. package/dist/lib/model-fetcher.js +1 -1
  66. package/dist/lib/notifications.js +1 -1
  67. package/dist/lib/objective-context.js +1 -1
  68. package/dist/lib/oidc-auth.js +1 -1
  69. package/dist/lib/oidc-device-flow.js +1 -1
  70. package/dist/lib/passwordTokens.js +1 -1
  71. package/dist/lib/permission-resolver.js +1 -1
  72. package/dist/lib/pin-cascade.js +1 -1
  73. package/dist/lib/provider-accounts.js +1 -1
  74. package/dist/lib/provider-oauth.js +1 -1
  75. package/dist/lib/provider-profile.js +1 -1
  76. package/dist/lib/provider-token-refresh.js +1 -1
  77. package/dist/lib/rbac-user-state.js +1 -1
  78. package/dist/lib/request-url.js +1 -1
  79. package/dist/lib/rewind.js +1 -1
  80. package/dist/lib/role-definitions.js +1 -1
  81. package/dist/lib/roles.js +1 -1
  82. package/dist/lib/secrets.js +1 -1
  83. package/dist/lib/setup-repo-git-auth.js +1 -1
  84. package/dist/lib/state-capture.js +1 -1
  85. package/dist/lib/static-files.js +1 -1
  86. package/dist/lib/task-aliases.js +1 -0
  87. package/dist/lib/task-name-format.js +1 -1
  88. package/dist/lib/task-name-generator.js +1 -1
  89. package/dist/lib/task-source-metadata.js +1 -1
  90. package/dist/lib/teams.js +1 -1
  91. package/dist/lib/user-git-oauth.js +1 -1
  92. package/dist/lib/user-git-tokens.js +1 -1
  93. package/dist/lib/users.js +1 -1
  94. package/dist/middleware/requireAuth.js +1 -1
  95. package/dist/middleware/requireInit.js +1 -1
  96. package/dist/middleware/requirePermission.js +1 -1
  97. package/dist/package.json +1 -1
  98. package/dist/playwright.config.js +1 -1
  99. package/dist/playwright.task-terminal.config.js +1 -1
  100. package/dist/routes/apiKeys.js +1 -1
  101. package/dist/routes/auth-oidc.js +1 -1
  102. package/dist/routes/auth.js +1 -1
  103. package/dist/routes/automations.js +1 -1
  104. package/dist/routes/bindings.js +1 -1
  105. package/dist/routes/build.js +1 -1
  106. package/dist/routes/containers.js +1 -1
  107. package/dist/routes/deploy-task.js +1 -1
  108. package/dist/routes/environment-management.js +1 -1
  109. package/dist/routes/environments.js +1 -1
  110. package/dist/routes/external-skills.js +1 -1
  111. package/dist/routes/git-credentials.js +1 -1
  112. package/dist/routes/git-oauth.js +1 -1
  113. package/dist/routes/git-provider-setup.js +1 -1
  114. package/dist/routes/health.js +1 -1
  115. package/dist/routes/jira.js +1 -1
  116. package/dist/routes/objective-management.js +1 -1
  117. package/dist/routes/password.js +1 -1
  118. package/dist/routes/prompt.js +1 -1
  119. package/dist/routes/provider-auth.js +1 -1
  120. package/dist/routes/qa.js +1 -1
  121. package/dist/routes/roles.js +1 -1
  122. package/dist/routes/settings.js +1 -1
  123. package/dist/routes/skill-management.js +1 -1
  124. package/dist/routes/skills.js +1 -1
  125. package/dist/routes/tasks.js +1 -1
  126. package/dist/routes/teams.js +1 -1
  127. package/dist/routes/templates.js +1 -1
  128. package/dist/routes/test-task.js +1 -1
  129. package/dist/routes/test.js +1 -1
  130. package/dist/routes/users.js +1 -1
  131. package/dist/routes/visualizations.js +1 -1
  132. package/dist/scripts/create-user.js +1 -1
  133. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  134. package/dist/start.js +1 -1
  135. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  136. package/dist/web-ui/public/activity-feed.js +1 -1
  137. package/dist/web-ui/public/activity-formatters.js +1 -1
  138. package/dist/web-ui/public/agent-event-parser.js +1 -1
  139. package/dist/web-ui/public/app.js +1 -1
  140. package/dist/web-ui/public/approve-dialog.js +1 -1
  141. package/dist/web-ui/public/automation-links.js +1 -1
  142. package/dist/web-ui/public/automation-schedule.js +1 -1
  143. package/dist/web-ui/public/comments-widget.js +1 -1
  144. package/dist/web-ui/public/diff-utils.js +1 -1
  145. package/dist/web-ui/public/environments.js +1 -1
  146. package/dist/web-ui/public/feedback-widget.css +39 -0
  147. package/dist/web-ui/public/feedback-widget.js +1 -1
  148. package/dist/web-ui/public/file-selection-tree.js +1 -1
  149. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  150. package/dist/web-ui/public/git-history.js +1 -1
  151. package/dist/web-ui/public/git-status.js +1 -1
  152. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  153. package/dist/web-ui/public/index.js +1 -1
  154. package/dist/web-ui/public/login.js +1 -1
  155. package/dist/web-ui/public/markdown-editor.js +1 -1
  156. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  157. package/dist/web-ui/public/modal-maximize.js +1 -1
  158. package/dist/web-ui/public/notifications.js +1 -1
  159. package/dist/web-ui/public/permissions.js +1 -1
  160. package/dist/web-ui/public/pr-dialog.js +1 -1
  161. package/dist/web-ui/public/roles.js +1 -1
  162. package/dist/web-ui/public/server-health.js +1 -1
  163. package/dist/web-ui/public/settings.html +0 -4
  164. package/dist/web-ui/public/settings.js +1 -1
  165. package/dist/web-ui/public/setup-password.js +1 -1
  166. package/dist/web-ui/public/skills.js +1 -1
  167. package/dist/web-ui/public/sse-client.js +1 -1
  168. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  169. package/dist/web-ui/public/styles.css +34 -0
  170. package/dist/web-ui/public/task-judging-helpers.js +1 -0
  171. package/dist/web-ui/public/task.html +1 -0
  172. package/dist/web-ui/public/task.js +1 -1
  173. package/dist/web-ui/public/teams.js +1 -1
  174. package/dist/web-ui/public/terminal.js +1 -1
  175. package/dist/web-ui/public/theme.js +1 -1
  176. package/dist/web-ui/public/users.js +1 -1
  177. package/dist/web-ui/public/variant-grouping.js +1 -1
  178. package/package.json +1 -1
@@ -1 +1 @@
1
- function isSharedWorkerSupported(){return typeof SharedWorker!=='undefined';}function eventTypeToHandler(_0x4d8812){if(_0x4d8812==='connected')return'onConnected';if(_0x4d8812==='error')return'onError';return'on'+_0x4d8812['split']('-')['map'](_0x34e0e8=>_0x34e0e8['charAt'](0x0)['toUpperCase']()+_0x34e0e8['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'](_0x486fcc,_0x2f8664){return!this['listeners']['has'](_0x486fcc)&&this['listeners']['set'](_0x486fcc,new Set()),this['listeners']['get'](_0x486fcc)['add'](_0x2f8664),this;}['off'](_0x3c1064,_0x586d86){return this['listeners']['has'](_0x3c1064)&&this['listeners']['get'](_0x3c1064)['delete'](_0x586d86),this;}['_emit'](_0x24ff4b,_0x377763){this['listeners']['has'](_0x24ff4b)&&this['listeners']['get'](_0x24ff4b)['forEach'](_0x2b5e21=>{try{_0x2b5e21(_0x377763);}catch(_0x45ff5a){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x24ff4b+'\x20listener:',_0x45ff5a);}});}['connect'](_0x573299='me'){this['userId']=_0x573299,this['useSharedWorker']?this['_connectViaWorker'](_0x573299):this['_connectDirect'](_0x573299);}['_connectViaWorker'](_0xd7cdcd){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0xd7cdcd});}catch(_0x5550a7){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0x5550a7),this['useSharedWorker']=![],this['_connectDirect'](_0xd7cdcd);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x5225da=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x5225da),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0x50caf9){const _0x2ab04b=_0x50caf9['data'];if(_0x2ab04b['type']&&_0x2ab04b['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x2ab04b);return;}switch(_0x2ab04b['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0x57acc3=JSON['parse'](_0x2ab04b['data']);this['_emit'](_0x2ab04b['type'],_0x57acc3);}catch(_0x409e6f){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x2ab04b['type']+'\x20data:',_0x409e6f);}break;case'error':this['connected']=![],this['_emit']('error',_0x2ab04b);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x2ab04b['type']);}}['_handleTaskStreamMessage'](_0x34fe1f){const {taskId:_0x1185f1,type:_0x4957d8,data:_0x3a5da8}=_0x34fe1f,_0x457d39=this['_taskSubscriptions']['get'](_0x1185f1);if(!_0x457d39||_0x457d39['size']===0x0)return;const _0x2e6ea8=_0x4957d8['replace']('task:',''),_0xc065a7=eventTypeToHandler(_0x2e6ea8);_0x457d39['forEach'](_0x315640=>{if(_0x315640['handlers'][_0xc065a7])try{const _0x56d552=typeof _0x3a5da8==='string'?JSON['parse'](_0x3a5da8):_0x3a5da8;_0x315640['handlers'][_0xc065a7](_0x56d552);}catch(_0x23e62a){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x2e6ea8+'\x20handler:',_0x23e62a);}});}['_connectDirect'](_0x4cd21a){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0x21b207=_0x4cd21a&&_0x4cd21a!=='me'?'?userId='+_0x4cd21a:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0x21b207),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x4625c7=>{this['_handleDirectSSE']('snapshot',_0x4625c7),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x12ab6a=>{this['_handleDirectSSE']('activity',_0x12ab6a);}),this['eventSource']['addEventListener']('status',_0x2b2a7f=>{this['_handleDirectSSE']('status',_0x2b2a7f);}),this['eventSource']['addEventListener']('new-task',_0x10d705=>{this['_handleDirectSSE']('new-task',_0x10d705);}),this['eventSource']['addEventListener']('queue-position',_0x5a1b24=>{this['_handleDirectSSE']('queue-position',_0x5a1b24);}),this['eventSource']['addEventListener']('error',_0x363453=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0x363453),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0x4de314){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0x4de314),this['_emit']('error',{'error':_0x4de314['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0x200df6,_0x54e7c1){try{const _0x2bd921=JSON['parse'](_0x54e7c1['data']);this['_emit'](_0x200df6,_0x2bd921);}catch(_0x18b005){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x200df6+'\x20data:',_0x18b005);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x3cc4e6=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x3cc4e6+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x3cc4e6);}['changeFilter'](_0x1f6ee6){if(_0x1f6ee6===this['userId'])return;this['userId']=_0x1f6ee6;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x1f6ee6});else this['eventSource']&&this['_connectDirect'](_0x1f6ee6);}['subscribeTask'](_0x278dfa,_0x265463){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x278dfa,_0x265463):this['_subscribeTaskDirect'](_0x278dfa,_0x265463);}['unsubscribeTask'](_0x2352f4){if(!_0x2352f4)return;_0x2352f4['type']==='worker'?this['_unsubscribeTaskWorker'](_0x2352f4):this['_unsubscribeTaskDirect'](_0x2352f4);}['_subscribeTaskViaWorker'](_0x1c6394,_0x1b8a97){try{this['_ensureWorker']();}catch(_0x5e29cf){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x5e29cf),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0x1c6394,_0x1b8a97);}const _0x22d756=++this['_taskSubIdCounter'],_0x1a1d96={'type':'worker','taskId':_0x1c6394,'handlers':_0x1b8a97,'id':_0x22d756};return!this['_taskSubscriptions']['has'](_0x1c6394)&&(this['_taskSubscriptions']['set'](_0x1c6394,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0x1c6394})),this['_taskSubscriptions']['get'](_0x1c6394)['add'](_0x1a1d96),_0x1a1d96;}['_unsubscribeTaskWorker'](_0x2de5b2){const {taskId:_0x5a0aef}=_0x2de5b2,_0x319234=this['_taskSubscriptions']['get'](_0x5a0aef);if(_0x319234){_0x319234['delete'](_0x2de5b2);if(_0x319234['size']===0x0){this['_taskSubscriptions']['delete'](_0x5a0aef);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x5a0aef});}catch(_0x152cc7){}}}}['_subscribeTaskDirect'](_0x521ff1,_0x172e78){const _0x3827f8=++this['_taskSubIdCounter'],_0x4bd067=new EventSource('/tasks/'+_0x521ff1+'/stream'),_0x1f2e7d={'type':'direct','taskId':_0x521ff1,'handlers':_0x172e78,'id':_0x3827f8,'eventSource':_0x4bd067};!this['_taskSubscriptions']['has'](_0x521ff1)&&this['_taskSubscriptions']['set'](_0x521ff1,new Set());this['_taskSubscriptions']['get'](_0x521ff1)['add'](_0x1f2e7d);for(const _0x5d6d68 of TASK_STREAM_EVENTS){const _0x2aa353=eventTypeToHandler(_0x5d6d68);_0x4bd067['addEventListener'](_0x5d6d68,_0x256f41=>{if(_0x172e78[_0x2aa353])try{const _0x3e582d=JSON['parse'](_0x256f41['data']);_0x172e78[_0x2aa353](_0x3e582d);}catch(_0x23a6f5){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x5d6d68+':',_0x23a6f5);}});}return _0x4bd067['addEventListener']('open',()=>{if(_0x172e78['onConnected'])_0x172e78['onConnected']();}),_0x4bd067['addEventListener']('error',()=>{if(_0x172e78['onError'])_0x172e78['onError']({'error':'Connection\x20error'});}),_0x1f2e7d;}['_unsubscribeTaskDirect'](_0x38239c){_0x38239c['eventSource']&&(_0x38239c['eventSource']['close'](),_0x38239c['eventSource']=null);const _0x113f08=this['_taskSubscriptions']['get'](_0x38239c['taskId']);_0x113f08&&(_0x113f08['delete'](_0x38239c),_0x113f08['size']===0x0&&this['_taskSubscriptions']['delete'](_0x38239c['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x282c9a,_0x4e078d)=>{_0x282c9a['forEach'](_0x3c79e8=>{_0x3c79e8['type']==='direct'&&_0x3c79e8['eventSource']&&_0x3c79e8['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0x4fe5cb){}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(_0x7f8428){if(_0x7f8428==='connected')return'onConnected';if(_0x7f8428==='error')return'onError';return'on'+_0x7f8428['split']('-')['map'](_0x512025=>_0x512025['charAt'](0x0)['toUpperCase']()+_0x512025['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'](_0x30121d,_0x5b43b0){return!this['listeners']['has'](_0x30121d)&&this['listeners']['set'](_0x30121d,new Set()),this['listeners']['get'](_0x30121d)['add'](_0x5b43b0),this;}['off'](_0x1dcd09,_0x1e11a3){return this['listeners']['has'](_0x1dcd09)&&this['listeners']['get'](_0x1dcd09)['delete'](_0x1e11a3),this;}['_emit'](_0x479be4,_0x174a8c){this['listeners']['has'](_0x479be4)&&this['listeners']['get'](_0x479be4)['forEach'](_0x9a9c5f=>{try{_0x9a9c5f(_0x174a8c);}catch(_0x4fdaa1){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x479be4+'\x20listener:',_0x4fdaa1);}});}['connect'](_0xd7a370='me'){this['userId']=_0xd7a370,this['useSharedWorker']?this['_connectViaWorker'](_0xd7a370):this['_connectDirect'](_0xd7a370);}['_connectViaWorker'](_0x26275e){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0x26275e});}catch(_0x57d261){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0x57d261),this['useSharedWorker']=![],this['_connectDirect'](_0x26275e);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x350ac1=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x350ac1),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0x60fae5){const _0x156875=_0x60fae5['data'];if(_0x156875['type']&&_0x156875['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x156875);return;}switch(_0x156875['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0x56604a=JSON['parse'](_0x156875['data']);this['_emit'](_0x156875['type'],_0x56604a);}catch(_0x22c9a3){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x156875['type']+'\x20data:',_0x22c9a3);}break;case'error':this['connected']=![],this['_emit']('error',_0x156875);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x156875['type']);}}['_handleTaskStreamMessage'](_0x433db0){const {taskId:_0x3a6cdf,type:_0x26ce23,data:_0x52db0f}=_0x433db0,_0x51b599=this['_taskSubscriptions']['get'](_0x3a6cdf);if(!_0x51b599||_0x51b599['size']===0x0)return;const _0x2c395c=_0x26ce23['replace']('task:',''),_0x5b3368=eventTypeToHandler(_0x2c395c);_0x51b599['forEach'](_0x3fdfaa=>{if(_0x3fdfaa['handlers'][_0x5b3368])try{const _0x3fe5e8=typeof _0x52db0f==='string'?JSON['parse'](_0x52db0f):_0x52db0f;_0x3fdfaa['handlers'][_0x5b3368](_0x3fe5e8);}catch(_0x8e1862){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x2c395c+'\x20handler:',_0x8e1862);}});}['_connectDirect'](_0x2f1fcd){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0xee193e=_0x2f1fcd&&_0x2f1fcd!=='me'?'?userId='+_0x2f1fcd:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0xee193e),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x9e4890=>{this['_handleDirectSSE']('snapshot',_0x9e4890),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x39a845=>{this['_handleDirectSSE']('activity',_0x39a845);}),this['eventSource']['addEventListener']('status',_0x57d8df=>{this['_handleDirectSSE']('status',_0x57d8df);}),this['eventSource']['addEventListener']('new-task',_0x5899f7=>{this['_handleDirectSSE']('new-task',_0x5899f7);}),this['eventSource']['addEventListener']('queue-position',_0x5513b6=>{this['_handleDirectSSE']('queue-position',_0x5513b6);}),this['eventSource']['addEventListener']('error',_0x36687a=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0x36687a),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0x11708f){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0x11708f),this['_emit']('error',{'error':_0x11708f['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0x2f6eb6,_0x3ba660){try{const _0x169146=JSON['parse'](_0x3ba660['data']);this['_emit'](_0x2f6eb6,_0x169146);}catch(_0x16f2fd){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x2f6eb6+'\x20data:',_0x16f2fd);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x2607bc=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x2607bc+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x2607bc);}['changeFilter'](_0x197abb){if(_0x197abb===this['userId'])return;this['userId']=_0x197abb;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x197abb});else this['eventSource']&&this['_connectDirect'](_0x197abb);}['subscribeTask'](_0x465f60,_0x2863aa){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x465f60,_0x2863aa):this['_subscribeTaskDirect'](_0x465f60,_0x2863aa);}['unsubscribeTask'](_0x21b0c9){if(!_0x21b0c9)return;_0x21b0c9['type']==='worker'?this['_unsubscribeTaskWorker'](_0x21b0c9):this['_unsubscribeTaskDirect'](_0x21b0c9);}['_subscribeTaskViaWorker'](_0xd492ee,_0x39a3a6){try{this['_ensureWorker']();}catch(_0x24611a){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x24611a),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0xd492ee,_0x39a3a6);}const _0x3f0f6f=++this['_taskSubIdCounter'],_0x26739a={'type':'worker','taskId':_0xd492ee,'handlers':_0x39a3a6,'id':_0x3f0f6f};return!this['_taskSubscriptions']['has'](_0xd492ee)&&(this['_taskSubscriptions']['set'](_0xd492ee,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0xd492ee})),this['_taskSubscriptions']['get'](_0xd492ee)['add'](_0x26739a),_0x26739a;}['_unsubscribeTaskWorker'](_0x277213){const {taskId:_0x1a5d1b}=_0x277213,_0x5a03d3=this['_taskSubscriptions']['get'](_0x1a5d1b);if(_0x5a03d3){_0x5a03d3['delete'](_0x277213);if(_0x5a03d3['size']===0x0){this['_taskSubscriptions']['delete'](_0x1a5d1b);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x1a5d1b});}catch(_0x5ca0b4){}}}}['_subscribeTaskDirect'](_0x409c96,_0x4f48a1){const _0x4f9725=++this['_taskSubIdCounter'],_0x43dded=new EventSource('/tasks/'+_0x409c96+'/stream'),_0x4c9b68={'type':'direct','taskId':_0x409c96,'handlers':_0x4f48a1,'id':_0x4f9725,'eventSource':_0x43dded};!this['_taskSubscriptions']['has'](_0x409c96)&&this['_taskSubscriptions']['set'](_0x409c96,new Set());this['_taskSubscriptions']['get'](_0x409c96)['add'](_0x4c9b68);for(const _0x25d623 of TASK_STREAM_EVENTS){const _0x4ad1fc=eventTypeToHandler(_0x25d623);_0x43dded['addEventListener'](_0x25d623,_0x3bda50=>{if(_0x4f48a1[_0x4ad1fc])try{const _0x35e8dd=JSON['parse'](_0x3bda50['data']);_0x4f48a1[_0x4ad1fc](_0x35e8dd);}catch(_0x539dbc){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x25d623+':',_0x539dbc);}});}return _0x43dded['addEventListener']('open',()=>{if(_0x4f48a1['onConnected'])_0x4f48a1['onConnected']();}),_0x43dded['addEventListener']('error',()=>{if(_0x4f48a1['onError'])_0x4f48a1['onError']({'error':'Connection\x20error'});}),_0x4c9b68;}['_unsubscribeTaskDirect'](_0x56e2b3){_0x56e2b3['eventSource']&&(_0x56e2b3['eventSource']['close'](),_0x56e2b3['eventSource']=null);const _0x318ff9=this['_taskSubscriptions']['get'](_0x56e2b3['taskId']);_0x318ff9&&(_0x318ff9['delete'](_0x56e2b3),_0x318ff9['size']===0x0&&this['_taskSubscriptions']['delete'](_0x56e2b3['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x39712b,_0x561e0f)=>{_0x39712b['forEach'](_0x184ef8=>{_0x184ef8['type']==='direct'&&_0x184ef8['eventSource']&&_0x184ef8['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0xb1063f){}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(_0xc007f7){eventSource&&currentUserId!==_0xc007f7&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0xc007f7;const _0x33b3d1=_0xc007f7&&_0xc007f7!=='me'?'?userId='+_0xc007f7:'';try{eventSource=new EventSource('/tasks/updates'+_0x33b3d1),eventSource['addEventListener']('snapshot',_0x1d5708=>{broadcast({'type':'snapshot','data':_0x1d5708['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x5c3f1f=>{broadcast({'type':'activity','data':_0x5c3f1f['data']});}),eventSource['addEventListener']('status',_0x2b3aaa=>{broadcast({'type':'status','data':_0x2b3aaa['data']});}),eventSource['addEventListener']('new-task',_0x449274=>{broadcast({'type':'new-task','data':_0x449274['data']});}),eventSource['addEventListener']('queue-position',_0x441674=>{broadcast({'type':'queue-position','data':_0x441674['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0x3d8e9d=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0x3d8e9d),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0x3ba163){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0x3ba163),broadcast({'type':'error','error':_0x3ba163['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x53ba7e=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x53ba7e+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x53ba7e);}function broadcast(_0x137e0e){const _0x3df8f3=[];ports['forEach'](_0x1815aa=>{try{_0x1815aa['postMessage'](_0x137e0e);}catch(_0x48945b){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x48945b),_0x3df8f3['push'](_0x1815aa);}}),_0x3df8f3['length']>0x0&&cleanUpDeadPorts(_0x3df8f3),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(_0x1ef6c1,_0x5959cd){let _0x74d14c=taskStreams['get'](_0x5959cd);!_0x74d14c&&(_0x74d14c={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0x5959cd,_0x74d14c));_0x74d14c['subscribedPorts']['add'](_0x1ef6c1);if(!_0x74d14c['eventSource']||_0x74d14c['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0x5959cd);else{if(_0x74d14c['eventSource']['readyState']===EventSource['OPEN'])try{_0x1ef6c1['postMessage']({'type':'task:connected','taskId':_0x5959cd});}catch(_0x94a1bc){}}}function unsubscribeTask(_0x2ff2e5,_0x507a28){const _0x9033d=taskStreams['get'](_0x507a28);if(!_0x9033d)return;_0x9033d['subscribedPorts']['delete'](_0x2ff2e5),_0x9033d['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x507a28);}function connectTaskStream(_0x238894){const _0x55a386=taskStreams['get'](_0x238894);if(!_0x55a386)return;_0x55a386['eventSource']&&(_0x55a386['eventSource']['close'](),_0x55a386['eventSource']=null);try{_0x55a386['eventSource']=new EventSource('/tasks/'+_0x238894+'/stream');for(const _0xc7a167 of TASK_STREAM_EVENTS){_0x55a386['eventSource']['addEventListener'](_0xc7a167,_0x381716=>{broadcastToTask(_0x238894,'task:'+_0xc7a167,_0x381716['data']),_0x55a386['reconnectAttempts']=0x0;});}_0x55a386['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x238894,'task:connected','{}'),_0x55a386['reconnectAttempts']=0x0;}),_0x55a386['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x238894,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0x55a386['eventSource']&&(_0x55a386['eventSource']['close'](),_0x55a386['eventSource']=null),scheduleTaskReconnect(_0x238894);});}catch(_0x5f2723){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x238894+':',_0x5f2723),broadcastToTask(_0x238894,'task:error',JSON['stringify']({'error':_0x5f2723['message']})),scheduleTaskReconnect(_0x238894);}}function broadcastToTask(_0x591216,_0x4fc941,_0x4fd17d){const _0x3cb018=taskStreams['get'](_0x591216);if(!_0x3cb018)return;const _0x5c4288=[];_0x3cb018['subscribedPorts']['forEach'](_0x90996a=>{try{_0x90996a['postMessage']({'type':_0x4fc941,'taskId':_0x591216,'data':_0x4fd17d});}catch(_0x2a423b){_0x5c4288['push'](_0x90996a);}}),_0x5c4288['length']>0x0&&(_0x5c4288['forEach'](_0x272d2b=>_0x3cb018['subscribedPorts']['delete'](_0x272d2b)),cleanUpDeadPorts(_0x5c4288),_0x3cb018['subscribedPorts']['size']===0x0&&closeTaskStream(_0x591216));}function closeTaskStream(_0x31c43c){const _0x458930=taskStreams['get'](_0x31c43c);if(!_0x458930)return;_0x458930['eventSource']&&_0x458930['eventSource']['close'](),_0x458930['reconnectTimeout']&&clearTimeout(_0x458930['reconnectTimeout']),taskStreams['delete'](_0x31c43c);}function deferredCloseTaskStream(_0xd7f662){setTimeout(()=>{const _0x64667d=taskStreams['get'](_0xd7f662);_0x64667d&&_0x64667d['subscribedPorts']['size']===0x0&&closeTaskStream(_0xd7f662);},0x0);}function scheduleTaskReconnect(_0x40fef4){const _0xc265e8=taskStreams['get'](_0x40fef4);if(!_0xc265e8||_0xc265e8['subscribedPorts']['size']===0x0)return;_0xc265e8['reconnectTimeout']&&clearTimeout(_0xc265e8['reconnectTimeout']);const _0x3b015a=Math['min'](0x3e8*Math['pow'](0x2,_0xc265e8['reconnectAttempts']),MAX_RECONNECT_DELAY);_0xc265e8['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x40fef4+'\x20in\x20'+_0x3b015a+'ms'),_0xc265e8['reconnectTimeout']=setTimeout(()=>{_0xc265e8['subscribedPorts']['size']>0x0&&connectTaskStream(_0x40fef4);},_0x3b015a);}function cleanUpDeadPorts(_0x5e9f72){for(const _0x2cfe9b of _0x5e9f72){ports['delete'](_0x2cfe9b),taskStreams['forEach']((_0x143271,_0x2bc11a)=>{_0x143271['subscribedPorts']['delete'](_0x2cfe9b),_0x143271['subscribedPorts']['size']===0x0&&closeTaskStream(_0x2bc11a);});}}function removePortFromAllTasks(_0x59c9bf){taskStreams['forEach']((_0x23981b,_0x19c8ca)=>{_0x23981b['subscribedPorts']['has'](_0x59c9bf)&&(_0x23981b['subscribedPorts']['delete'](_0x59c9bf),_0x23981b['subscribedPorts']['size']===0x0&&closeTaskStream(_0x19c8ca));});}self['onconnect']=function(_0xba9291){const _0xe4ce0=_0xba9291['ports'][0x0];ports['add'](_0xe4ce0),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0xe4ce0['onmessage']=function(_0x484f99){const {action:_0x1c379b,userId:_0x517f94,taskId:_0x47cb73}=_0x484f99['data'];switch(_0x1c379b){case'connect':connect(_0x517f94);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0xe4ce0['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0xe4ce0),removePortFromAllTasks(_0xe4ce0),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':_0x517f94!==currentUserId&&connect(_0x517f94);break;case'subscribeTask':subscribeTask(_0xe4ce0,_0x47cb73);break;case'unsubscribeTask':unsubscribeTask(_0xe4ce0,_0x47cb73);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0x1c379b);}},_0xe4ce0['onmessageerror']=function(_0x1941a6){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x1941a6),ports['delete'](_0xe4ce0),removePortFromAllTasks(_0xe4ce0);},_0xe4ce0['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(_0x36c72a){eventSource&&currentUserId!==_0x36c72a&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0x36c72a;const _0x1cb102=_0x36c72a&&_0x36c72a!=='me'?'?userId='+_0x36c72a:'';try{eventSource=new EventSource('/tasks/updates'+_0x1cb102),eventSource['addEventListener']('snapshot',_0x2f49da=>{broadcast({'type':'snapshot','data':_0x2f49da['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x1d0aad=>{broadcast({'type':'activity','data':_0x1d0aad['data']});}),eventSource['addEventListener']('status',_0x1191c5=>{broadcast({'type':'status','data':_0x1191c5['data']});}),eventSource['addEventListener']('new-task',_0x41d044=>{broadcast({'type':'new-task','data':_0x41d044['data']});}),eventSource['addEventListener']('queue-position',_0x29a649=>{broadcast({'type':'queue-position','data':_0x29a649['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0xb081c1=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0xb081c1),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0x5c2307){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0x5c2307),broadcast({'type':'error','error':_0x5c2307['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x2565f5=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x2565f5+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x2565f5);}function broadcast(_0x8947dc){const _0x15e09d=[];ports['forEach'](_0x303ec6=>{try{_0x303ec6['postMessage'](_0x8947dc);}catch(_0x4b0514){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x4b0514),_0x15e09d['push'](_0x303ec6);}}),_0x15e09d['length']>0x0&&cleanUpDeadPorts(_0x15e09d),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(_0x372881,_0x318210){let _0x4ae9fd=taskStreams['get'](_0x318210);!_0x4ae9fd&&(_0x4ae9fd={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0x318210,_0x4ae9fd));_0x4ae9fd['subscribedPorts']['add'](_0x372881);if(!_0x4ae9fd['eventSource']||_0x4ae9fd['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0x318210);else{if(_0x4ae9fd['eventSource']['readyState']===EventSource['OPEN'])try{_0x372881['postMessage']({'type':'task:connected','taskId':_0x318210});}catch(_0x3cc7bc){}}}function unsubscribeTask(_0x24075f,_0x488c73){const _0x177589=taskStreams['get'](_0x488c73);if(!_0x177589)return;_0x177589['subscribedPorts']['delete'](_0x24075f),_0x177589['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x488c73);}function connectTaskStream(_0x9e452b){const _0x3d4477=taskStreams['get'](_0x9e452b);if(!_0x3d4477)return;_0x3d4477['eventSource']&&(_0x3d4477['eventSource']['close'](),_0x3d4477['eventSource']=null);try{_0x3d4477['eventSource']=new EventSource('/tasks/'+_0x9e452b+'/stream');for(const _0x662a09 of TASK_STREAM_EVENTS){_0x3d4477['eventSource']['addEventListener'](_0x662a09,_0x34d35a=>{broadcastToTask(_0x9e452b,'task:'+_0x662a09,_0x34d35a['data']),_0x3d4477['reconnectAttempts']=0x0;});}_0x3d4477['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x9e452b,'task:connected','{}'),_0x3d4477['reconnectAttempts']=0x0;}),_0x3d4477['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x9e452b,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0x3d4477['eventSource']&&(_0x3d4477['eventSource']['close'](),_0x3d4477['eventSource']=null),scheduleTaskReconnect(_0x9e452b);});}catch(_0x8deb6d){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x9e452b+':',_0x8deb6d),broadcastToTask(_0x9e452b,'task:error',JSON['stringify']({'error':_0x8deb6d['message']})),scheduleTaskReconnect(_0x9e452b);}}function broadcastToTask(_0x46477e,_0x4c8c5c,_0x14a236){const _0xfe28e5=taskStreams['get'](_0x46477e);if(!_0xfe28e5)return;const _0x1a4b3d=[];_0xfe28e5['subscribedPorts']['forEach'](_0x3931a6=>{try{_0x3931a6['postMessage']({'type':_0x4c8c5c,'taskId':_0x46477e,'data':_0x14a236});}catch(_0xb47ef0){_0x1a4b3d['push'](_0x3931a6);}}),_0x1a4b3d['length']>0x0&&(_0x1a4b3d['forEach'](_0x94a6c0=>_0xfe28e5['subscribedPorts']['delete'](_0x94a6c0)),cleanUpDeadPorts(_0x1a4b3d),_0xfe28e5['subscribedPorts']['size']===0x0&&closeTaskStream(_0x46477e));}function closeTaskStream(_0x219e37){const _0x163f0e=taskStreams['get'](_0x219e37);if(!_0x163f0e)return;_0x163f0e['eventSource']&&_0x163f0e['eventSource']['close'](),_0x163f0e['reconnectTimeout']&&clearTimeout(_0x163f0e['reconnectTimeout']),taskStreams['delete'](_0x219e37);}function deferredCloseTaskStream(_0x1f56bd){setTimeout(()=>{const _0x5445e9=taskStreams['get'](_0x1f56bd);_0x5445e9&&_0x5445e9['subscribedPorts']['size']===0x0&&closeTaskStream(_0x1f56bd);},0x0);}function scheduleTaskReconnect(_0x1ef25a){const _0x532628=taskStreams['get'](_0x1ef25a);if(!_0x532628||_0x532628['subscribedPorts']['size']===0x0)return;_0x532628['reconnectTimeout']&&clearTimeout(_0x532628['reconnectTimeout']);const _0x26bcaf=Math['min'](0x3e8*Math['pow'](0x2,_0x532628['reconnectAttempts']),MAX_RECONNECT_DELAY);_0x532628['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x1ef25a+'\x20in\x20'+_0x26bcaf+'ms'),_0x532628['reconnectTimeout']=setTimeout(()=>{_0x532628['subscribedPorts']['size']>0x0&&connectTaskStream(_0x1ef25a);},_0x26bcaf);}function cleanUpDeadPorts(_0x5f141e){for(const _0xd541b3 of _0x5f141e){ports['delete'](_0xd541b3),taskStreams['forEach']((_0x46fa0a,_0x42417a)=>{_0x46fa0a['subscribedPorts']['delete'](_0xd541b3),_0x46fa0a['subscribedPorts']['size']===0x0&&closeTaskStream(_0x42417a);});}}function removePortFromAllTasks(_0x41749c){taskStreams['forEach']((_0x34073d,_0x51b8c7)=>{_0x34073d['subscribedPorts']['has'](_0x41749c)&&(_0x34073d['subscribedPorts']['delete'](_0x41749c),_0x34073d['subscribedPorts']['size']===0x0&&closeTaskStream(_0x51b8c7));});}self['onconnect']=function(_0x52a501){const _0x325fda=_0x52a501['ports'][0x0];ports['add'](_0x325fda),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0x325fda['onmessage']=function(_0x6662b3){const {action:_0x467f36,userId:_0x556309,taskId:_0x213d47}=_0x6662b3['data'];switch(_0x467f36){case'connect':connect(_0x556309);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0x325fda['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0x325fda),removePortFromAllTasks(_0x325fda),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':_0x556309!==currentUserId&&connect(_0x556309);break;case'subscribeTask':subscribeTask(_0x325fda,_0x213d47);break;case'unsubscribeTask':unsubscribeTask(_0x325fda,_0x213d47);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0x467f36);}},_0x325fda['onmessageerror']=function(_0x38be5d){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x38be5d),ports['delete'](_0x325fda),removePortFromAllTasks(_0x325fda);},_0x325fda['start']();};
@@ -16199,6 +16199,15 @@ input.toggle-switch:focus {
16199
16199
  background: var(--color-surface-muted);
16200
16200
  }
16201
16201
 
16202
+ .judgment-variant-task-link {
16203
+ color: var(--color-accent);
16204
+ text-decoration: none;
16205
+ }
16206
+
16207
+ .judgment-variant-task-link:hover {
16208
+ text-decoration: underline;
16209
+ }
16210
+
16202
16211
  .judgment-variant-copy-id-btn {
16203
16212
  border: 1px solid var(--color-border);
16204
16213
  background: var(--color-surface-muted);
@@ -16514,6 +16523,31 @@ input.toggle-switch:focus {
16514
16523
  gap: 8px;
16515
16524
  }
16516
16525
 
16526
+ .feedback-judgment-summary {
16527
+ margin-bottom: 16px;
16528
+ }
16529
+
16530
+ .feedback-judgment-meta {
16531
+ display: flex;
16532
+ flex-wrap: wrap;
16533
+ gap: 10px;
16534
+ }
16535
+
16536
+ .feedback-judgment-pill {
16537
+ display: inline-flex;
16538
+ align-items: center;
16539
+ gap: 8px;
16540
+ padding: 8px 12px;
16541
+ border-radius: 999px;
16542
+ background: rgba(0, 0, 0, 0.05);
16543
+ color: var(--color-text-secondary);
16544
+ font-size: 13px;
16545
+ }
16546
+
16547
+ .feedback-judgment-pill strong {
16548
+ color: var(--color-text);
16549
+ }
16550
+
16517
16551
  .toggle-feedback-btn {
16518
16552
  display: inline-flex;
16519
16553
  align-items: center;
@@ -0,0 +1 @@
1
+ export function toDisplayAgentName(_0x41d566,{fallback:fallback='Unknown'}={}){const _0x4728f0=String(_0x41d566||'')['trim']()['toLowerCase']();if(!_0x4728f0)return fallback;return _0x4728f0['charAt'](0x0)['toUpperCase']()+_0x4728f0['slice'](0x1);}export function escapeRegExp(_0x1e5ae5){return String(_0x1e5ae5)['replace'](/[.*+?^${}()|[\]\\]/g,'\x5c$&');}export function compareJudgmentsForAliasOrder(_0x3c6e95,_0x2b8541){const _0x255b0b=String(_0x3c6e95?.['createdAt']||''),_0x3e0843=String(_0x2b8541?.['createdAt']||'');if(_0x255b0b!==_0x3e0843)return _0x255b0b['localeCompare'](_0x3e0843);return String(_0x3c6e95?.['taskId']||'')['localeCompare'](String(_0x2b8541?.['taskId']||''));}export function parseJudgeAliasNumber(_0xaa388e,_0x4b725e){const _0x2e5391=typeof _0xaa388e==='string'?_0xaa388e['trim']():'',_0x24a17e=toDisplayAgentName(_0x4b725e,{'fallback':''});if(!_0x2e5391||!_0x24a17e)return null;const _0x3e02b9=_0x2e5391['toLowerCase'](),_0x134dca=_0x24a17e['toLowerCase']();if(_0x3e02b9===_0x134dca||_0x3e02b9===_0x134dca+'\x20judge')return 0x1;const _0x8448c4=[new RegExp('^'+escapeRegExp(_0x24a17e)+'\x5cs+(\x5cd+)$','i'),new RegExp('^'+escapeRegExp(_0x24a17e)+'\x5cs+Judge\x5cs+(\x5cd+)$','i')];for(const _0x4618ed of _0x8448c4){const _0x1c433a=_0x2e5391['match'](_0x4618ed);if(_0x1c433a){const _0x4644c0=Number(_0x1c433a[0x1]);if(Number['isInteger'](_0x4644c0)&&_0x4644c0>0x0)return _0x4644c0;}}return null;}export function formatJudgeDisplayName({alias:_0x18a7b4,agent:_0x390bbb,number:number=null,hasDuplicates:hasDuplicates=![]}={}){const _0xde5a25=toDisplayAgentName(_0x390bbb,{'fallback':'Judge'}),_0x355f24=typeof _0x18a7b4==='string'?_0x18a7b4['trim']():'';if(Number['isInteger'](number)&&number>0x0)return _0xde5a25+'\x20Judge\x20'+number;if(_0x355f24)return/\bjudge\b/i['test'](_0x355f24)?_0x355f24:_0x355f24+'\x20Judge';if(hasDuplicates)return _0xde5a25+'\x20Judge';return _0xde5a25==='Judge'?_0xde5a25:_0xde5a25+'\x20Judge';}export function buildJudgmentDisplayNameMap(_0x576f30=[]){const _0x1a2686=Array['isArray'](_0x576f30)?_0x576f30['filter'](Boolean):[],_0x4f1e7b=new Map();_0x1a2686['forEach'](_0x356957=>{const _0x1f79a2=_0x356957?.['judgeAgent']||_0x356957?.['envVars']?.['CODER_AGENT']||'unknown',_0x58715d=String(_0x1f79a2||'')['trim']()['toLowerCase']()||'unknown';!_0x4f1e7b['has'](_0x58715d)&&_0x4f1e7b['set'](_0x58715d,[]),_0x4f1e7b['get'](_0x58715d)['push'](_0x356957);});const _0xea3fb2=new Map();return _0x4f1e7b['forEach'](_0x55b294=>{const _0x10d55c=[..._0x55b294]['sort'](compareJudgmentsForAliasOrder),_0x5c0001=_0x10d55c['length']>0x1,_0x5c19d9=new Set(),_0xf2bd29=new Map();_0x5c0001&&_0x10d55c['forEach'](_0x358a0c=>{const _0x3d4b5d=parseJudgeAliasNumber(_0x358a0c?.['judgeAlias'],_0x358a0c?.['judgeAgent']);if(!Number['isInteger'](_0x3d4b5d)||_0x3d4b5d<=0x0||_0x5c19d9['has'](_0x3d4b5d))return;_0xf2bd29['set'](_0x358a0c['taskId'],_0x3d4b5d),_0x5c19d9['add'](_0x3d4b5d);});let _0x48afaf=0x1;const _0x32e60b=()=>{while(_0x5c19d9['has'](_0x48afaf)){_0x48afaf+=0x1;}return _0x5c19d9['add'](_0x48afaf),_0x48afaf;};_0x10d55c['forEach'](_0x23050d=>{let _0x326803=_0xf2bd29['get'](_0x23050d['taskId'])||null;_0x5c0001&&_0x326803===null&&!String(_0x23050d?.['judgeAlias']||'')['trim']()&&(_0x326803=_0x32e60b()),_0xea3fb2['set'](_0x23050d['taskId'],formatJudgeDisplayName({'alias':_0x23050d?.['judgeAlias']||null,'agent':_0x23050d?.['judgeAgent']||_0x23050d?.['envVars']?.['CODER_AGENT']||'unknown','number':_0x326803,'hasDuplicates':_0x5c0001}));});}),_0xea3fb2;}export function buildTaskNavigationHref(_0x596cc8,{currentUrl:_0x2e6fb2,groupedTaskIds:groupedTaskIds=[],groupId:groupId=null}={}){const _0x599206=new URL(_0x2e6fb2),_0x28b089=String(_0x596cc8||'')['trim'](),_0x4cf33b=String(groupId||'')['trim'](),_0x5a92cb=Array['isArray'](groupedTaskIds)?groupedTaskIds['map'](_0x46b7a8=>String(_0x46b7a8||'')['trim']())['filter'](Boolean):[],_0x380dd6=Boolean(_0x4cf33b)||_0x5a92cb['length']>0x1;if(!_0x380dd6)return _0x28b089&&_0x599206['searchParams']['set']('id',_0x28b089),_0x599206['searchParams']['delete']('groupId'),_0x599206['toString']();const _0x3eb5c2=_0x5a92cb['includes'](_0x28b089)?_0x5a92cb:[..._0x5a92cb,_0x28b089]['filter'](Boolean);if(_0x3eb5c2['length']>0x0)_0x599206['searchParams']['set']('id',_0x3eb5c2['join'](','));else _0x28b089&&_0x599206['searchParams']['set']('id',_0x28b089);return _0x4cf33b?_0x599206['searchParams']['set']('groupId',_0x4cf33b):_0x599206['searchParams']['delete']('groupId'),_0x599206['toString']();}
@@ -2082,6 +2082,7 @@
2082
2082
  Expand All
2083
2083
  </button>
2084
2084
  </div>
2085
+ <div class="feedback-judgment-summary" id="feedback-judgment-summary" hidden></div>
2085
2086
  <div class="variant-feedback-section" id="variant-feedback-section">
2086
2087
  <div class="variant-feedback-list" id="variant-feedback-list">
2087
2088
  <!-- Populated dynamically when a judgment with feedback is selected -->