@profoundlogic/coderflow-server 0.6.6 → 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(_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(_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(_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(_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 -->