expxagents 0.6.0 → 0.7.1

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 (156) hide show
  1. package/dist/__tests__/cli.test.d.ts +1 -0
  2. package/dist/__tests__/cli.test.js +23 -0
  3. package/dist/cli/src/commands/init.js +12 -2
  4. package/dist/cli/src/commands/virtual-office.js +50 -5
  5. package/dist/cli/src/utils/config.d.ts +5 -0
  6. package/dist/cli/src/utils/config.js +1 -1
  7. package/dist/commands/create.d.ts +1 -0
  8. package/dist/commands/create.js +34 -0
  9. package/dist/commands/init.d.ts +1 -0
  10. package/dist/commands/init.js +58 -0
  11. package/dist/commands/install.d.ts +1 -0
  12. package/dist/commands/install.js +16 -0
  13. package/dist/commands/list.d.ts +1 -0
  14. package/dist/commands/list.js +58 -0
  15. package/dist/commands/run.d.ts +1 -0
  16. package/dist/commands/run.js +173 -0
  17. package/dist/commands/server.d.ts +1 -0
  18. package/dist/commands/server.js +22 -0
  19. package/dist/commands/stop.d.ts +1 -0
  20. package/dist/commands/stop.js +23 -0
  21. package/dist/commands/uninstall.d.ts +1 -0
  22. package/dist/commands/uninstall.js +12 -0
  23. package/dist/dashboard/assets/BufferResource-Cf2Uo4_f.js +185 -0
  24. package/dist/dashboard/assets/CanvasRenderer-DFdMBORe.js +1 -0
  25. package/dist/dashboard/assets/RenderTargetSystem-CMh8XRf_.js +172 -0
  26. package/dist/dashboard/assets/WebGLRenderer-B5huw0RY.js +156 -0
  27. package/dist/dashboard/assets/WebGPURenderer-BdIKurkV.js +41 -0
  28. package/dist/dashboard/assets/browserAll-BjVJrv1L.js +14 -0
  29. package/dist/dashboard/assets/index-DwTFo09S.js +344 -0
  30. package/dist/dashboard/assets/webworkerAll-DMtK63GZ.js +83 -0
  31. package/dist/dashboard/index.html +16 -0
  32. package/dist/index.d.ts +1 -0
  33. package/dist/index.js +47 -0
  34. package/dist/server/api/health-routes.d.ts +3 -0
  35. package/dist/server/api/health-routes.d.ts.map +1 -0
  36. package/dist/server/api/health-routes.js +6 -0
  37. package/dist/server/api/health-routes.js.map +1 -0
  38. package/dist/server/api/squads-routes.d.ts +7 -0
  39. package/dist/server/api/squads-routes.d.ts.map +1 -0
  40. package/dist/server/api/squads-routes.js +91 -0
  41. package/dist/server/api/squads-routes.js.map +1 -0
  42. package/dist/server/api/users-routes.d.ts +8 -0
  43. package/dist/server/api/users-routes.d.ts.map +1 -0
  44. package/dist/server/api/users-routes.js +45 -0
  45. package/dist/server/api/users-routes.js.map +1 -0
  46. package/dist/server/app.d.ts +7 -0
  47. package/dist/server/app.d.ts.map +1 -0
  48. package/dist/server/app.js +109 -0
  49. package/dist/server/app.js.map +1 -0
  50. package/dist/server/auth/auth-middleware.d.ts +13 -0
  51. package/dist/server/auth/auth-middleware.d.ts.map +1 -0
  52. package/dist/server/auth/auth-middleware.js +25 -0
  53. package/dist/server/auth/auth-middleware.js.map +1 -0
  54. package/dist/server/auth/auth-routes.d.ts +9 -0
  55. package/dist/server/auth/auth-routes.d.ts.map +1 -0
  56. package/dist/server/auth/auth-routes.js +149 -0
  57. package/dist/server/auth/auth-routes.js.map +1 -0
  58. package/dist/server/auth/jwt.d.ts +14 -0
  59. package/dist/server/auth/jwt.d.ts.map +1 -0
  60. package/dist/server/auth/jwt.js +16 -0
  61. package/dist/server/auth/jwt.js.map +1 -0
  62. package/dist/server/auth/password.d.ts +3 -0
  63. package/dist/server/auth/password.d.ts.map +1 -0
  64. package/dist/server/auth/password.js +9 -0
  65. package/dist/server/auth/password.js.map +1 -0
  66. package/dist/server/bridge/__tests__/chat-handler.test.d.ts +2 -0
  67. package/dist/server/bridge/__tests__/chat-handler.test.d.ts.map +1 -0
  68. package/dist/server/bridge/__tests__/chat-handler.test.js +132 -0
  69. package/dist/server/bridge/__tests__/chat-handler.test.js.map +1 -0
  70. package/dist/server/bridge/__tests__/chat-integration.test.d.ts +2 -0
  71. package/dist/server/bridge/__tests__/chat-integration.test.d.ts.map +1 -0
  72. package/dist/server/bridge/__tests__/chat-integration.test.js +141 -0
  73. package/dist/server/bridge/__tests__/chat-integration.test.js.map +1 -0
  74. package/dist/server/bridge/__tests__/claude-bridge.test.d.ts +2 -0
  75. package/dist/server/bridge/__tests__/claude-bridge.test.d.ts.map +1 -0
  76. package/dist/server/bridge/__tests__/claude-bridge.test.js +223 -0
  77. package/dist/server/bridge/__tests__/claude-bridge.test.js.map +1 -0
  78. package/dist/server/bridge/__tests__/conversation.test.d.ts +2 -0
  79. package/dist/server/bridge/__tests__/conversation.test.d.ts.map +1 -0
  80. package/dist/server/bridge/__tests__/conversation.test.js +168 -0
  81. package/dist/server/bridge/__tests__/conversation.test.js.map +1 -0
  82. package/dist/server/bridge/__tests__/stream-parser.test.d.ts +2 -0
  83. package/dist/server/bridge/__tests__/stream-parser.test.d.ts.map +1 -0
  84. package/dist/server/bridge/__tests__/stream-parser.test.js +66 -0
  85. package/dist/server/bridge/__tests__/stream-parser.test.js.map +1 -0
  86. package/dist/server/bridge/chat-handler.d.ts +19 -0
  87. package/dist/server/bridge/chat-handler.d.ts.map +1 -0
  88. package/dist/server/bridge/chat-handler.js +104 -0
  89. package/dist/server/bridge/chat-handler.js.map +1 -0
  90. package/dist/server/bridge/claude-bridge.d.ts +27 -0
  91. package/dist/server/bridge/claude-bridge.d.ts.map +1 -0
  92. package/dist/server/bridge/claude-bridge.js +91 -0
  93. package/dist/server/bridge/claude-bridge.js.map +1 -0
  94. package/dist/server/bridge/conversation.d.ts +44 -0
  95. package/dist/server/bridge/conversation.d.ts.map +1 -0
  96. package/dist/server/bridge/conversation.js +73 -0
  97. package/dist/server/bridge/conversation.js.map +1 -0
  98. package/dist/server/bridge/stream-parser.d.ts +14 -0
  99. package/dist/server/bridge/stream-parser.d.ts.map +1 -0
  100. package/dist/server/bridge/stream-parser.js +26 -0
  101. package/dist/server/bridge/stream-parser.js.map +1 -0
  102. package/dist/server/config.d.ts +10 -0
  103. package/dist/server/config.d.ts.map +1 -0
  104. package/dist/server/config.js +22 -0
  105. package/dist/server/config.js.map +1 -0
  106. package/dist/server/db/__tests__/chat-tables.test.d.ts +2 -0
  107. package/dist/server/db/__tests__/chat-tables.test.d.ts.map +1 -0
  108. package/dist/server/db/__tests__/chat-tables.test.js +82 -0
  109. package/dist/server/db/__tests__/chat-tables.test.js.map +1 -0
  110. package/dist/server/db/connection.d.ts +4 -0
  111. package/dist/server/db/connection.d.ts.map +1 -0
  112. package/dist/server/db/connection.js +21 -0
  113. package/dist/server/db/connection.js.map +1 -0
  114. package/dist/server/db/migrations.d.ts +4 -0
  115. package/dist/server/db/migrations.d.ts.map +1 -0
  116. package/dist/server/db/migrations.js +17 -0
  117. package/dist/server/db/migrations.js.map +1 -0
  118. package/dist/server/db/schema.d.ts +2 -0
  119. package/dist/server/db/schema.d.ts.map +1 -0
  120. package/dist/server/db/schema.js +44 -0
  121. package/dist/server/db/schema.js.map +1 -0
  122. package/dist/server/index.d.ts +2 -0
  123. package/dist/server/index.d.ts.map +1 -0
  124. package/dist/server/index.js +18 -0
  125. package/dist/server/index.js.map +1 -0
  126. package/dist/server/routes/__tests__/conversations.test.d.ts +2 -0
  127. package/dist/server/routes/__tests__/conversations.test.d.ts.map +1 -0
  128. package/dist/server/routes/__tests__/conversations.test.js +94 -0
  129. package/dist/server/routes/__tests__/conversations.test.js.map +1 -0
  130. package/dist/server/routes/conversations.d.ts +8 -0
  131. package/dist/server/routes/conversations.d.ts.map +1 -0
  132. package/dist/server/routes/conversations.js +25 -0
  133. package/dist/server/routes/conversations.js.map +1 -0
  134. package/dist/server/watcher/file-watcher.d.ts +12 -0
  135. package/dist/server/watcher/file-watcher.d.ts.map +1 -0
  136. package/dist/server/watcher/file-watcher.js +68 -0
  137. package/dist/server/watcher/file-watcher.js.map +1 -0
  138. package/dist/server/watcher/state-parser.d.ts +77 -0
  139. package/dist/server/watcher/state-parser.d.ts.map +1 -0
  140. package/dist/server/watcher/state-parser.js +74 -0
  141. package/dist/server/watcher/state-parser.js.map +1 -0
  142. package/dist/server/ws/ws-auth.d.ts +4 -0
  143. package/dist/server/ws/ws-auth.d.ts.map +1 -0
  144. package/dist/server/ws/ws-auth.js +42 -0
  145. package/dist/server/ws/ws-auth.js.map +1 -0
  146. package/dist/server/ws/ws-handler.d.ts +11 -0
  147. package/dist/server/ws/ws-handler.d.ts.map +1 -0
  148. package/dist/server/ws/ws-handler.js +107 -0
  149. package/dist/server/ws/ws-handler.js.map +1 -0
  150. package/dist/server/ws/ws-rooms.d.ts +12 -0
  151. package/dist/server/ws/ws-rooms.d.ts.map +1 -0
  152. package/dist/server/ws/ws-rooms.js +52 -0
  153. package/dist/server/ws/ws-rooms.js.map +1 -0
  154. package/dist/utils/config.d.ts +15 -0
  155. package/dist/utils/config.js +23 -0
  156. package/package.json +16 -5
