@profoundlogic/coderflow-server 0.6.6 → 0.6.8

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 (179) 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
  179. package/dist/start.js.bak +0 -1381
@@ -1 +1 @@
1
- function isSharedWorkerSupported(){return typeof SharedWorker!=='undefined';}function eventTypeToHandler(_0x4b4821){if(_0x4b4821==='connected')return'onConnected';if(_0x4b4821==='error')return'onError';return'on'+_0x4b4821['split']('-')['map'](_0x1158ec=>_0x1158ec['charAt'](0x0)['toUpperCase']()+_0x1158ec['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'](_0x52fafa,_0x119e92){return!this['listeners']['has'](_0x52fafa)&&this['listeners']['set'](_0x52fafa,new Set()),this['listeners']['get'](_0x52fafa)['add'](_0x119e92),this;}['off'](_0x4ebb84,_0x4937ca){return this['listeners']['has'](_0x4ebb84)&&this['listeners']['get'](_0x4ebb84)['delete'](_0x4937ca),this;}['_emit'](_0x19c9ea,_0x599b0c){this['listeners']['has'](_0x19c9ea)&&this['listeners']['get'](_0x19c9ea)['forEach'](_0x17fa70=>{try{_0x17fa70(_0x599b0c);}catch(_0x5ec301){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x19c9ea+'\x20listener:',_0x5ec301);}});}['connect'](_0x15e3ac='me'){this['userId']=_0x15e3ac,this['useSharedWorker']?this['_connectViaWorker'](_0x15e3ac):this['_connectDirect'](_0x15e3ac);}['_connectViaWorker'](_0x4ed11b){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0x4ed11b});}catch(_0xe82bd4){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0xe82bd4),this['useSharedWorker']=![],this['_connectDirect'](_0x4ed11b);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x5714af=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x5714af),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0x23f864){const _0x3dccc5=_0x23f864['data'];if(_0x3dccc5['type']&&_0x3dccc5['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x3dccc5);return;}switch(_0x3dccc5['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0x96d258=JSON['parse'](_0x3dccc5['data']);this['_emit'](_0x3dccc5['type'],_0x96d258);}catch(_0x9ed7b3){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x3dccc5['type']+'\x20data:',_0x9ed7b3);}break;case'error':this['connected']=![],this['_emit']('error',_0x3dccc5);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x3dccc5['type']);}}['_handleTaskStreamMessage'](_0x3e8d15){const {taskId:_0x203f55,type:_0x1995d8,data:_0x3edbe5}=_0x3e8d15,_0xedc7d3=this['_taskSubscriptions']['get'](_0x203f55);if(!_0xedc7d3||_0xedc7d3['size']===0x0)return;const _0x2a422b=_0x1995d8['replace']('task:',''),_0x5a7689=eventTypeToHandler(_0x2a422b);_0xedc7d3['forEach'](_0x7319a1=>{if(_0x7319a1['handlers'][_0x5a7689])try{const _0x3cdccc=typeof _0x3edbe5==='string'?JSON['parse'](_0x3edbe5):_0x3edbe5;_0x7319a1['handlers'][_0x5a7689](_0x3cdccc);}catch(_0x58ab87){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x2a422b+'\x20handler:',_0x58ab87);}});}['_connectDirect'](_0x486fea){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0x2381be=_0x486fea&&_0x486fea!=='me'?'?userId='+_0x486fea:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0x2381be),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x35d0df=>{this['_handleDirectSSE']('snapshot',_0x35d0df),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x146827=>{this['_handleDirectSSE']('activity',_0x146827);}),this['eventSource']['addEventListener']('status',_0x512ace=>{this['_handleDirectSSE']('status',_0x512ace);}),this['eventSource']['addEventListener']('new-task',_0x31b637=>{this['_handleDirectSSE']('new-task',_0x31b637);}),this['eventSource']['addEventListener']('queue-position',_0x566408=>{this['_handleDirectSSE']('queue-position',_0x566408);}),this['eventSource']['addEventListener']('error',_0x388d09=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0x388d09),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0x29ffd5){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0x29ffd5),this['_emit']('error',{'error':_0x29ffd5['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0x15ede5,_0x35f254){try{const _0x1e57b3=JSON['parse'](_0x35f254['data']);this['_emit'](_0x15ede5,_0x1e57b3);}catch(_0x2a677b){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x15ede5+'\x20data:',_0x2a677b);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x535ca0=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x535ca0+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x535ca0);}['changeFilter'](_0x16a1bb){if(_0x16a1bb===this['userId'])return;this['userId']=_0x16a1bb;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x16a1bb});else this['eventSource']&&this['_connectDirect'](_0x16a1bb);}['subscribeTask'](_0x661efa,_0x1769ac){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x661efa,_0x1769ac):this['_subscribeTaskDirect'](_0x661efa,_0x1769ac);}['unsubscribeTask'](_0x4f396b){if(!_0x4f396b)return;_0x4f396b['type']==='worker'?this['_unsubscribeTaskWorker'](_0x4f396b):this['_unsubscribeTaskDirect'](_0x4f396b);}['_subscribeTaskViaWorker'](_0x101772,_0x278764){try{this['_ensureWorker']();}catch(_0x7ae4d0){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x7ae4d0),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0x101772,_0x278764);}const _0xda5932=++this['_taskSubIdCounter'],_0x2d4e1e={'type':'worker','taskId':_0x101772,'handlers':_0x278764,'id':_0xda5932};return!this['_taskSubscriptions']['has'](_0x101772)&&(this['_taskSubscriptions']['set'](_0x101772,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0x101772})),this['_taskSubscriptions']['get'](_0x101772)['add'](_0x2d4e1e),_0x2d4e1e;}['_unsubscribeTaskWorker'](_0x20a97c){const {taskId:_0x2146ef}=_0x20a97c,_0x306ea7=this['_taskSubscriptions']['get'](_0x2146ef);if(_0x306ea7){_0x306ea7['delete'](_0x20a97c);if(_0x306ea7['size']===0x0){this['_taskSubscriptions']['delete'](_0x2146ef);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x2146ef});}catch(_0x100298){}}}}['_subscribeTaskDirect'](_0x4bd9fe,_0xecf7b2){const _0x1aeef3=++this['_taskSubIdCounter'],_0x878867=new EventSource('/tasks/'+_0x4bd9fe+'/stream'),_0x353eab={'type':'direct','taskId':_0x4bd9fe,'handlers':_0xecf7b2,'id':_0x1aeef3,'eventSource':_0x878867};!this['_taskSubscriptions']['has'](_0x4bd9fe)&&this['_taskSubscriptions']['set'](_0x4bd9fe,new Set());this['_taskSubscriptions']['get'](_0x4bd9fe)['add'](_0x353eab);for(const _0x26ef93 of TASK_STREAM_EVENTS){const _0x101a53=eventTypeToHandler(_0x26ef93);_0x878867['addEventListener'](_0x26ef93,_0x294f1a=>{if(_0xecf7b2[_0x101a53])try{const _0x498f89=JSON['parse'](_0x294f1a['data']);_0xecf7b2[_0x101a53](_0x498f89);}catch(_0x278b48){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x26ef93+':',_0x278b48);}});}return _0x878867['addEventListener']('open',()=>{if(_0xecf7b2['onConnected'])_0xecf7b2['onConnected']();}),_0x878867['addEventListener']('error',()=>{if(_0xecf7b2['onError'])_0xecf7b2['onError']({'error':'Connection\x20error'});}),_0x353eab;}['_unsubscribeTaskDirect'](_0x3f6db9){_0x3f6db9['eventSource']&&(_0x3f6db9['eventSource']['close'](),_0x3f6db9['eventSource']=null);const _0x16d3ea=this['_taskSubscriptions']['get'](_0x3f6db9['taskId']);_0x16d3ea&&(_0x16d3ea['delete'](_0x3f6db9),_0x16d3ea['size']===0x0&&this['_taskSubscriptions']['delete'](_0x3f6db9['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x48f154,_0x5c24dd)=>{_0x48f154['forEach'](_0x149d3f=>{_0x149d3f['type']==='direct'&&_0x149d3f['eventSource']&&_0x149d3f['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0x56f625){}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(_0x22ae55){if(_0x22ae55==='connected')return'onConnected';if(_0x22ae55==='error')return'onError';return'on'+_0x22ae55['split']('-')['map'](_0x4f1511=>_0x4f1511['charAt'](0x0)['toUpperCase']()+_0x4f1511['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'](_0x182249,_0x52fa31){return!this['listeners']['has'](_0x182249)&&this['listeners']['set'](_0x182249,new Set()),this['listeners']['get'](_0x182249)['add'](_0x52fa31),this;}['off'](_0x39c2b5,_0x4841cd){return this['listeners']['has'](_0x39c2b5)&&this['listeners']['get'](_0x39c2b5)['delete'](_0x4841cd),this;}['_emit'](_0x55dbeb,_0x312f59){this['listeners']['has'](_0x55dbeb)&&this['listeners']['get'](_0x55dbeb)['forEach'](_0x33431b=>{try{_0x33431b(_0x312f59);}catch(_0x579a20){console['error']('[SSE\x20Client]\x20Error\x20in\x20'+_0x55dbeb+'\x20listener:',_0x579a20);}});}['connect'](_0xef248d='me'){this['userId']=_0xef248d,this['useSharedWorker']?this['_connectViaWorker'](_0xef248d):this['_connectDirect'](_0xef248d);}['_connectViaWorker'](_0x180318){try{this['_ensureWorker'](),this['port']['postMessage']({'action':'connect','userId':_0x180318});}catch(_0x48636c){console['error']('[SSE\x20Client]\x20SharedWorker\x20failed,\x20falling\x20back\x20to\x20direct\x20SSE:',_0x48636c),this['useSharedWorker']=![],this['_connectDirect'](_0x180318);}}['_ensureWorker'](){!this['worker']&&(this['worker']=new SharedWorker('/sse-shared-worker.js'),this['port']=this['worker']['port'],this['port']['onmessage']=this['_handleWorkerMessage'],this['port']['onmessageerror']=_0x11296f=>{console['error']('[SSE\x20Client]\x20Worker\x20message\x20error:',_0x11296f),this['_emit']('error',{'error':'Worker\x20message\x20error'});},this['port']['start']());}['_handleWorkerMessage'](_0x4e0894){const _0x1e418c=_0x4e0894['data'];if(_0x1e418c['type']&&_0x1e418c['type']['startsWith']('task:')){this['_handleTaskStreamMessage'](_0x1e418c);return;}switch(_0x1e418c['type']){case'connected':this['connected']=!![],this['_emit']('connected',{});break;case'snapshot':case'activity':case'status':case'new-task':case'queue-position':try{const _0xa99e93=JSON['parse'](_0x1e418c['data']);this['_emit'](_0x1e418c['type'],_0xa99e93);}catch(_0x20f94c){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0x1e418c['type']+'\x20data:',_0x20f94c);}break;case'error':this['connected']=![],this['_emit']('error',_0x1e418c);break;default:console['warn']('[SSE\x20Client]\x20Unknown\x20message\x20type:',_0x1e418c['type']);}}['_handleTaskStreamMessage'](_0x377cb5){const {taskId:_0x1ab021,type:_0x2dd734,data:_0x1eb999}=_0x377cb5,_0x106a01=this['_taskSubscriptions']['get'](_0x1ab021);if(!_0x106a01||_0x106a01['size']===0x0)return;const _0x48aada=_0x2dd734['replace']('task:',''),_0x28813e=eventTypeToHandler(_0x48aada);_0x106a01['forEach'](_0x380cb6=>{if(_0x380cb6['handlers'][_0x28813e])try{const _0x4a0498=typeof _0x1eb999==='string'?JSON['parse'](_0x1eb999):_0x1eb999;_0x380cb6['handlers'][_0x28813e](_0x4a0498);}catch(_0x293a31){console['error']('[SSE\x20Client]\x20Error\x20in\x20task\x20'+_0x48aada+'\x20handler:',_0x293a31);}});}['_connectDirect'](_0x330a06){this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null);const _0x5c4121=_0x330a06&&_0x330a06!=='me'?'?userId='+_0x330a06:'';try{this['eventSource']=new EventSource('/tasks/updates'+_0x5c4121),this['eventSource']['addEventListener']('open',()=>{this['connected']=!![],this['reconnectAttempts']=0x0,this['_emit']('connected',{});}),this['eventSource']['addEventListener']('snapshot',_0x271cce=>{this['_handleDirectSSE']('snapshot',_0x271cce),this['reconnectAttempts']=0x0;}),this['eventSource']['addEventListener']('activity',_0x55f6cc=>{this['_handleDirectSSE']('activity',_0x55f6cc);}),this['eventSource']['addEventListener']('status',_0x26408d=>{this['_handleDirectSSE']('status',_0x26408d);}),this['eventSource']['addEventListener']('new-task',_0x335164=>{this['_handleDirectSSE']('new-task',_0x335164);}),this['eventSource']['addEventListener']('queue-position',_0x4030cf=>{this['_handleDirectSSE']('queue-position',_0x4030cf);}),this['eventSource']['addEventListener']('error',_0x5d5269=>{console['error']('[SSE\x20Client]\x20Direct\x20SSE\x20error:',_0x5d5269),this['connected']=![],this['_emit']('error',{'error':'Connection\x20error'}),this['eventSource']&&(this['eventSource']['close'](),this['eventSource']=null),this['_scheduleReconnect']();});}catch(_0x1e863d){console['error']('[SSE\x20Client]\x20Failed\x20to\x20create\x20EventSource:',_0x1e863d),this['_emit']('error',{'error':_0x1e863d['message']}),this['_scheduleReconnect']();}}['_handleDirectSSE'](_0xfe15a5,_0x2a6ccd){try{const _0x55479a=JSON['parse'](_0x2a6ccd['data']);this['_emit'](_0xfe15a5,_0x55479a);}catch(_0x6936c9){console['error']('[SSE\x20Client]\x20Failed\x20to\x20parse\x20'+_0xfe15a5+'\x20data:',_0x6936c9);}}['_scheduleReconnect'](){this['reconnectTimeout']&&clearTimeout(this['reconnectTimeout']);const _0x1bd1a2=Math['min'](0x3e8*Math['pow'](0x2,this['reconnectAttempts']),0x7530);this['reconnectAttempts']++,console['log']('[SSE\x20Client]\x20Scheduling\x20reconnect\x20in\x20'+_0x1bd1a2+'ms'),this['reconnectTimeout']=setTimeout(()=>{this['_connectDirect'](this['userId']);},_0x1bd1a2);}['changeFilter'](_0x3aaa61){if(_0x3aaa61===this['userId'])return;this['userId']=_0x3aaa61;if(this['useSharedWorker']&&this['port'])this['port']['postMessage']({'action':'changeFilter','userId':_0x3aaa61});else this['eventSource']&&this['_connectDirect'](_0x3aaa61);}['subscribeTask'](_0x1e0fbe,_0x33fd02){return this['useSharedWorker']?this['_subscribeTaskViaWorker'](_0x1e0fbe,_0x33fd02):this['_subscribeTaskDirect'](_0x1e0fbe,_0x33fd02);}['unsubscribeTask'](_0x1909da){if(!_0x1909da)return;_0x1909da['type']==='worker'?this['_unsubscribeTaskWorker'](_0x1909da):this['_unsubscribeTaskDirect'](_0x1909da);}['_subscribeTaskViaWorker'](_0x1cd41e,_0xfc875d){try{this['_ensureWorker']();}catch(_0x3f93d6){return console['error']('[SSE\x20Client]\x20SharedWorker\x20failed\x20for\x20task\x20sub,\x20falling\x20back:',_0x3f93d6),this['useSharedWorker']=![],this['_subscribeTaskDirect'](_0x1cd41e,_0xfc875d);}const _0x31159b=++this['_taskSubIdCounter'],_0x3afb7e={'type':'worker','taskId':_0x1cd41e,'handlers':_0xfc875d,'id':_0x31159b};return!this['_taskSubscriptions']['has'](_0x1cd41e)&&(this['_taskSubscriptions']['set'](_0x1cd41e,new Set()),this['port']['postMessage']({'action':'subscribeTask','taskId':_0x1cd41e})),this['_taskSubscriptions']['get'](_0x1cd41e)['add'](_0x3afb7e),_0x3afb7e;}['_unsubscribeTaskWorker'](_0x4ddbda){const {taskId:_0x20edd3}=_0x4ddbda,_0x40a101=this['_taskSubscriptions']['get'](_0x20edd3);if(_0x40a101){_0x40a101['delete'](_0x4ddbda);if(_0x40a101['size']===0x0){this['_taskSubscriptions']['delete'](_0x20edd3);try{this['port']&&this['port']['postMessage']({'action':'unsubscribeTask','taskId':_0x20edd3});}catch(_0x108e9f){}}}}['_subscribeTaskDirect'](_0x21dbe6,_0x5c32e7){const _0x1a2aa1=++this['_taskSubIdCounter'],_0x28770c=new EventSource('/tasks/'+_0x21dbe6+'/stream'),_0x5373bb={'type':'direct','taskId':_0x21dbe6,'handlers':_0x5c32e7,'id':_0x1a2aa1,'eventSource':_0x28770c};!this['_taskSubscriptions']['has'](_0x21dbe6)&&this['_taskSubscriptions']['set'](_0x21dbe6,new Set());this['_taskSubscriptions']['get'](_0x21dbe6)['add'](_0x5373bb);for(const _0x1224d8 of TASK_STREAM_EVENTS){const _0x23feb6=eventTypeToHandler(_0x1224d8);_0x28770c['addEventListener'](_0x1224d8,_0x20182c=>{if(_0x5c32e7[_0x23feb6])try{const _0x969535=JSON['parse'](_0x20182c['data']);_0x5c32e7[_0x23feb6](_0x969535);}catch(_0x309f0d){console['error']('[SSE\x20Client]\x20Error\x20parsing\x20task\x20'+_0x1224d8+':',_0x309f0d);}});}return _0x28770c['addEventListener']('open',()=>{if(_0x5c32e7['onConnected'])_0x5c32e7['onConnected']();}),_0x28770c['addEventListener']('error',()=>{if(_0x5c32e7['onError'])_0x5c32e7['onError']({'error':'Connection\x20error'});}),_0x5373bb;}['_unsubscribeTaskDirect'](_0xc4a812){_0xc4a812['eventSource']&&(_0xc4a812['eventSource']['close'](),_0xc4a812['eventSource']=null);const _0x58b65e=this['_taskSubscriptions']['get'](_0xc4a812['taskId']);_0x58b65e&&(_0x58b65e['delete'](_0xc4a812),_0x58b65e['size']===0x0&&this['_taskSubscriptions']['delete'](_0xc4a812['taskId']));}['disconnect'](){this['reconnectTimeout']&&(clearTimeout(this['reconnectTimeout']),this['reconnectTimeout']=null);this['_taskSubscriptions']['forEach']((_0x3ae96b,_0x6490c0)=>{_0x3ae96b['forEach'](_0x520c2c=>{_0x520c2c['type']==='direct'&&_0x520c2c['eventSource']&&_0x520c2c['eventSource']['close']();});}),this['_taskSubscriptions']['clear']();if(this['useSharedWorker']&&this['port'])try{this['port']['postMessage']({'action':'disconnect'});}catch(_0x35c37d){}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(_0x4b140b){eventSource&&currentUserId!==_0x4b140b&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0x4b140b;const _0x18fb77=_0x4b140b&&_0x4b140b!=='me'?'?userId='+_0x4b140b:'';try{eventSource=new EventSource('/tasks/updates'+_0x18fb77),eventSource['addEventListener']('snapshot',_0x5cdacc=>{broadcast({'type':'snapshot','data':_0x5cdacc['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x20aa80=>{broadcast({'type':'activity','data':_0x20aa80['data']});}),eventSource['addEventListener']('status',_0x34a5ce=>{broadcast({'type':'status','data':_0x34a5ce['data']});}),eventSource['addEventListener']('new-task',_0x57e374=>{broadcast({'type':'new-task','data':_0x57e374['data']});}),eventSource['addEventListener']('queue-position',_0x6e3fd0=>{broadcast({'type':'queue-position','data':_0x6e3fd0['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0x35aea3=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0x35aea3),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0xed5736){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0xed5736),broadcast({'type':'error','error':_0xed5736['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x53beee=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x53beee+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x53beee);}function broadcast(_0xf42582){const _0x49d6cd=[];ports['forEach'](_0x33747e=>{try{_0x33747e['postMessage'](_0xf42582);}catch(_0x4e0639){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x4e0639),_0x49d6cd['push'](_0x33747e);}}),_0x49d6cd['length']>0x0&&cleanUpDeadPorts(_0x49d6cd),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(_0x2cc729,_0x15f7d9){let _0x1ab36d=taskStreams['get'](_0x15f7d9);!_0x1ab36d&&(_0x1ab36d={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0x15f7d9,_0x1ab36d));_0x1ab36d['subscribedPorts']['add'](_0x2cc729);if(!_0x1ab36d['eventSource']||_0x1ab36d['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0x15f7d9);else{if(_0x1ab36d['eventSource']['readyState']===EventSource['OPEN'])try{_0x2cc729['postMessage']({'type':'task:connected','taskId':_0x15f7d9});}catch(_0x4dd8b6){}}}function unsubscribeTask(_0x5ec5e5,_0x39ccf4){const _0xb91803=taskStreams['get'](_0x39ccf4);if(!_0xb91803)return;_0xb91803['subscribedPorts']['delete'](_0x5ec5e5),_0xb91803['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x39ccf4);}function connectTaskStream(_0x36e070){const _0x17776c=taskStreams['get'](_0x36e070);if(!_0x17776c)return;_0x17776c['eventSource']&&(_0x17776c['eventSource']['close'](),_0x17776c['eventSource']=null);try{_0x17776c['eventSource']=new EventSource('/tasks/'+_0x36e070+'/stream');for(const _0x74c769 of TASK_STREAM_EVENTS){_0x17776c['eventSource']['addEventListener'](_0x74c769,_0xaa7aa5=>{broadcastToTask(_0x36e070,'task:'+_0x74c769,_0xaa7aa5['data']),_0x17776c['reconnectAttempts']=0x0;});}_0x17776c['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x36e070,'task:connected','{}'),_0x17776c['reconnectAttempts']=0x0;}),_0x17776c['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x36e070,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0x17776c['eventSource']&&(_0x17776c['eventSource']['close'](),_0x17776c['eventSource']=null),scheduleTaskReconnect(_0x36e070);});}catch(_0x4d8369){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x36e070+':',_0x4d8369),broadcastToTask(_0x36e070,'task:error',JSON['stringify']({'error':_0x4d8369['message']})),scheduleTaskReconnect(_0x36e070);}}function broadcastToTask(_0x5265ea,_0x23e522,_0x1c61e0){const _0x2ca7b4=taskStreams['get'](_0x5265ea);if(!_0x2ca7b4)return;const _0x426346=[];_0x2ca7b4['subscribedPorts']['forEach'](_0x3eae2f=>{try{_0x3eae2f['postMessage']({'type':_0x23e522,'taskId':_0x5265ea,'data':_0x1c61e0});}catch(_0x1f3b89){_0x426346['push'](_0x3eae2f);}}),_0x426346['length']>0x0&&(_0x426346['forEach'](_0x525947=>_0x2ca7b4['subscribedPorts']['delete'](_0x525947)),cleanUpDeadPorts(_0x426346),_0x2ca7b4['subscribedPorts']['size']===0x0&&closeTaskStream(_0x5265ea));}function closeTaskStream(_0x38d8e3){const _0x1a2463=taskStreams['get'](_0x38d8e3);if(!_0x1a2463)return;_0x1a2463['eventSource']&&_0x1a2463['eventSource']['close'](),_0x1a2463['reconnectTimeout']&&clearTimeout(_0x1a2463['reconnectTimeout']),taskStreams['delete'](_0x38d8e3);}function deferredCloseTaskStream(_0x4f1638){setTimeout(()=>{const _0x419c17=taskStreams['get'](_0x4f1638);_0x419c17&&_0x419c17['subscribedPorts']['size']===0x0&&closeTaskStream(_0x4f1638);},0x0);}function scheduleTaskReconnect(_0x30df77){const _0x3c0503=taskStreams['get'](_0x30df77);if(!_0x3c0503||_0x3c0503['subscribedPorts']['size']===0x0)return;_0x3c0503['reconnectTimeout']&&clearTimeout(_0x3c0503['reconnectTimeout']);const _0x3503cd=Math['min'](0x3e8*Math['pow'](0x2,_0x3c0503['reconnectAttempts']),MAX_RECONNECT_DELAY);_0x3c0503['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x30df77+'\x20in\x20'+_0x3503cd+'ms'),_0x3c0503['reconnectTimeout']=setTimeout(()=>{_0x3c0503['subscribedPorts']['size']>0x0&&connectTaskStream(_0x30df77);},_0x3503cd);}function cleanUpDeadPorts(_0x14ce7b){for(const _0x117781 of _0x14ce7b){ports['delete'](_0x117781),taskStreams['forEach']((_0x6f777,_0xbb9bff)=>{_0x6f777['subscribedPorts']['delete'](_0x117781),_0x6f777['subscribedPorts']['size']===0x0&&closeTaskStream(_0xbb9bff);});}}function removePortFromAllTasks(_0x59718b){taskStreams['forEach']((_0x1af528,_0x178380)=>{_0x1af528['subscribedPorts']['has'](_0x59718b)&&(_0x1af528['subscribedPorts']['delete'](_0x59718b),_0x1af528['subscribedPorts']['size']===0x0&&closeTaskStream(_0x178380));});}self['onconnect']=function(_0x21e8b1){const _0x27005f=_0x21e8b1['ports'][0x0];ports['add'](_0x27005f),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0x27005f['onmessage']=function(_0x12469b){const {action:_0xa684e9,userId:_0x596cbe,taskId:_0xb1d6ad}=_0x12469b['data'];switch(_0xa684e9){case'connect':connect(_0x596cbe);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0x27005f['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0x27005f),removePortFromAllTasks(_0x27005f),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':_0x596cbe!==currentUserId&&connect(_0x596cbe);break;case'subscribeTask':subscribeTask(_0x27005f,_0xb1d6ad);break;case'unsubscribeTask':unsubscribeTask(_0x27005f,_0xb1d6ad);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0xa684e9);}},_0x27005f['onmessageerror']=function(_0x36e6ce){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x36e6ce),ports['delete'](_0x27005f),removePortFromAllTasks(_0x27005f);},_0x27005f['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(_0x171e79){eventSource&&currentUserId!==_0x171e79&&(eventSource['close'](),eventSource=null);if(eventSource&&eventSource['readyState']!==EventSource['CLOSED'])return;currentUserId=_0x171e79;const _0x3c9e82=_0x171e79&&_0x171e79!=='me'?'?userId='+_0x171e79:'';try{eventSource=new EventSource('/tasks/updates'+_0x3c9e82),eventSource['addEventListener']('snapshot',_0x16b9e5=>{broadcast({'type':'snapshot','data':_0x16b9e5['data']}),reconnectAttempts=0x0;}),eventSource['addEventListener']('activity',_0x146267=>{broadcast({'type':'activity','data':_0x146267['data']});}),eventSource['addEventListener']('status',_0xeb11e4=>{broadcast({'type':'status','data':_0xeb11e4['data']});}),eventSource['addEventListener']('new-task',_0x3995af=>{broadcast({'type':'new-task','data':_0x3995af['data']});}),eventSource['addEventListener']('queue-position',_0x224051=>{broadcast({'type':'queue-position','data':_0x224051['data']});}),eventSource['addEventListener']('open',()=>{broadcast({'type':'connected'}),reconnectAttempts=0x0;}),eventSource['addEventListener']('error',_0x2bf13e=>{console['error']('[SSE\x20Worker]\x20Connection\x20error:',_0x2bf13e),broadcast({'type':'error','error':'Connection\x20error'}),eventSource&&(eventSource['close'](),eventSource=null),scheduleReconnect();});}catch(_0x252bdf){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20EventSource:',_0x252bdf),broadcast({'type':'error','error':_0x252bdf['message']}),scheduleReconnect();}}function scheduleReconnect(){reconnectTimeout&&clearTimeout(reconnectTimeout);if(ports['size']===0x0)return;const _0x495468=Math['min'](0x3e8*Math['pow'](0x2,reconnectAttempts),MAX_RECONNECT_DELAY);reconnectAttempts++,console['log']('[SSE\x20Worker]\x20Scheduling\x20reconnect\x20in\x20'+_0x495468+'ms\x20(attempt\x20'+reconnectAttempts+')'),reconnectTimeout=setTimeout(()=>{ports['size']>0x0&&connect(currentUserId);},_0x495468);}function broadcast(_0x8261fb){const _0x4fc413=[];ports['forEach'](_0x4fc64a=>{try{_0x4fc64a['postMessage'](_0x8261fb);}catch(_0x415dbb){console['warn']('[SSE\x20Worker]\x20Failed\x20to\x20send\x20to\x20port,\x20removing:',_0x415dbb),_0x4fc413['push'](_0x4fc64a);}}),_0x4fc413['length']>0x0&&cleanUpDeadPorts(_0x4fc413),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(_0x578c2a,_0x196882){let _0x456626=taskStreams['get'](_0x196882);!_0x456626&&(_0x456626={'eventSource':null,'reconnectTimeout':null,'reconnectAttempts':0x0,'subscribedPorts':new Set()},taskStreams['set'](_0x196882,_0x456626));_0x456626['subscribedPorts']['add'](_0x578c2a);if(!_0x456626['eventSource']||_0x456626['eventSource']['readyState']===EventSource['CLOSED'])connectTaskStream(_0x196882);else{if(_0x456626['eventSource']['readyState']===EventSource['OPEN'])try{_0x578c2a['postMessage']({'type':'task:connected','taskId':_0x196882});}catch(_0xd3d648){}}}function unsubscribeTask(_0x29fff0,_0x5135c4){const _0x2a3522=taskStreams['get'](_0x5135c4);if(!_0x2a3522)return;_0x2a3522['subscribedPorts']['delete'](_0x29fff0),_0x2a3522['subscribedPorts']['size']===0x0&&deferredCloseTaskStream(_0x5135c4);}function connectTaskStream(_0x488eea){const _0x398f78=taskStreams['get'](_0x488eea);if(!_0x398f78)return;_0x398f78['eventSource']&&(_0x398f78['eventSource']['close'](),_0x398f78['eventSource']=null);try{_0x398f78['eventSource']=new EventSource('/tasks/'+_0x488eea+'/stream');for(const _0x42a225 of TASK_STREAM_EVENTS){_0x398f78['eventSource']['addEventListener'](_0x42a225,_0x4a1adc=>{broadcastToTask(_0x488eea,'task:'+_0x42a225,_0x4a1adc['data']),_0x398f78['reconnectAttempts']=0x0;});}_0x398f78['eventSource']['addEventListener']('open',()=>{broadcastToTask(_0x488eea,'task:connected','{}'),_0x398f78['reconnectAttempts']=0x0;}),_0x398f78['eventSource']['addEventListener']('error',()=>{broadcastToTask(_0x488eea,'task:error',JSON['stringify']({'error':'Connection\x20error'})),_0x398f78['eventSource']&&(_0x398f78['eventSource']['close'](),_0x398f78['eventSource']=null),scheduleTaskReconnect(_0x488eea);});}catch(_0x19b165){console['error']('[SSE\x20Worker]\x20Failed\x20to\x20create\x20task\x20EventSource\x20for\x20'+_0x488eea+':',_0x19b165),broadcastToTask(_0x488eea,'task:error',JSON['stringify']({'error':_0x19b165['message']})),scheduleTaskReconnect(_0x488eea);}}function broadcastToTask(_0x2f72f1,_0x1b95da,_0xc44143){const _0x100418=taskStreams['get'](_0x2f72f1);if(!_0x100418)return;const _0x197d3e=[];_0x100418['subscribedPorts']['forEach'](_0x500408=>{try{_0x500408['postMessage']({'type':_0x1b95da,'taskId':_0x2f72f1,'data':_0xc44143});}catch(_0x3a7004){_0x197d3e['push'](_0x500408);}}),_0x197d3e['length']>0x0&&(_0x197d3e['forEach'](_0x11dac3=>_0x100418['subscribedPorts']['delete'](_0x11dac3)),cleanUpDeadPorts(_0x197d3e),_0x100418['subscribedPorts']['size']===0x0&&closeTaskStream(_0x2f72f1));}function closeTaskStream(_0x5a2b28){const _0x64a9a6=taskStreams['get'](_0x5a2b28);if(!_0x64a9a6)return;_0x64a9a6['eventSource']&&_0x64a9a6['eventSource']['close'](),_0x64a9a6['reconnectTimeout']&&clearTimeout(_0x64a9a6['reconnectTimeout']),taskStreams['delete'](_0x5a2b28);}function deferredCloseTaskStream(_0x1e0b6b){setTimeout(()=>{const _0x5486a0=taskStreams['get'](_0x1e0b6b);_0x5486a0&&_0x5486a0['subscribedPorts']['size']===0x0&&closeTaskStream(_0x1e0b6b);},0x0);}function scheduleTaskReconnect(_0x1d013b){const _0x128bc9=taskStreams['get'](_0x1d013b);if(!_0x128bc9||_0x128bc9['subscribedPorts']['size']===0x0)return;_0x128bc9['reconnectTimeout']&&clearTimeout(_0x128bc9['reconnectTimeout']);const _0x47d2cb=Math['min'](0x3e8*Math['pow'](0x2,_0x128bc9['reconnectAttempts']),MAX_RECONNECT_DELAY);_0x128bc9['reconnectAttempts']++,console['log']('[SSE\x20Worker]\x20Scheduling\x20task\x20stream\x20reconnect\x20for\x20'+_0x1d013b+'\x20in\x20'+_0x47d2cb+'ms'),_0x128bc9['reconnectTimeout']=setTimeout(()=>{_0x128bc9['subscribedPorts']['size']>0x0&&connectTaskStream(_0x1d013b);},_0x47d2cb);}function cleanUpDeadPorts(_0x4f866d){for(const _0x201eea of _0x4f866d){ports['delete'](_0x201eea),taskStreams['forEach']((_0xd41e4f,_0x18d3e6)=>{_0xd41e4f['subscribedPorts']['delete'](_0x201eea),_0xd41e4f['subscribedPorts']['size']===0x0&&closeTaskStream(_0x18d3e6);});}}function removePortFromAllTasks(_0x5a85df){taskStreams['forEach']((_0x3c73ba,_0x25aac3)=>{_0x3c73ba['subscribedPorts']['has'](_0x5a85df)&&(_0x3c73ba['subscribedPorts']['delete'](_0x5a85df),_0x3c73ba['subscribedPorts']['size']===0x0&&closeTaskStream(_0x25aac3));});}self['onconnect']=function(_0x3bc674){const _0xc1a754=_0x3bc674['ports'][0x0];ports['add'](_0xc1a754),console['log']('[SSE\x20Worker]\x20New\x20port\x20connected.\x20Total\x20ports:\x20'+ports['size']),_0xc1a754['onmessage']=function(_0x2cdd22){const {action:_0x45581c,userId:_0x2bb268,taskId:_0x1812fb}=_0x2cdd22['data'];switch(_0x45581c){case'connect':connect(_0x2bb268);eventSource&&eventSource['readyState']===EventSource['OPEN']&&_0xc1a754['postMessage']({'type':'connected'});break;case'disconnect':ports['delete'](_0xc1a754),removePortFromAllTasks(_0xc1a754),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':_0x2bb268!==currentUserId&&connect(_0x2bb268);break;case'subscribeTask':subscribeTask(_0xc1a754,_0x1812fb);break;case'unsubscribeTask':unsubscribeTask(_0xc1a754,_0x1812fb);break;default:console['warn']('[SSE\x20Worker]\x20Unknown\x20action:',_0x45581c);}},_0xc1a754['onmessageerror']=function(_0x3ff9c6){console['error']('[SSE\x20Worker]\x20Port\x20message\x20error:',_0x3ff9c6),ports['delete'](_0xc1a754),removePortFromAllTasks(_0xc1a754);},_0xc1a754['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(_0x1b7ab7,{fallback:fallback='Unknown'}={}){const _0x27b7aa=String(_0x1b7ab7||'')['trim']()['toLowerCase']();if(!_0x27b7aa)return fallback;return _0x27b7aa['charAt'](0x0)['toUpperCase']()+_0x27b7aa['slice'](0x1);}export function escapeRegExp(_0x34ca03){return String(_0x34ca03)['replace'](/[.*+?^${}()|[\]\\]/g,'\x5c$&');}export function compareJudgmentsForAliasOrder(_0x351265,_0x499a96){const _0x1eff0b=String(_0x351265?.['createdAt']||''),_0x12f34d=String(_0x499a96?.['createdAt']||'');if(_0x1eff0b!==_0x12f34d)return _0x1eff0b['localeCompare'](_0x12f34d);return String(_0x351265?.['taskId']||'')['localeCompare'](String(_0x499a96?.['taskId']||''));}export function parseJudgeAliasNumber(_0x24b364,_0x325773){const _0x48fd17=typeof _0x24b364==='string'?_0x24b364['trim']():'',_0x5d14af=toDisplayAgentName(_0x325773,{'fallback':''});if(!_0x48fd17||!_0x5d14af)return null;const _0x44604d=_0x48fd17['toLowerCase'](),_0x3db408=_0x5d14af['toLowerCase']();if(_0x44604d===_0x3db408||_0x44604d===_0x3db408+'\x20judge')return 0x1;const _0x13bf69=[new RegExp('^'+escapeRegExp(_0x5d14af)+'\x5cs+(\x5cd+)$','i'),new RegExp('^'+escapeRegExp(_0x5d14af)+'\x5cs+Judge\x5cs+(\x5cd+)$','i')];for(const _0x199f76 of _0x13bf69){const _0x55f2e9=_0x48fd17['match'](_0x199f76);if(_0x55f2e9){const _0x5f1509=Number(_0x55f2e9[0x1]);if(Number['isInteger'](_0x5f1509)&&_0x5f1509>0x0)return _0x5f1509;}}return null;}export function formatJudgeDisplayName({alias:_0x2f8370,agent:_0x5368a8,number:number=null,hasDuplicates:hasDuplicates=![]}={}){const _0x1db9d2=toDisplayAgentName(_0x5368a8,{'fallback':'Judge'}),_0x39099b=typeof _0x2f8370==='string'?_0x2f8370['trim']():'';if(Number['isInteger'](number)&&number>0x0)return _0x1db9d2+'\x20Judge\x20'+number;if(_0x39099b)return/\bjudge\b/i['test'](_0x39099b)?_0x39099b:_0x39099b+'\x20Judge';if(hasDuplicates)return _0x1db9d2+'\x20Judge';return _0x1db9d2==='Judge'?_0x1db9d2:_0x1db9d2+'\x20Judge';}export function buildJudgmentDisplayNameMap(_0x2a0e34=[]){const _0x557fcc=Array['isArray'](_0x2a0e34)?_0x2a0e34['filter'](Boolean):[],_0x30a470=new Map();_0x557fcc['forEach'](_0x175be7=>{const _0xe08e05=_0x175be7?.['judgeAgent']||_0x175be7?.['envVars']?.['CODER_AGENT']||'unknown',_0x4f0c27=String(_0xe08e05||'')['trim']()['toLowerCase']()||'unknown';!_0x30a470['has'](_0x4f0c27)&&_0x30a470['set'](_0x4f0c27,[]),_0x30a470['get'](_0x4f0c27)['push'](_0x175be7);});const _0x14a6d7=new Map();return _0x30a470['forEach'](_0x5e8a71=>{const _0x4b5cbb=[..._0x5e8a71]['sort'](compareJudgmentsForAliasOrder),_0x34387e=_0x4b5cbb['length']>0x1,_0x3fb92f=new Set(),_0x308844=new Map();_0x34387e&&_0x4b5cbb['forEach'](_0x4d1b8e=>{const _0x153a89=parseJudgeAliasNumber(_0x4d1b8e?.['judgeAlias'],_0x4d1b8e?.['judgeAgent']);if(!Number['isInteger'](_0x153a89)||_0x153a89<=0x0||_0x3fb92f['has'](_0x153a89))return;_0x308844['set'](_0x4d1b8e['taskId'],_0x153a89),_0x3fb92f['add'](_0x153a89);});let _0xf6e9d4=0x1;const _0x3ebb8a=()=>{while(_0x3fb92f['has'](_0xf6e9d4)){_0xf6e9d4+=0x1;}return _0x3fb92f['add'](_0xf6e9d4),_0xf6e9d4;};_0x4b5cbb['forEach'](_0x36ce06=>{let _0x4bcabd=_0x308844['get'](_0x36ce06['taskId'])||null;_0x34387e&&_0x4bcabd===null&&!String(_0x36ce06?.['judgeAlias']||'')['trim']()&&(_0x4bcabd=_0x3ebb8a()),_0x14a6d7['set'](_0x36ce06['taskId'],formatJudgeDisplayName({'alias':_0x36ce06?.['judgeAlias']||null,'agent':_0x36ce06?.['judgeAgent']||_0x36ce06?.['envVars']?.['CODER_AGENT']||'unknown','number':_0x4bcabd,'hasDuplicates':_0x34387e}));});}),_0x14a6d7;}export function buildTaskNavigationHref(_0x4ca6a9,{currentUrl:_0x5eca01,groupedTaskIds:groupedTaskIds=[],groupId:groupId=null}={}){const _0x30e4c2=new URL(_0x5eca01),_0x2b96f0=String(_0x4ca6a9||'')['trim'](),_0x5436ab=String(groupId||'')['trim'](),_0x5f387b=Array['isArray'](groupedTaskIds)?groupedTaskIds['map'](_0x131c0d=>String(_0x131c0d||'')['trim']())['filter'](Boolean):[],_0x576933=Boolean(_0x5436ab)||_0x5f387b['length']>0x1;if(!_0x576933)return _0x2b96f0&&_0x30e4c2['searchParams']['set']('id',_0x2b96f0),_0x30e4c2['searchParams']['delete']('groupId'),_0x30e4c2['toString']();const _0x33bd26=_0x5f387b['includes'](_0x2b96f0)?_0x5f387b:[..._0x5f387b,_0x2b96f0]['filter'](Boolean);if(_0x33bd26['length']>0x0)_0x30e4c2['searchParams']['set']('id',_0x33bd26['join'](','));else _0x2b96f0&&_0x30e4c2['searchParams']['set']('id',_0x2b96f0);return _0x5436ab?_0x30e4c2['searchParams']['set']('groupId',_0x5436ab):_0x30e4c2['searchParams']['delete']('groupId'),_0x30e4c2['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 -->