@@ -0,0 +1,83 @@
1
+ import{Q as G,W as I,X as B,e as _,M as k,H as O,v as A,a0 as m,T as v,aj as C,R as E,w as z,$ as U,k as w}from"./index-DwTFo09S.js";var M=`in vec2 aPosition;
2
+ out vec2 vTextureCoord;
3
+
4
+ uniform vec4 uInputSize;
5
+ uniform vec4 uOutputFrame;
6
+ uniform vec4 uOutputTexture;
7
+
8
+ vec4 filterVertexPosition( void )
9
+ {
10
+ vec2 position = aPosition * uOutputFrame.zw + uOutputFrame.xy;
11
+
12
+ position.x = position.x * (2.0 / uOutputTexture.x) - 1.0;
13
+ position.y = position.y * (2.0*uOutputTexture.z / uOutputTexture.y) - uOutputTexture.z;
14
+
15
+ return vec4(position, 0.0, 1.0);
16
+ }
17
+
18
+ vec2 filterTextureCoord( void )
19
+ {
20
+ return aPosition * (uOutputFrame.zw * uInputSize.zw);
21
+ }
22
+
23
+ void main(void)
24
+ {
25
+ gl_Position = filterVertexPosition();
26
+ vTextureCoord = filterTextureCoord();
27
+ }
28
+ `,V=`in vec2 vTextureCoord;
29
+ out vec4 finalColor;
30
+ uniform sampler2D uTexture;
31
+ void main() {
32
+ finalColor = texture(uTexture, vTextureCoord);
33
+ }
34
+ `,y=`struct GlobalFilterUniforms {
35
+ uInputSize: vec4<f32>,
36
+ uInputPixel: vec4<f32>,
37
+ uInputClamp: vec4<f32>,
38
+ uOutputFrame: vec4<f32>,
39
+ uGlobalFrame: vec4<f32>,
40
+ uOutputTexture: vec4<f32>,
41
+ };
42
+
43
+ @group(0) @binding(0) var <uniform> gfu: GlobalFilterUniforms;
44
+ @group(0) @binding(1) var uTexture: texture_2d<f32>;
45
+ @group(0) @binding(2) var uSampler: sampler;
46
+
47
+ struct VSOutput {
48
+ @builtin(position) position: vec4<f32>,
49
+ @location(0) uv: vec2<f32>
50
+ };
51
+
52
+ fn filterVertexPosition(aPosition: vec2<f32>) -> vec4<f32>
53
+ {
54
+ var position = aPosition * gfu.uOutputFrame.zw + gfu.uOutputFrame.xy;
55
+
56
+ position.x = position.x * (2.0 / gfu.uOutputTexture.x) - 1.0;
57
+ position.y = position.y * (2.0 * gfu.uOutputTexture.z / gfu.uOutputTexture.y) - gfu.uOutputTexture.z;
58
+
59
+ return vec4(position, 0.0, 1.0);
60
+ }
61
+
62
+ fn filterTextureCoord(aPosition: vec2<f32>) -> vec2<f32>
63
+ {
64
+ return aPosition * (gfu.uOutputFrame.zw * gfu.uInputSize.zw);
65
+ }
66
+
67
+ @vertex
68
+ fn mainVertex(
69
+ @location(0) aPosition: vec2<f32>,
70
+ ) -> VSOutput {
71
+ return VSOutput(
72
+ filterVertexPosition(aPosition),
73
+ filterTextureCoord(aPosition)
74
+ );
75
+ }
76
+
77
+ @fragment
78
+ fn mainFragment(
79
+ @location(0) uv: vec2<f32>,
80
+ ) -> @location(0) vec4<f32> {
81
+ return textureSample(uTexture, uSampler, uv);
82
+ }
83
+ `;class Y extends G{constructor(){const e=I.from({vertex:{source:y,entryPoint:"mainVertex"},fragment:{source:y,entryPoint:"mainFragment"},name:"passthrough-filter"}),t=B.from({vertex:M,fragment:V,name:"passthrough-filter"});super({gpuProgram:e,glProgram:t})}}class R{constructor(e){this._renderer=e}push(e,t,r){this._renderer.renderPipes.batch.break(r),r.add({renderPipeId:"filter",canBundle:!1,action:"pushFilter",container:t,filterEffect:e})}pop(e,t,r){this._renderer.renderPipes.batch.break(r),r.add({renderPipeId:"filter",action:"popFilter",canBundle:!1})}execute(e){e.action==="pushFilter"?this._renderer.filter.push(e):e.action==="popFilter"&&this._renderer.filter.pop()}destroy(){this._renderer=null}}R.extension={type:[_.WebGLPipes,_.WebGPUPipes,_.CanvasPipes],name:"filter"};const P=new k;function X(T,e){e.clear();const t=e.matrix;for(let r=0;r<T.length;r++){const n=T[r];if(n.globalDisplayStatus<7)continue;const i=n.renderGroup??n.parentRenderGroup;i!=null&&i.isCachedAsTexture?e.matrix=P.copyFrom(i.textureOffsetInverseTransform).append(n.worldTransform):i!=null&&i._parentCacheAsTextureRenderGroup?e.matrix=P.copyFrom(i._parentCacheAsTextureRenderGroup.inverseWorldTransform).append(n.groupTransform):e.matrix=n.worldTransform,e.addBounds(n.bounds)}return e.matrix=t,e}const q=new C({attributes:{aPosition:{buffer:new Float32Array([0,0,1,0,1,1,0,1]),format:"float32x2",stride:8,offset:0}},indexBuffer:new Uint32Array([0,1,2,0,2,3])});class W{constructor(){this.skip=!1,this.inputTexture=null,this.backTexture=null,this.filters=null,this.bounds=new U,this.container=null,this.blendRequired=!1,this.outputRenderSurface=null,this.globalFrame={x:0,y:0,width:0,height:0},this.firstEnabledIndex=-1,this.lastEnabledIndex=-1}}class S{constructor(e){this._filterStackIndex=0,this._filterStack=[],this._filterGlobalUniforms=new O({uInputSize:{value:new Float32Array(4),type:"vec4<f32>"},uInputPixel:{value:new Float32Array(4),type:"vec4<f32>"},uInputClamp:{value:new Float32Array(4),type:"vec4<f32>"},uOutputFrame:{value:new Float32Array(4),type:"vec4<f32>"},uGlobalFrame:{value:new Float32Array(4),type:"vec4<f32>"},uOutputTexture:{value:new Float32Array(4),type:"vec4<f32>"}}),this._globalFilterBindGroup=new A({}),this.renderer=e}get activeBackTexture(){var e;return(e=this._activeFilterData)==null?void 0:e.backTexture}push(e){const t=this.renderer,r=e.filterEffect.filters,n=this._pushFilterData();n.skip=!1,n.filters=r,n.container=e.container,n.outputRenderSurface=t.renderTarget.renderSurface;const i=t.renderTarget.renderTarget.colorTexture.source,o=i.resolution,s=i.antialias;if(r.every(d=>!d.enabled)){n.skip=!0;return}const c=n.bounds;if(this._calculateFilterArea(e,c),this._calculateFilterBounds(n,t.renderTarget.rootViewPort,s,o,1),n.skip)return;const u=this._getPreviousFilterData(),f=this._findFilterResolution(o);let l=0,a=0;u&&(l=u.bounds.minX,a=u.bounds.minY),this._calculateGlobalFrame(n,l,a,f,i.width,i.height),this._setupFilterTextures(n,c,t,u)}generateFilteredTexture({texture:e,filters:t}){const r=this._pushFilterData();this._activeFilterData=r,r.skip=!1,r.filters=t;const n=e.source,i=n.resolution,o=n.antialias;if(t.every(d=>!d.enabled))return r.skip=!0,e;const s=r.bounds;if(s.addRect(e.frame),this._calculateFilterBounds(r,s.rectangle,o,i,0),r.skip)return e;const c=i;this._calculateGlobalFrame(r,0,0,c,n.width,n.height),r.outputRenderSurface=m.getOptimalTexture(s.width,s.height,r.resolution,r.antialias),r.backTexture=v.EMPTY,r.inputTexture=e,this.renderer.renderTarget.finishRenderPass(),this._applyFiltersToTexture(r,!0);const a=r.outputRenderSurface;return a.source.alphaMode="premultiplied-alpha",a}pop(){const e=this.renderer,t=this._popFilterData();t.skip||(e.globalUniforms.pop(),e.renderTarget.finishRenderPass(),this._activeFilterData=t,this._applyFiltersToTexture(t,!1),t.blendRequired&&m.returnTexture(t.backTexture),m.returnTexture(t.inputTexture))}getBackTexture(e,t,r){const n=e.colorTexture.source._resolution,i=m.getOptimalTexture(t.width,t.height,n,!1);let o=t.minX,s=t.minY;r&&(o-=r.minX,s-=r.minY),o=Math.floor(o*n),s=Math.floor(s*n);const c=Math.ceil(t.width*n),u=Math.ceil(t.height*n);return this.renderer.renderTarget.copyToTexture(e,i,{x:o,y:s},{width:c,height:u},{x:0,y:0}),i}applyFilter(e,t,r,n){const i=this.renderer,o=this._activeFilterData,c=o.outputRenderSurface===r,u=i.renderTarget.rootRenderTarget.colorTexture.source._resolution,f=this._findFilterResolution(u);let l=0,a=0;if(c){const p=this._findPreviousFilterOffset();l=p.x,a=p.y}this._updateFilterUniforms(t,r,o,l,a,f,c,n);const d=e.enabled?e:this._getPassthroughFilter();this._setupBindGroupsAndRender(d,t,i)}calculateSpriteMatrix(e,t){const r=this._activeFilterData,n=e.set(r.inputTexture._source.width,0,0,r.inputTexture._source.height,r.bounds.minX,r.bounds.minY),i=t.worldTransform.copyTo(k.shared),o=t.renderGroup||t.parentRenderGroup;return o&&o.cacheToLocalTransform&&i.prepend(o.cacheToLocalTransform),i.invert(),n.prepend(i),n.scale(1/t.texture.orig.width,1/t.texture.orig.height),n.translate(t.anchor.x,t.anchor.y),n}destroy(){var e;(e=this._passthroughFilter)==null||e.destroy(!0),this._passthroughFilter=null}_getPassthroughFilter(){return this._passthroughFilter??(this._passthroughFilter=new Y),this._passthroughFilter}_setupBindGroupsAndRender(e,t,r){if(r.renderPipes.uniformBatch){const n=r.renderPipes.uniformBatch.getUboResource(this._filterGlobalUniforms);this._globalFilterBindGroup.setResource(n,0)}else this._globalFilterBindGroup.setResource(this._filterGlobalUniforms,0);this._globalFilterBindGroup.setResource(t.source,1),this._globalFilterBindGroup.setResource(t.source.style,2),e.groups[0]=this._globalFilterBindGroup,r.encoder.draw({geometry:q,shader:e,state:e._state,topology:"triangle-list"}),r.type===E.WEBGL&&r.renderTarget.finishRenderPass()}_setupFilterTextures(e,t,r,n){if(e.backTexture=v.EMPTY,e.inputTexture=m.getOptimalTexture(t.width,t.height,e.resolution,e.antialias),e.blendRequired){r.renderTarget.finishRenderPass();const i=r.renderTarget.getRenderTarget(e.outputRenderSurface);e.backTexture=this.getBackTexture(i,t,n==null?void 0:n.bounds)}r.renderTarget.bind(e.inputTexture,!0),r.globalUniforms.push({offset:t})}_calculateGlobalFrame(e,t,r,n,i,o){const s=e.globalFrame;s.x=t*n,s.y=r*n,s.width=i*n,s.height=o*n}_updateFilterUniforms(e,t,r,n,i,o,s,c){const u=this._filterGlobalUniforms.uniforms,f=u.uOutputFrame,l=u.uInputSize,a=u.uInputPixel,d=u.uInputClamp,p=u.uGlobalFrame,x=u.uOutputTexture;s?(f[0]=r.bounds.minX-n,f[1]=r.bounds.minY-i):(f[0]=0,f[1]=0),f[2]=e.frame.width,f[3]=e.frame.height,l[0]=e.source.width,l[1]=e.source.height,l[2]=1/l[0],l[3]=1/l[1],a[0]=e.source.pixelWidth,a[1]=e.source.pixelHeight,a[2]=1/a[0],a[3]=1/a[1],d[0]=.5*a[2],d[1]=.5*a[3],d[2]=e.frame.width*l[2]-.5*a[2],d[3]=e.frame.height*l[3]-.5*a[3];const b=this.renderer.renderTarget.rootRenderTarget.colorTexture;p[0]=n*o,p[1]=i*o,p[2]=b.source.width*o,p[3]=b.source.height*o,t instanceof v&&(t.source.resource=null);const g=this.renderer.renderTarget.getRenderTarget(t);this.renderer.renderTarget.bind(t,!!c),t instanceof v?(x[0]=t.frame.width,x[1]=t.frame.height):(x[0]=g.width,x[1]=g.height),x[2]=g.isRoot?-1:1,this._filterGlobalUniforms.update()}_findFilterResolution(e){let t=this._filterStackIndex-1;for(;t>0&&this._filterStack[t].skip;)--t;return t>0&&this._filterStack[t].inputTexture?this._filterStack[t].inputTexture.source._resolution:e}_findPreviousFilterOffset(){let e=0,t=0,r=this._filterStackIndex;for(;r>0;){r--;const n=this._filterStack[r];if(!n.skip){e=n.bounds.minX,t=n.bounds.minY;break}}return{x:e,y:t}}_calculateFilterArea(e,t){if(e.renderables?X(e.renderables,t):e.filterEffect.filterArea?(t.clear(),t.addRect(e.filterEffect.filterArea),t.applyMatrix(e.container.worldTransform)):e.container.getFastGlobalBounds(!0,t),e.container){const n=(e.container.renderGroup||e.container.parentRenderGroup).cacheToLocalTransform;n&&t.applyMatrix(n)}}_applyFiltersToTexture(e,t){const r=e.inputTexture,n=e.bounds,i=e.filters,o=e.firstEnabledIndex,s=e.lastEnabledIndex;if(this._globalFilterBindGroup.setResource(r.source.style,2),this._globalFilterBindGroup.setResource(e.backTexture.source,3),o===s)i[o].apply(this,r,e.outputRenderSurface,t);else{let c=e.inputTexture;const u=m.getOptimalTexture(n.width,n.height,c.source._resolution,!1);let f=u;for(let l=o;l<s;l++){const a=i[l];if(!a.enabled)continue;a.apply(this,c,f,!0);const d=c;c=f,f=d}i[s].apply(this,c,e.outputRenderSurface,t),m.returnTexture(u)}}_calculateFilterBounds(e,t,r,n,i){var g;const o=this.renderer,s=e.bounds,c=e.filters;let u=1/0,f=0,l=!0,a=!1,d=!1,p=!0,x=-1,b=-1;for(let F=0;F<c.length;F++){const h=c[F];if(!h.enabled)continue;if(x===-1&&(x=F),b=F,u=Math.min(u,h.resolution==="inherit"?n:h.resolution),f+=h.padding,h.antialias==="off"?l=!1:h.antialias==="inherit"&&l&&(l=r),h.clipToViewport||(p=!1),!!!(h.compatibleRenderers&o.type)){d=!1;break}if(h.blendRequired&&!(((g=o.backBuffer)==null?void 0:g.useBackBuffer)??!0)){z("Blend filter requires backBuffer on WebGL renderer to be enabled. Set `useBackBuffer: true` in the renderer options."),d=!1;break}d=!0,a||(a=h.blendRequired)}if(!d){e.skip=!0;return}if(p&&s.fitBounds(0,t.width/n,0,t.height/n),s.scale(u).ceil().scale(1/u).pad((f|0)*i),!s.isPositive){e.skip=!0;return}e.antialias=l,e.resolution=u,e.blendRequired=a,e.firstEnabledIndex=x,e.lastEnabledIndex=b}_popFilterData(){return this._filterStackIndex--,this._filterStack[this._filterStackIndex]}_getPreviousFilterData(){let e,t=this._filterStackIndex-1;for(;t>0&&(t--,e=this._filterStack[t],!!e.skip););return e}_pushFilterData(){let e=this._filterStack[this._filterStackIndex];return e||(e=this._filterStack[this._filterStackIndex]=new W),this._filterStackIndex++,e}}S.extension={type:[_.WebGLSystem,_.WebGPUSystem],name:"filter"};w.add(S);w.add(R);
@@ -0,0 +1,16 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <title>ExpxAgents</title>
7
+ <style>
8
+ * { margin: 0; padding: 0; box-sizing: border-box; }
9
+ body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; background: #0f0f1a; color: #e0e0e0; }
10
+ </style>
11
+ <script type="module" crossorigin src="/assets/index-DwTFo09S.js"></script>
12
+ </head>
13
+ <body>
14
+ <div id="root"></div>
15
+ </body>
16
+ </html>
@@ -0,0 +1 @@
1
+ export {};
package/dist/index.js ADDED
@@ -0,0 +1,47 @@
1
+ import { Command } from 'commander';
2
+ import { initCommand } from './commands/init.js';
3
+ import { createCommand } from './commands/create.js';
4
+ import { runCommand } from './commands/run.js';
5
+ import { stopCommand } from './commands/stop.js';
6
+ import { listCommand } from './commands/list.js';
7
+ import { installCommand } from './commands/install.js';
8
+ import { uninstallCommand } from './commands/uninstall.js';
9
+ import { serverCommand } from './commands/server.js';
10
+ const program = new Command();
11
+ program
12
+ .name('expxagents')
13
+ .description('ExpxAgents — Multi-agent orchestration platform')
14
+ .version('0.1.0');
15
+ program
16
+ .command('init')
17
+ .description('Initialize project (dirs, .env, admin user)')
18
+ .action(initCommand);
19
+ program
20
+ .command('create')
21
+ .description('Create a new squad (interactive via Architect)')
22
+ .action(createCommand);
23
+ program
24
+ .command('run <name>')
25
+ .description('Execute squad pipeline')
26
+ .action(runCommand);
27
+ program
28
+ .command('stop <name>')
29
+ .description('Stop running squad')
30
+ .action(stopCommand);
31
+ program
32
+ .command('list')
33
+ .description('List squads and skills')
34
+ .action(listCommand);
35
+ program
36
+ .command('install <skill>')
37
+ .description('Install skill from registry')
38
+ .action(installCommand);
39
+ program
40
+ .command('uninstall <skill>')
41
+ .description('Remove skill')
42
+ .action(uninstallCommand);
43
+ program
44
+ .command('server')
45
+ .description('Start the web server')
46
+ .action(serverCommand);
47
+ program.parse();
@@ -0,0 +1,3 @@
1
+ import type { FastifyInstance } from 'fastify';
2
+ export declare function healthRoutes(app: FastifyInstance): Promise<void>;
3
+ //# sourceMappingURL=health-routes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"health-routes.d.ts","sourceRoot":"","sources":["../../src/api/health-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C,wBAAsB,YAAY,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAItE"}
@@ -0,0 +1,6 @@
1
+ export async function healthRoutes(app) {
2
+ app.get('/api/health', async () => {
3
+ return { status: 'ok' };
4
+ });
5
+ }
6
+ //# sourceMappingURL=health-routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"health-routes.js","sourceRoot":"","sources":["../../src/api/health-routes.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,GAAoB;IACrD,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;QAChC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
2
+ interface SquadsRoutesOptions extends FastifyPluginOptions {
3
+ squadsDir: string;
4
+ }
5
+ export declare function squadsRoutes(app: FastifyInstance, opts: SquadsRoutesOptions): Promise<void>;
6
+ export {};
7
+ //# sourceMappingURL=squads-routes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"squads-routes.d.ts","sourceRoot":"","sources":["../../src/api/squads-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAKrE,UAAU,mBAAoB,SAAQ,oBAAoB;IACxD,SAAS,EAAE,MAAM,CAAC;CACnB;AAyDD,wBAAsB,YAAY,CAChC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,mBAAmB,GACxB,OAAO,CAAC,IAAI,CAAC,CAwDf"}
@@ -0,0 +1,91 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { parse as parseYaml } from 'yaml';
4
+ function discoverSquads(squadsDir) {
5
+ if (!fs.existsSync(squadsDir))
6
+ return [];
7
+ const entries = fs.readdirSync(squadsDir, { withFileTypes: true });
8
+ const squads = [];
9
+ for (const entry of entries) {
10
+ if (!entry.isDirectory())
11
+ continue;
12
+ if (entry.name.startsWith('.') || entry.name.startsWith('_'))
13
+ continue;
14
+ const yamlPath = path.join(squadsDir, entry.name, 'squad.yaml');
15
+ if (fs.existsSync(yamlPath)) {
16
+ try {
17
+ const raw = fs.readFileSync(yamlPath, 'utf-8');
18
+ const parsed = parseYaml(raw);
19
+ const s = parsed?.squad;
20
+ if (s) {
21
+ squads.push({
22
+ code: typeof s.code === 'string' ? s.code : entry.name,
23
+ name: typeof s.name === 'string' ? s.name : entry.name,
24
+ description: typeof s.description === 'string' ? s.description : '',
25
+ icon: typeof s.icon === 'string' ? s.icon : '📋',
26
+ agents: Array.isArray(s.agents) ? s.agents.map((a) => ({
27
+ id: a.id || a,
28
+ name: a.name || a.id || a,
29
+ icon: a.icon || 'robot',
30
+ })) : [],
31
+ });
32
+ continue;
33
+ }
34
+ }
35
+ catch {
36
+ // Fall through
37
+ }
38
+ }
39
+ squads.push({
40
+ code: entry.name,
41
+ name: entry.name,
42
+ description: '',
43
+ icon: '📋',
44
+ agents: [],
45
+ });
46
+ }
47
+ return squads;
48
+ }
49
+ export async function squadsRoutes(app, opts) {
50
+ const { squadsDir } = opts;
51
+ // GET /api/squads
52
+ app.get('/api/squads', { preHandler: [app.requireAuth] }, async () => {
53
+ return { squads: discoverSquads(squadsDir) };
54
+ });
55
+ // GET /api/squads/:name
56
+ app.get('/api/squads/:name', { preHandler: [app.requireAuth] }, async (request, reply) => {
57
+ const { name } = request.params;
58
+ const squadDir = path.join(squadsDir, name);
59
+ if (!fs.existsSync(squadDir)) {
60
+ return reply.code(404).send({ error: 'Squad not found' });
61
+ }
62
+ const squads = discoverSquads(squadsDir);
63
+ const squad = squads.find((s) => s.code === name);
64
+ let state = null;
65
+ const statePath = path.join(squadDir, 'state.json');
66
+ if (fs.existsSync(statePath)) {
67
+ try {
68
+ state = JSON.parse(fs.readFileSync(statePath, 'utf-8'));
69
+ }
70
+ catch {
71
+ // Skip invalid JSON
72
+ }
73
+ }
74
+ return { squad: squad || { code: name, name, description: '', icon: '📋', agents: [] }, state };
75
+ });
76
+ // GET /api/squads/:name/state
77
+ app.get('/api/squads/:name/state', { preHandler: [app.requireAuth] }, async (request, reply) => {
78
+ const { name } = request.params;
79
+ const statePath = path.join(squadsDir, name, 'state.json');
80
+ if (!fs.existsSync(statePath)) {
81
+ return reply.code(404).send({ error: 'State not found' });
82
+ }
83
+ try {
84
+ return JSON.parse(fs.readFileSync(statePath, 'utf-8'));
85
+ }
86
+ catch {
87
+ return reply.code(500).send({ error: 'Invalid state file' });
88
+ }
89
+ });
90
+ }
91
+ //# sourceMappingURL=squads-routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"squads-routes.js","sourceRoot":"","sources":["../../src/api/squads-routes.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
2
+ import type Database from 'better-sqlite3';
3
+ interface UsersRoutesOptions extends FastifyPluginOptions {
4
+ db: Database.Database;
5
+ }
6
+ export declare function usersRoutes(app: FastifyInstance, opts: UsersRoutesOptions): Promise<void>;
7
+ export {};
8
+ //# sourceMappingURL=users-routes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"users-routes.d.ts","sourceRoot":"","sources":["../../src/api/users-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAE3C,UAAU,kBAAmB,SAAQ,oBAAoB;IACvD,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;CACvB;AAWD,wBAAsB,WAAW,CAC/B,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,kBAAkB,GACvB,OAAO,CAAC,IAAI,CAAC,CA2Ef"}
@@ -0,0 +1,45 @@
1
+ export async function usersRoutes(app, opts) {
2
+ const { db } = opts;
3
+ // GET /api/users (admin only)
4
+ app.get('/api/users', { preHandler: [app.requireAuth, app.requireRole('admin')] }, async () => {
5
+ const users = db
6
+ .prepare('SELECT id, username, email, role, created_at, last_login FROM users')
7
+ .all();
8
+ return { users };
9
+ });
10
+ // PATCH /api/users/:id (admin only)
11
+ app.patch('/api/users/:id', { preHandler: [app.requireAuth, app.requireRole('admin')] }, async (request, reply) => {
12
+ const { id } = request.params;
13
+ const { role } = request.body;
14
+ const validRoles = ['admin', 'operator', 'viewer'];
15
+ if (!role || !validRoles.includes(role)) {
16
+ return reply.code(400).send({ error: 'Invalid role. Must be admin, operator, or viewer.' });
17
+ }
18
+ const user = db.prepare('SELECT id FROM users WHERE id = ?').get(id);
19
+ if (!user) {
20
+ return reply.code(404).send({ error: 'User not found' });
21
+ }
22
+ db.prepare('UPDATE users SET role = ? WHERE id = ?').run(role, id);
23
+ const updated = db
24
+ .prepare('SELECT id, username, email, role, created_at, last_login FROM users WHERE id = ?')
25
+ .get(id);
26
+ return { user: updated };
27
+ });
28
+ // DELETE /api/users/:id (admin only)
29
+ app.delete('/api/users/:id', { preHandler: [app.requireAuth, app.requireRole('admin')] }, async (request, reply) => {
30
+ const { id } = request.params;
31
+ if (id === request.user.userId) {
32
+ return reply.code(400).send({ error: 'Cannot delete yourself' });
33
+ }
34
+ const user = db.prepare('SELECT id FROM users WHERE id = ?').get(id);
35
+ if (!user) {
36
+ return reply.code(404).send({ error: 'User not found' });
37
+ }
38
+ db.prepare('DELETE FROM sessions WHERE user_id = ?').run(id);
39
+ db.prepare('DELETE FROM users WHERE id = ?').run(id);
40
+ // Audit log
41
+ db.prepare('INSERT INTO audit_log (user_id, action, details, created_at) VALUES (?, ?, ?, ?)').run(request.user.userId, 'delete_user', JSON.stringify({ deletedUserId: id }), new Date().toISOString());
42
+ return { ok: true };
43
+ });
44
+ }
45
+ //# sourceMappingURL=users-routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"users-routes.js","sourceRoot":"","sources":["../../src/api/users-routes.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { FastifyInstance } from 'fastify';
2
+ import { type Config } from './config.js';
3
+ export interface BuildAppOptions {
4
+ config?: Partial<Config>;
5
+ }
6
+ export declare function buildApp(opts?: BuildAppOptions): Promise<FastifyInstance>;
7
+ //# sourceMappingURL=app.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAQ/C,OAAO,EAAc,KAAK,MAAM,EAAE,MAAM,aAAa,CAAC;AAgBtD,MAAM,WAAW,eAAe;IAC9B,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;CAC1B;AAED,wBAAsB,QAAQ,CAAC,IAAI,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,eAAe,CAAC,CA6F/E"}
@@ -0,0 +1,109 @@
1
+ import Fastify from 'fastify';
2
+ import cors from '@fastify/cors';
3
+ import cookie from '@fastify/cookie';
4
+ import rateLimit from '@fastify/rate-limit';
5
+ import fastifyStatic from '@fastify/static';
6
+ import path from 'node:path';
7
+ import { fileURLToPath } from 'node:url';
8
+ import { loadConfig } from './config.js';
9
+ import { getDb } from './db/connection.js';
10
+ import { seedDefaultAdmin } from './db/migrations.js';
11
+ import { registerAuthMiddleware } from './auth/auth-middleware.js';
12
+ import { healthRoutes } from './api/health-routes.js';
13
+ import { authRoutes } from './auth/auth-routes.js';
14
+ import { squadsRoutes } from './api/squads-routes.js';
15
+ import { usersRoutes } from './api/users-routes.js';
16
+ import { registerWebSocket } from './ws/ws-handler.js';
17
+ import { createFileWatcher } from './watcher/file-watcher.js';
18
+ import { conversationRoutes } from './routes/conversations.js';
19
+ import { ClaudeBridge } from './bridge/claude-bridge.js';
20
+ import { ChatHandler } from './bridge/chat-handler.js';
21
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
22
+ export async function buildApp(opts) {
23
+ const config = { ...loadConfig(), ...opts?.config };
24
+ const app = Fastify({
25
+ logger: {
26
+ level: config.nodeEnv === 'production' ? 'info' : 'debug',
27
+ },
28
+ });
29
+ // Plugins
30
+ await app.register(cors, { origin: config.corsOrigin, credentials: true });
31
+ await app.register(cookie);
32
+ await app.register(rateLimit, {
33
+ global: false,
34
+ });
35
+ // Database
36
+ const db = getDb(config.dataDir);
37
+ await seedDefaultAdmin(db);
38
+ // Expose db on the app instance for testability
39
+ app.decorate('db', db);
40
+ // Auth middleware
41
+ registerAuthMiddleware(app, config.jwtSecret);
42
+ // Routes
43
+ await app.register(healthRoutes);
44
+ await app.register(authRoutes, { db, jwtSecret: config.jwtSecret });
45
+ await app.register(squadsRoutes, { squadsDir: config.squadsDir });
46
+ await app.register(usersRoutes, { db });
47
+ await app.register(conversationRoutes, { db });
48
+ // WebSocket
49
+ const wsContext = await registerWebSocket(app, config.jwtSecret, config.squadsDir);
50
+ // Chat Bridge
51
+ const bridge = new ClaudeBridge({
52
+ timeoutMs: parseInt(process.env.BRIDGE_TIMEOUT_MS ?? '300000', 10),
53
+ });
54
+ const chatHandler = new ChatHandler({
55
+ db,
56
+ bridge,
57
+ broadcast: (squadName, message) => {
58
+ wsContext.broadcastToSquad(squadName, message);
59
+ },
60
+ squadsDir: config.squadsDir,
61
+ });
62
+ wsContext.setChatHandler(chatHandler);
63
+ // File Watcher
64
+ const watcher = createFileWatcher(config.squadsDir, (event) => {
65
+ if (event.type === 'squad:state') {
66
+ wsContext.broadcastToSquad(event.squadName, event);
67
+ }
68
+ else if (event.type === 'squad:inactive') {
69
+ wsContext.broadcastToSquad(event.squadName, event);
70
+ }
71
+ else if (event.type === 'agent:status') {
72
+ wsContext.broadcastToAll(event);
73
+ }
74
+ else if (event.type === 'chat:agent_dm') {
75
+ wsContext.broadcastToAll(event);
76
+ }
77
+ else if (event.type === 'agent:step_start') {
78
+ wsContext.broadcastToSquad(event.squadName, event);
79
+ }
80
+ else if (event.type === 'agent:step_complete') {
81
+ wsContext.broadcastToSquad(event.squadName, event);
82
+ }
83
+ else if (event.type === 'squad:checkpoint') {
84
+ wsContext.broadcastToSquad(event.squadName, event);
85
+ }
86
+ });
87
+ await watcher.ready;
88
+ // Cleanup watcher on close
89
+ app.addHook('onClose', async () => {
90
+ watcher.stop();
91
+ });
92
+ // Serve static files in production
93
+ if (config.nodeEnv === 'production') {
94
+ const dashboardDist = process.env.DASHBOARD_DIST ?? path.resolve(__dirname, '..', '..', 'dashboard', 'dist');
95
+ await app.register(fastifyStatic, {
96
+ root: dashboardDist,
97
+ prefix: '/',
98
+ wildcard: false,
99
+ });
100
+ app.setNotFoundHandler(async (request, reply) => {
101
+ if (request.url.startsWith('/api/') || request.url.startsWith('/ws')) {
102
+ return reply.code(404).send({ error: 'Not found' });
103
+ }
104
+ return reply.sendFile('index.html');
105
+ });
106
+ }
107
+ return app;
108
+ }
109
+ //# sourceMappingURL=app.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { FastifyInstance } from 'fastify';
2
+ import { type AccessTokenPayload } from './jwt.js';
3
+ declare module 'fastify' {
4
+ interface FastifyInstance {
5
+ requireAuth: (request: FastifyRequest, reply: FastifyReply) => Promise<void>;
6
+ requireRole: (role: string) => (request: FastifyRequest, reply: FastifyReply) => Promise<void>;
7
+ }
8
+ interface FastifyRequest {
9
+ user: AccessTokenPayload;
10
+ }
11
+ }
12
+ export declare function registerAuthMiddleware(app: FastifyInstance, jwtSecret: string): void;
13
+ //# sourceMappingURL=auth-middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-middleware.d.ts","sourceRoot":"","sources":["../../src/auth/auth-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAgC,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAqB,KAAK,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAEtE,OAAO,QAAQ,SAAS,CAAC;IACvB,UAAU,eAAe;QACvB,WAAW,EAAE,CAAC,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,YAAY,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7E,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,YAAY,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;KAChG;IACD,UAAU,cAAc;QACtB,IAAI,EAAE,kBAAkB,CAAC;KAC1B;CACF;AAED,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI,CA0BpF"}
@@ -0,0 +1,25 @@
1
+ import { verifyAccessToken } from './jwt.js';
2
+ export function registerAuthMiddleware(app, jwtSecret) {
3
+ app.decorateRequest('user', null);
4
+ app.decorate('requireAuth', async function (request, reply) {
5
+ const token = request.cookies?.access_token ||
6
+ request.headers.authorization?.replace('Bearer ', '');
7
+ if (!token) {
8
+ return reply.code(401).send({ error: 'Authentication required' });
9
+ }
10
+ try {
11
+ request.user = verifyAccessToken(token, jwtSecret);
12
+ }
13
+ catch {
14
+ return reply.code(401).send({ error: 'Invalid or expired token' });
15
+ }
16
+ });
17
+ app.decorate('requireRole', function (role) {
18
+ return async function (request, reply) {
19
+ if (request.user.role !== role) {
20
+ return reply.code(403).send({ error: 'Insufficient permissions' });
21
+ }
22
+ };
23
+ });
24
+ }
25
+ //# sourceMappingURL=auth-middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-middleware.js","sourceRoot":"","sources":["../../src/auth/auth-middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAA2B,MAAM,UAAU,CAAC;AAYtE,MAAM,UAAU,sBAAsB,CAAC,GAAoB,EAAE,SAAiB;IAC5E,GAAG,CAAC,eAAe,CAAC,MAAM,EAAE,IAAqC,CAAC,CAAC;IAEnE,GAAG,CAAC,QAAQ,CAAC,aAAa,EAAE,KAAK,WAAW,OAAuB,EAAE,KAAmB;QACtF,MAAM,KAAK,GACT,OAAO,CAAC,OAAO,EAAE,YAAY;YAC7B,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QAExD,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,yBAAyB,EAAE,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,CAAC;YACH,OAAO,CAAC,IAAI,GAAG,iBAAiB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,CAAC;QACrE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,QAAQ,CAAC,aAAa,EAAE,UAAU,IAAY;QAChD,OAAO,KAAK,WAAW,OAAuB,EAAE,KAAmB;YACjE,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;gBAC/B,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,CAAC;YACrE,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
2
+ import type Database from 'better-sqlite3';
3
+ interface AuthRoutesOptions extends FastifyPluginOptions {
4
+ db: Database.Database;
5
+ jwtSecret: string;
6
+ }
7
+ export declare function authRoutes(app: FastifyInstance, opts: AuthRoutesOptions): Promise<void>;
8
+ export {};
9
+ //# sourceMappingURL=auth-routes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-routes.d.ts","sourceRoot":"","sources":["../../src/auth/auth-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAK3C,UAAU,iBAAkB,SAAQ,oBAAoB;IACtD,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAYD,wBAAsB,UAAU,CAC9B,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,iBAAiB,GACtB,OAAO,CAAC,IAAI,CAAC,CAqNf"}