@fugood/bricks-cli 2.24.0-beta.18 → 2.24.0-beta.19

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 (2) hide show
  1. package/lib/index.js +1 -1
  2. package/package.json +3 -3
package/lib/index.js CHANGED
@@ -3141,4 +3141,4 @@ import{createRequire as e}from"node:module";const t=e(import.meta.url);import*as
3141
3141
  }
3142
3142
  }
3143
3143
  ${Hh}
3144
- `,vy={query:"query",mutation:"mutate"},Ry=(e,t,a)=>([n,r])=>{if(e[n])throw new Error(`Overwriting client.${n}`);e[n]=async(i,o={})=>{let s,p;const l={[t]:r,variables:i,...o};if(a&&(l.variables={...a,...l.variables}),o.readQuery)s=e.readQuery(l);else if(o.writeQuery)e.writeQuery({...l,data:o.writeQuery});else{const a=await e[vy[t]](l);({data:s,errors:p}=a||{})}if(p)throw new Error(p.map(e=>e.message).join("\n"));return s?s[n]:null}},by=e=>({data:t,errors:a})=>{const n=((e,t)=>e?.length?new Error(e.map(e=>e.message).join("\n")):t?new Error(t):null)(a,!t?.mediaBoxChanged&&"Missing mediaBoxChanged payload");return n?e(n):e(null,t.mediaBoxChanged)},Oy=(e={})=>{const t=(({endpoint:e="http://localhost:3002",accessToken:t,boxId:a,passcode:n,enableSubscription:r=!0,enableRetry:i=!0,subscriptionOnConnectionOrError:o,onNetworkError:s}={})=>{const p=a&&n;let l=`${e}/api/graphql`;return p&&(l=`${e}/api/graphql_with_passcode`),Kh({endpointURL:l,subscriptionEndpointURL:l.replace("http:","ws:"),accessToken:t,enableSubscription:!p&&r,enableRetry:i,subscriptionOnConnectionOrError:o,onNetworkError:s})})(e);if(e.boxId&&e.passcode){t.type="passcode",t.queries=R,t.mutations=b;const a={boxId:e.boxId,passcode:e.passcode};Object.entries(R).forEach(Ry(t,"query",a)),Object.entries(b).forEach(Ry(t,"mutation",a)),t.listenBoxChanged=(e,n)=>t.subscribe({query:gy,variables:{...a,...e}}).subscribe({next:by(n),error(e){n(e)}})}else t.accessToken=e.accessToken,t.type="token",t.queries=g,t.mutations=v,Object.entries(g).forEach(Ry(t,"query")),Object.entries(v).forEach(Ry(t,"mutation")),t.listenBoxChanged=(e,a)=>t.subscribe({query:cy,variables:e}).subscribe({next:by(a),error(e){a(e)}});return t};function Ny(e,t,a){switch(a){case"user":return new yf(e,t);case"workspace":return new ah(e,t);default:throw new Error(`Invalid token type: ${a}.`)}}process.env.STAGE,process.env.URL_BASE;var Ay="bricks-mcp",Sy={bricks:process.env.BRICKS_API_SERVER||"https://display-beta.bricks.tools",media:process.env.MEDIA_API_SERVER||"https://media-beta.bricks.tools"},wy=(process.env.AUTH0_DOMAIN,process.env.CACHE_URL,m(1639));const Iy=({type:e,title:t,template_key:a})=>{var n,r,i=(0,wy.makeId)(e);switch(e){case"subspace":n={title:t,layout:{width:"number",height:"number"},root_canvas_id:"CANVAS_<UUID>",canvas_map:{},brick_map:{},animation_map:{},generator_map:{},property_bank_map:{},property_bank_calc_map:{}},r={"canvas_map.CANVAS_<UUID>.item_list":[{type:"subspace",subspace_id:"SUBSPACE_<UUID>",$note:"If not a root subspace, it can be linked to canvas in other subspace"}]};break;case"canvas":var o=oc(ic.canvas);n={title:t,item_list:[],property:{$definitions:Object.fromEntries(Object.entries(o.propTypes).map(([e,t])=>[e,{...t,description:o.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(o.eventTypes).map(([e])=>[e,{description:o.brickEventDescriptions[e]}]))}},r={property_bank_map:{[(0,wy.makeId)("property_bank")]:{title:`Canvas ID: ${t}`,type:"string",value:i,routing:"read-only",kind:"auto-generated-item-id",idType:"canvas"}}};break;case"brick":var s=oc(ic.components.Basic),p=oc(ic.brickMapping[a]);if(!p)throw new Error(`Brick ${a} not found`);var l={...p,propTypes:{...s.propTypes,...p.propTypes},brickPropDescriptions:{...s.brickPropDescriptions,...p.brickPropDescriptions},eventTypes:{...s.eventTypes,...p.eventTypes},brickEventDescriptions:{...s.brickEventDescriptions,...p.brickEventDescriptions}};n={title:t,template_key:a,property:{$definitions:Object.fromEntries(Object.entries(l.propTypes).map(([e,t])=>[e,{...t,description:l.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(l.eventTypes).map(([e])=>[e,{description:l.brickEventDescriptions[e]}]))},outlet:{$definitions:Object.fromEntries(Object.entries(l.outletTypes).map(([e])=>[e,{description:l.brickOutletDescriptions[e]}]))},state_group:{"BRICK_STATE_GROUP_<UUID>":{}}},r={canvas_map:{"CANVAS_<UUID WHICH NEED DISPLAY THIS BRICK>":{item_list:[{type:"brick",brick_id:i,frame:{x:"number",y:"number",width:"number",height:"number",standby_mode:"custom|top|left|right|bottom",standby_delay:"number",standby_easing:{default:{method:"ease",duration:"number"}}}}]}}};break;case"state_group":n={title:t,description:"State Group Description",conds:[{type:"property_bank|inner_state",key:"PROPERTY_BANK#<Data Node ID>|[current_canvas|BRICK_<OUTLET NAME>]|",method:"==|!=|>|>=|<|<=",value:"value_to_compare"}],override:{property:!1,event:!1,outlet:!1},commented:!1,break:!1,property:{},outlet:{},animation:{}};case"generator":var u=oc(ic.generatorMapping[a]);if(!u)throw new Error(`Generator ${a} not found`);n={title:t,template_key:a,property:{$definitions:Object.fromEntries(Object.entries(u.propTypes).map(([e,t])=>[e,{...t,description:u.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(u.eventTypes).map(([e])=>[e,{description:u.brickEventDescriptions[e]}]))},outlet:{$definitions:Object.fromEntries(Object.entries(u.outletTypes).map(([e])=>[e,{description:u.brickOutletDescriptions[e]}]))}};break;case"animation":n={title:t,type:"timing|decay|spring",property:"opacity|transform.translateX|transform.scale|etc",config:{$note:"Config for the animation"},compose_type:"parallel|sequence",item_list:[{animation_id:"ANIMATION_<SUB ANIMATION UUID>"}]};break;case"property_bank":n={title:t,description:"Property Bank Description",linkedFrom:"SUBSPACE_<UUID WHICH IS CROSS SUBSPACE>",type:"string|number|bool|object|array|any",kind:"color|datetime|id|media-resource-*|lottie-file-uri",unit:"grid|px|ms",routing:"read-only|default",value:"fit-to-type",event_map:{$note:`Available events: ${Object.keys(ic.propertyBank.eventTypes).join(", ")}`},local_sync:{update_mode:"all|main-only|minor-only|dont-sync"},$remote_update_additional:{$note:"Configure remote update behavior",enable_remote_update:!0,bank_type:"create|create-device-specific"}};break;case"property_bank_command":break;case"property_bank_calc":var d=(0,wy.makeId)("property_bank_command"),c=(0,wy.makeId)("property_bank_command"),m=(0,wy.makeId)("property_bank_command"),f="const { arg_name } = inputs;\n\nreturn { arg_name };";n={title:t,map:{$note:"Required, actual implementation","PROPERTY_BANK_DATA_NODE_<UUID>":{type:"data-node",properties:{},in:{change:null},out:{value:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID>",port:"value"}]},$note:"Use this to input data to the sandbox"},"PROPERTY_BANK_COMMAND_NODE_<UUID FIRST>":{type:"command-node-object",title:"Command: OBJECT_SET",properties:{command:"OBJECT_SET",args:{path:"arg_name"}},in:{obj:null,path:null,value:[{id:"PROPERTY_BANK_DATA_NODE_<UUID>",port:"value"}]},out:{result:[{id:`PROPERTY_BANK_COMMAND_NODE_<UUID NEXT> | ${d}`,port:"obj | inputs"}]}},"PROPERTY_BANK_COMMAND_NODE_<UUID SECOND>":{type:"command-node-object",title:"Command: OBJECT_SET",properties:{command:"OBJECT_SET",args:{path:"arg_name"}},in:{obj:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID PREVIOUS>",port:"result"}],path:null,value:[{id:"PROPERTY_BANK_DATA_NODE_<UUID SECOND>",port:"value"}]},out:{result:[{id:`PROPERTY_BANK_COMMAND_NODE_<UUID NEXT> | ${d}`,port:"obj | inputs"}]}},[d]:{type:"command-node-sandbox",title:"Command: SANDBOX_RUN_JAVASCRIPT",properties:{command:"SANDBOX_RUN_JAVASCRIPT",args:{code:f,enable_async:!1}},in:{code:null,inputs:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID FINAL>",port:"result"}]},out:{result:[{id:m,port:"result"},{id:c,port:"result"}]}},[m]:{type:"command-node-sandbox",title:"Command: SANDBOX_GET_ERROR",properties:{command:"SANDBOX_GET_ERROR"},in:{result:[{id:d,port:"result"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE ERROR>",port:"change"}],$note:"Set `result` as null if there is no error"}},[c]:{type:"command-node-sandbox",title:"Command: SANDBOX_GET_RETURN_VALUE",properties:{command:"SANDBOX_GET_RETURN_VALUE"},in:{result:[{id:d,port:"result"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT> | PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT> | null",port:"change"}]}},"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT>":{type:"data-node",properties:{},in:{change:[{id:c,port:"result"}]},out:{value:null},$note:"Put full result into data node"},"PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT>":{type:"command-node-object",title:"Command: OBJECT_GET",properties:{command:"OBJECT_GET",args:{path:"obj_key"}},in:{obj:[{id:c,port:"obj"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>",port:"change"}]},$note:"Parse result object into data node"},"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>":{type:"data-node",properties:{},in:{change:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT>",port:"result"}]},out:{value:null},$note:"Put partial result into data node"}},editor_info:{},type:"script",script_config:{title:t,enable_async:!1,inputs:{"PROPERTY_BANK_DATA_NODE_<UUID>":"arg_name"},disabled_triggers:{},error:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE ERROR> | null",output:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT> | null",outputs:{obj_key:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>"},code:f,$note:"Required, info for GUI editor"}}}return ad({id:i,example:n,extraInfo:r})};function Cy(e,t){var a,n,r,i,o,s,p,l,u,d,c,m,f,h="user"===t.tokenType,y=((e,t=null)=>({name:a,description:n,inputSchema:r,permission:i},o)=>{cc(t,i)&&e.tool(a,n,r,o)})(e,t),_=e=>({...e,...h?{workspace_id:sa().describe("Workspace ID")}:{}}),E=t.client,T=h?function(e){var t=e.endpoint,a=e.accessToken;if(!t)throw new Error("Media API endpoint is required");if(!a)throw new Error("Access token is required");return Oy({endpoint:t,accessToken:a,enableSubscription:!1,enableRetry:!0})}({endpoint:Sy.media,accessToken:t.token}):E;h&&e.tool("list_workspaces","List all workspaces",{},O(function*(){return ad(yield E.workspaces())})),y({name:"get_workspace_overview",description:"Get comprehensive overview of the BRICKS workspace including stats and summary",inputSchema:_({}),permission:"info"},function(){var e=O(function*({workspace_id:e}){var t=yield Promise.all([E.workspace({id:e}),E.applications({workspaceId:e,paginate:{limit:50,offset:0}}),E.modules({workspaceId:e,paginate:{limit:50,offset:0}}),E.devices({workspaceId:e,paginate:{limit:50,offset:0}}),h?T.mediaWorkspace({workspaceId:e}).catch(()=>null):T.mediaWorkspace().catch(()=>null),h?T.mediaBoxes({workspaceId:e}).catch(()=>[]):T.mediaBoxes().catch(()=>[])]),a=de(t,6),n=a[0],r=a[1],i=a[2],o=a[3],s=a[4],p=a[5];if(!n)throw new Error("Authentication failed, please check your token");return ad({workspace:n,stats:{applications:r?.length??"No permission",modules:i?.length??"No permission",devices:o?.length??"No permission",running_apps:r?.filter(e=>e.status?.running).length??"No permission",media_boxes:p?.length??"No permission",media_enabled:!!s,notes:"Note: The stats are based on the first 50 applications, modules, and devices in the workspace."},recent_activity:{latest_apps:r?.slice(0,5).map(e=>({id:e._id,name:e.name,status:e.status?.running?"running":"stopped",last_update:e.last_modify_datetime}))||[]},media_info:s?{workspace_id:s.id,name:s.name,size_used:s.size,size_limit:s.sizeLimit,boxes:p?.slice(0,5).map(e=>({id:e.id,name:e.name,size:e.size,description:e.description}))||[]}:{enabled:!1,note:"Media workspace is not enabled for this workspace"}})});return function(t){return e.apply(this,arguments)}}()),y({name:"get_applications",description:"List all applications in the workspace",inputSchema:_({limit:pa().describe("Maximum number of applications to return").optional().default(50),offset:pa().describe("Number of applications to skip").optional().default(0)}),permission:"query_application"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.applications({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_application",description:"Get detailed info and config of a specific application",inputSchema:_({id:sa().describe("Application ID")}),permission:"query_application"},function(){var e=O(function*({workspace_id:e,id:t}){return ad(yield E.application({workspaceId:e,id:t}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_modules",description:"List all modules in the workspace",inputSchema:_({limit:pa().describe("Maximum number of modules to return").optional().default(50),offset:pa().describe("Number of modules to skip").optional().default(0)}),permission:"query_module"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.modules({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_module",description:"Get detailed info and config of a specific module",inputSchema:_({id:sa().describe("Module ID")}),permission:"query_module"},function(){var e=O(function*({workspace_id:e,id:t}){return ad(yield E.module({workspaceId:e,id:t}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_module_info",description:"Update a specific module info",inputSchema:_({id:sa().describe("Module ID"),name:sa().describe("Module name"),description:sa().describe("Module description")}),permission:"update_module"},function(){var e=O(function*({workspace_id:e,id:t,name:a,description:n}){return ad(yield E.updateModule({workspaceId:e,id:t,name:a,description:n}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_module_config",description:"Update a specific module configuration",inputSchema:_({id:sa().describe("Module ID"),config:ua({}).passthrough().describe("New configuration object, see file://docs/config-schema.md for schema reference")}),permission:"update_module"},function(){var e=O(function*({workspace_id:e,id:t,config:a}){var n=yield nc(a);if(!n.valid)throw new Error(`Config validation failed: ${n.errors.join(", ")}`);return ad(yield E.updateModule({workspaceId:e,id:t,config:JSON.stringify(a),validateConfig:!0}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_devices",description:"List all devices in the workspace",inputSchema:_({limit:pa().describe("Maximum number of devices to return").optional().default(50),offset:pa().describe("Number of devices to skip").optional().default(0)}),permission:"query_device"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.devices({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"create_application",description:"Create a new BRICKS application with default grid layout",inputSchema:_({name:sa().describe("Application name"),description:sa().describe("Application description").optional(),grid_width:pa().describe("Grid width in units").optional().default(96),grid_height:pa().describe("Grid height in units").optional().default(54)}),permission:"create_application"},function(){var e=O(function*({workspace_id:e,name:t,description:a,grid_width:n,grid_height:r}){return ad(yield E.createApplication({workspaceId:e,name:t,description:a,gridWidth:n,gridHeight:r}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_application_info",description:"Update application info",inputSchema:{id:sa().describe("Application ID"),name:sa().describe("Application name"),description:sa().describe("Application description")},permission:"update_application"},function(){var e=O(function*({id:e,name:t,description:a}){return ad(yield E.updateApplication({id:e,name:t,description:a}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_application_config",description:"Update application configuration with validation",inputSchema:{id:sa().describe("Application ID"),config:ua({}).passthrough().describe("New application configuration. Please read `getting-started` for BRICKS concepts before changing")},permission:"update_application"},function(){var e=O(function*({id:e,config:t}){var a=yield nc(t);if(!a.valid)throw new Error(`Config validation failed: ${a.errors.join(", ")}`);return ad(yield E.updateApplication({id:e,config:JSON.stringify(t)}))});return function(t){return e.apply(this,arguments)}}()),y({name:"bind_application",description:"Bind application to device with viewport configuration",inputSchema:{app_id:sa().describe("Application ID"),viewports:la(ua({device_id:sa().describe("Device ID"),x:pa().describe("X coordinate"),y:pa().describe("Y coordinate"),width:pa().describe("Width"),height:pa().describe("Height"),rotate:pa().describe("Rotation"),rotateType:sa().describe("Rotation type")})).describe("Viewport configuration")},permission:"bind_application"},(a=O(function*({app_id:e,viewports:t}){return ad(yield E.bindApplication({id:e,bind_devices:t.map(e=>e.device_id),device_frames:t.reduce((e,t)=>({...e,[t.device_id]:{x:t.x,y:t.y,width:t.width,height:t.height,rotate:t.rotate,rotateType:t.rotateType}}),{})}))}),function(e){return a.apply(this,arguments)})),y({name:"unbind_application",description:"Unbind application from device",inputSchema:{app_id:sa().describe("Application ID"),device_id:sa().describe("Device ID")},permission:"bind_application"},(n=O(function*({app_id:e,device_id:t}){return ad(yield E.bindApplication({id:e,unbindDevices:[t]}))}),function(e){return n.apply(this,arguments)})),h&&y({name:"list_media_workspaces",description:"List all media workspaces",inputSchema:{},permission:"query_media_flow"},O(function*(){return ad(yield T.mediaWorkspaces())})),y({name:"get_media_workspace",description:"Get media workspace information and status",inputSchema:_({}),permission:"query_media_flow"},(r=O(function*({workspace_id:e}){return ad(yield T.mediaWorkspace({workspaceId:e}))}),function(e){return r.apply(this,arguments)})),y({name:"list_media_boxes",description:"List all media boxes in the workspace",inputSchema:_({}),permission:"query_media_flow"},(i=O(function*({workspace_id:e}){return ad(yield T.mediaBoxes({workspaceId:e}))}),function(e){return i.apply(this,arguments)})),y({name:"get_media_box",description:"Get detailed information about a specific media box",inputSchema:{box_id:sa().describe("Media box ID")},permission:"query_media_flow"},(o=O(function*({box_id:e}){return ad(yield T.mediaBox({boxId:e}))}),function(e){return o.apply(this,arguments)})),y({name:"list_media_files",description:"List media files in a specific box with filtering options",inputSchema:{box_id:sa().describe("Media box ID"),include_types:la(sa()).optional().describe('Filter by file types (e.g., ["image", "video", "audio"])'),user_tags:la(sa()).optional().describe("Filter by user tags"),limit:pa().optional().default(50).describe("Maximum number of files to return"),offset:pa().optional().default(0).describe("Number of files to skip")},permission:"query_media_flow"},(s=O(function*({box_id:e,include_types:t,user_tags:a,limit:n,offset:r}){return ad(yield T.mediaFiles({boxId:e,includeTypes:t,userTags:a,limit:n,offset:r}))}),function(e){return s.apply(this,arguments)})),y({name:"get_media_file_meta",description:"Get detailed information about a specific media file",inputSchema:{file_id:sa().describe("Media file ID")},permission:"query_media_flow"},(p=O(function*({file_id:e}){return ad(yield T.mediaFile({fileId:e}))}),function(e){return p.apply(this,arguments)})),y({name:"media_box_upload",description:"Upload a file to a media box from URL or base64 data",inputSchema:{box_id:sa().describe("Target media box ID"),name:sa().describe("File name"),description:sa().optional().default("").describe("File description"),file_type:da(["image","video","audio","file"]).describe("File type"),source_url:sa().optional().describe("URL to download the file from"),base64_data:sa().optional().describe("Base64 encoded file data"),user_tags:la(sa()).optional().default([]).describe("User-defined tags for the file")},permission:"write_media_flow"},(l=O(function*({box_id:e,name:t,description:a,source_url:n,base64_data:r,file_type:i,user_tags:o}){if(!n&&!r)throw new Error("Either source_url or base64_data must be provided");if(n&&r)throw new Error("Provide either source_url OR base64_data, not both");var s=n?null:"application/octet-stream",p=n?yield(0,nd.Ay)(n,{agent:yd(n)}).then(e=>(s=e.headers.get("content-type"),e.blob())):new Blob([td.Buffer.from(r,"base64")],{type:s}),l=yield T.requestFileUpload({name:t,description:a,boxId:e,fileType:h?i.toUpperCase():i,contentType:s,userTags:o,meta:{}}),u=JSON.parse(l?.meta.uploadInfo),d=new FormData;d.append("file",p),d.append("Content-Type",s),d.append("AWSAccessKeyId",u.AWSAccessKeyId),d.append("Signature",u.Signature),d.append("Policy",u.Policy),d.append("acl",u.acl),d.append("key",u.key);var c=yield(0,nd.Ay)(u.url,{method:"POST",body:d}).then(e=>e.ok).catch(()=>!1);return ad({file_id:l.id,upload_success:c,upload_info:{content_type:s,file_type:i,source_type:n?"url":"base64",processing_note:"File will be processed automatically. Use get_media_file to check processing status."}})}),function(e){return l.apply(this,arguments)})),y({name:"update_media_file_meta",description:"Update media file information",inputSchema:{file_id:sa().describe("Media file ID"),name:sa().optional().describe("New file name"),description:sa().optional().describe("New file description"),user_tags:la(sa()).optional().describe("New user tags")},permission:"write_media_flow"},(u=O(function*({file_id:e,name:t,description:a,user_tags:n}){return ad(yield T.updateMediaFile({fileId:e,name:t,description:a,userTags:n,requestUploadAgain:!1}))}),function(e){return u.apply(this,arguments)})),y({name:"copy_media_files",description:"Copy media files from one box to another",inputSchema:{from_box_id:sa().describe("Source media box ID"),to_box_id:sa().describe("Target media box ID"),file_ids:la(sa()).describe("Array of media file IDs to copy")},permission:"write_media_flow"},(d=O(function*({from_box_id:e,to_box_id:t,file_ids:a}){return ad(yield T.copyMediaFiles({fromBoxId:e,toBoxId:t,list:a}))}),function(e){return d.apply(this,arguments)})),y({name:"delete_media_files",description:"Delete specific media files from a box",inputSchema:{box_id:sa().describe("Media box ID"),file_ids:la(sa()).describe("Array of media file IDs to delete")},permission:"write_media_flow"},(c=O(function*({box_id:e,file_ids:t}){return ad(yield T.deleteMediaFiles({boxId:e,list:t}))}),function(e){return c.apply(this,arguments)})),y({name:"cleanup_media_box",description:"Delete all files in a media box, optionally filtered by type",inputSchema:{box_id:sa().describe("Media box ID"),include_types:la(sa()).optional().describe('Only delete files of these types (e.g., ["image", "video"])')},permission:"write_media_flow"},(m=O(function*({box_id:e,include_types:t}){if("deleteMediaBoxFiles"in T)return ad(yield T.deleteMediaBoxFiles({boxId:e,includeTypes:t}));var a=yield T.mediaFiles({boxId:e,includeTypes:t});return ad(yield T.deleteMediaFiles({boxId:e,list:a.map(e=>e.id)}))}),function(e){return m.apply(this,arguments)})),e.tool("calculate_grid_layout","Calculate grid layout and pixel conversions for different device resolutions",{device_width:pa().describe("Device width in pixels"),device_height:pa().describe("Device height in pixels"),app_grid_width:pa().describe("Application grid width").optional().default(96),app_grid_height:pa().describe("Application grid height").optional().default(54)},(f=O(function*({device_width:e,device_height:t,app_grid_width:a,app_grid_height:n}){var r,i,o={deviceBrickWidth:(r=e)/(i=r/a),deviceBrickHeight:t/i,deviceBrickUnit:i},s=function(e,t,a=96){var n=e/a;return t>e&&(n=t/a),{deviceBrickWidth:Math.round(e/n),deviceBrickHeight:Math.round(t/n),deviceBrickUnit:n}}(e,t,a);return ad({device_resolution:{width:e,height:t,aspect_ratio:(e/t).toFixed(2)},current_grid:{width:a,height:n,unit_size_px:o.deviceBrickUnit.toFixed(2),total_pixels:{width:o.deviceBrickWidth.toFixed(2),height:o.deviceBrickHeight.toFixed(2)}},recommended_grid:{width:s.deviceBrickWidth,height:s.deviceBrickHeight,unit_size_px:s.deviceBrickUnit.toFixed(2),note:"Optimized for device aspect ratio"}})}),function(e){return f.apply(this,arguments)})),e.tool("create_item","Use this tool to create new item that you can put in application configuration",{type:da(["subspace","canvas","brick","generator","property_bank","property_bank_calc","property_bank_command","animation","state_group","automation_map"]).describe("Item type"),title:sa().describe("Item title"),template_key:sa().optional().describe("Template key for brick or generator")},Iy),e.tool("getting_started","Get documentation content for getting started",{},O(function*(){return ad(dc)}))}var Dy="2.24.0-beta.18";function Py(){return Py=O(function*(e={}){var t=e.token||process.env.BRICKS_API_TOKEN;if(!t)throw console.error("Error: API token is required"),console.error("Please provide a token via options or set BRICKS_API_TOKEN environment variable"),new Error("API token is required");var a=Zu({queryStringParameters:{token:t}});if(!a.success)throw console.error("Error: Invalid BRICKS_API_TOKEN"),console.error(a.message),new Error("Invalid BRICKS_API_TOKEN");var n,r=new Mu({name:Ay,version:Dy}),i={...a,client:Ny(Sy.bricks,a.token,a.tokenType)};(n=r).prompt("getting-started","Getting started with BRICKS",{},O(function*(){return{messages:[{role:"user",content:{type:"text",text:'Welcome to BRICKS — start here.\n\nBefore doing any complex work (application design, deployments, etc.),\nalways consult the official docs rather than guessing.\n\nIMPORTANT: BRICKS users interact through a GUI editor, not raw config files.\nNever show users JSON config details, schema fields, or technical implementation.\nFocus on user-friendly descriptions of what the app will do and how it will look.\n\nGolden rules for working with BRICKS:\n1) Read before you act\n - Open these resources first, then proceed:\n - `getting-started` — overview & architecture\n - `config-schema` — canonical schema for apps, subspaces, bricks, generators, etc.\n - `components-index` — available bricks/generators\n2) Source of truth\n - Rely on the docs above; do not invent fields not present in the schema\n3) No guessing\n - If names, constraints, or device details are missing, ask to fetch them first\n4) Plan then execute\n - Propose a clear step-by-step plan and wait for approval before writing or mutating data\n5) User-friendly communication\n - Describe features in terms of what users see and do, not technical config\n - Use visual/functional language: "text display", "button", "screen transition"\n - Avoid exposing JSON, IDs, or schema details to end users\n\nBRICKS essentials:\n- Applications: interactive digital signage experiences\n- Devices: deployment targets (screens/players)\n- Modules: Reusable module across applications\n- Grid system: default 96×54; 1 unit = device_width/96 (e.g., 20px at 1920×1080)\n- Key primitives: Subspaces, Canvas, Bricks, Generators, Property Banks (Data)\n\nQuick actions:\n- "Create a new application" → use the `create-application` prompt\n- "Deploy an application to a device" → use the `deploy-to-device` prompt\n\nTry asking:\n- "Draft a plan to create an app with a text display and deploy it; ask any missing questions first"'}}]}})),n.prompt("create-application","Create a new BRICKS application with guided setup",{app_name:sa().describe("Name for the new application"),description:sa().describe("Short description for the new application").optional()},function(){var e=O(function*(e){var t=e?.app_name||"New Application",a=e?.description||"";return{messages:[{role:"user",content:{type:"text",text:`Help me create a new BRICKS application called "${t}".\n\n${a?`Goal: ${a}`:""}\n\nIMPORTANT: Users see a visual GUI editor, not raw config. Describe features in user-friendly terms:\n- "text display" not "BRICK_TEXT"\n- "image" not "BRICK_IMAGE"\n- "canvas name" not "CANVAS_xxx"\n- "data storage" not "PROPERTY_BANK"\n- Focus on what users see and do, not technical implementation\n\nHow we'll proceed (no guessing, schema-first):\n1) Confirm intent\n - Restate objectives and success criteria in 1–3 bullets\n2) Consult docs (as needed)\n - getting-started, config-schema, components-index\n - Ensure proposed fields exist in the schema\n3) Ask missing questions before changes\n - Target device(s) and resolution(s)\n - Layout needs (pages/screens), content types, data sources\n - Localization, scheduling, or interaction needs\n4) Propose a minimal viable design (After confirming intent)\n - App structure: screens → visual elements\n - Initial component selection with rationale\n - Grid usage: default 96×54 (≈20px at 1920×1080)\n5) Produce a schema-valid skeleton (no side effects yet)\n - Include only fields defined by config-schema\n - Use clear placeholders for text/assets/URLs/ids\n\nWhat I'll produce first:\n- Short recap of requirements\n- Clarifying questions (only what's necessary)\n- High-level architecture plan\n- Minimal config skeleton that validates against the schema`}}]}});return function(t){return e.apply(this,arguments)}}()),function(e){e.resource("getting-started-docs","file://docs/getting-started.md",{mimeType:"text/markdown",title:"Getting Started with BRICKS",description:"Comprehensive guide to BRICKS architecture, concepts, and development workflow"},O(function*(){return ad(ed,{uri:"file://docs/getting-started.md",mimeType:"text/markdown"})}))}(r),Cy(r,i);var o=new Wu;try{yield r.connect(o),console.error("BRICKS MCP Server running on STDIO"),console.error(`Server: ${Ay} v${Dy}`),console.error(`Token Type: ${a.tokenType}`),console.error(`Permissions: ${a.tokenInfo.permissions.join(", ")}`),console.error("Ready to accept requests...")}catch(e){throw console.error("Failed to start MCP server:",e),e}}),Py.apply(this,arguments)}var jy=new j("mcp").description("MCP server management");jy.command("start").description("Start the BRICKS MCP server in STDIO mode").option("-t, --token <token>","API token (overrides saved token)").action(function(){var e=O(function*(e){var t=(0,G.getCurrentProfile)(),a=e.token||(0,G.getToken)(t);a||(console.error(M.Ay.red("Error: No API token found.")),console.error(M.Ay.gray("Please login first with: bricks auth login <passcode>")),console.error(M.Ay.gray("Or provide a token with: bricks mcp start --token <token>")),process.exit(1));try{yield function(){return Py.apply(this,arguments)}({token:a})}catch(e){console.error(M.Ay.red(`Failed to start MCP server: ${e.message}`)),process.exit(1)}});return function(t){return e.apply(this,arguments)}}());var ky=new j("devtools").description("DevTools server discovery and connection");ky.command("scan").description("Scan LAN for DevTools servers via UDP + HTTP").option("-t, --timeout <ms>","Scan timeout in milliseconds","3000").option("-j, --json","Output as JSON").option("--verify","Verify each discovered server via HTTP").option("--udp-only","Skip HTTP subnet probe (UDP only)").option("-p, --port <port>","Port for HTTP probe","19851").action(function(){var e=O(function*(e){var t=(yield Promise.resolve().then(m.bind(m,9790))).default,a=yield m.e(44).then(m.bind(m,2044)),n=a.discoverDevToolsServers,r=a.verifyDevToolsServer,i=a.httpProbeSubnet,o=yield Promise.resolve().then(m.bind(m,8765)),s=o.getCurrentProfile,p=o.getTokenInfo,l=parseInt(e.timeout,10),u=t(`Scanning for DevTools servers (${l}ms)...`).start();try{var d=n({timeout:l}),c=e.udpOnly?Promise.resolve([]):(u.text="Scanning via UDP + HTTP probe...",i({port:parseInt(e.port,10)})),f=yield Promise.all([d,c]),h=de(f,2),y=h[0],_=h[1],E=[...y,..._],T=new Map;for(var g of E){var v=g.deviceId||`${g.address}:${g.port}`,R=T.get(v);if(R)for(var b of(R.addresses.includes(g.address)||R.addresses.push(g.address),"127.0.0.1"===R.address&&"127.0.0.1"!==g.address&&(R.address=g.address),g.protocols||[]))R.protocols?.includes(b)||R.protocols?.push(b);else T.set(v,{...g,addresses:[g.address]})}var N=[...T.values()];if(0===N.length)return void u.info("No DevTools servers found on the network.");if(e.verify){u.text=`Verifying ${N.length} server(s)...`;var A=yield Promise.all(N.map(function(){var e=O(function*(e){var t=yield r(e.address,e.port);return{...e,verified:!!t}});return function(t){return e.apply(this,arguments)}}()));N.splice(0,N.length,...A)}if(u.stop(),e.json)return void console.log(JSON.stringify(N,null,2));var S=p(s()),w=S?.workspaceId||null;console.log(M.Ay.bold(`\nFound ${N.length} DevTools server(s)`)),console.log("─".repeat(80));var I=function*(e){var t=!1===e.verified?M.Ay.red("unverified"):M.Ay.green("online"),a=e.hasPasscode?M.Ay.yellow("passcode"):M.Ay.gray("open"),n=(e.protocols||[]).map(e=>M.Ay.cyan(e)).join(", "),r=e.workspaceId&&w&&e.workspaceId===w,i=e.addresses||[e.address],o=i.filter(t=>t!==e.address),s=o.length>0?`${e.address}:${e.port} +${o.length} more`:`${e.address}:${e.port}`;console.log(` ${M.Ay.bold(e.name||"Unknown")} ${M.Ay.gray(`(${s})`)} [${t}]`),o.length>0&&console.log(` Addresses: ${i.map(e=>M.Ay.gray(e)).join(", ")}`);var p=` Protocols: ${n||M.Ay.gray("none")} Auth: ${a}`;if(e.deviceId&&(p+=` Device: ${M.Ay.gray(e.deviceId)}`),console.log(p),e.workspaceId){var l=r?M.Ay.green(`${e.workspaceId} (current profile)`):M.Ay.gray(e.workspaceId);console.log(` Workspace: ${l}`)}};for(var C of N)yield*I(C);console.log("─".repeat(80)),console.log(M.Ay.gray(`\nConnect via: devtools://devtools/bundled/js_app.html?ws=<address>:${N[0]?.port||19851}/ws?p=<passcode>`)),process.exit(0)}catch(e){u.fail(`Scan failed: ${e.message}`),process.exit(1)}});return function(t){return e.apply(this,arguments)}}()),ky.command("open <address>").description("Show connection URLs for a DevTools server").option("-p, --port <port>","Server port","19851").option("--verify","Verify server is reachable first").action(function(){var e=O(function*(e,t){var a=parseInt(t.port,10),n=`${e}:${a}`;if(t.verify){var r=(yield Promise.resolve().then(m.bind(m,9790))).default,i=(yield m.e(44).then(m.bind(m,2044))).verifyDevToolsServer,o=r(`Verifying ${n}...`).start(),s=yield i(e,a);s||(o.fail(`Could not reach DevTools server at ${n}`),process.exit(1)),o.succeed(`${s.name||"DevTools"} is reachable`),console.log()}console.log(M.Ay.bold("Connection URLs")),console.log("─".repeat(60)),console.log(` Web UI: ${M.Ay.cyan(`http://${n}`)}`),console.log(` CDP: ${M.Ay.cyan(`devtools://devtools/bundled/js_app.html?ws=${n}/ws?p=<passcode>`)}`),console.log(` MCP: ${M.Ay.cyan(`http://${n}/mcp`)}`),console.log(` MCP SSE: ${M.Ay.cyan(`http://${n}/sse`)}`),console.log(` Info: ${M.Ay.cyan(`http://${n}/devtools/info`)}`),console.log("─".repeat(60)),console.log(),console.log(M.Ay.bold("Authorization")),console.log(" MCP and MCP SSE require a Bearer token header with the device passcode:"),console.log(` ${M.Ay.gray("Authorization: Bearer <passcode>")}`)});return function(t,a){return e.apply(this,arguments)}}());var xy=function(){var e=O(function*(){var e=process.argv.findIndex(e=>"--auth-profile"===e||"-ap"===e);if(-1!==e&&process.argv[e+1]&&((0,G.setProfileOverride)(process.argv[e+1]),process.argv.splice(e,2)),A.name("bricks").description("BRICKS CLI - Command-line interface for BRICKS Workspace API").version("2.24.0-beta.18").enablePositionalOptions(),A.addCommand(H),A.addCommand(ee),A.addCommand(pe),A.addCommand(ue),A.addCommand(he),A.addCommand(be),A.addCommand(De),A.addCommand(jy),A.addCommand(ky),A.command("interactive").alias("i").description("Start interactive mode with Ink UI").action(O(function*(){try{(0,(yield m.e(612).then(m.bind(m,9612))).runInteractiveMode)()}catch(e){console.error(M.Ay.red(`Failed to start interactive mode: ${e.message}`)),process.exit(1)}})),A.command("workspace").alias("ws").description("Show current workspace information").option("-j, --json","Output as JSON").action(function(){var e=O(function*(e){var t=yield Promise.resolve().then(m.bind(m,8765)),a=t.getToken,n=t.getBaseUrl,r=t.getCurrentProfile,i=(yield Promise.resolve().then(m.bind(m,700))).createClient,o=(yield Promise.resolve().then(m.bind(m,9790))).default,s=a(r());s||(console.error(M.Ay.red("Not logged in. Use `bricks auth login` first.")),process.exit(1));var p=o("Fetching workspace info...").start();try{var l=i(n(),s),u=yield l.workspace();if(p.stop(),e.json)return void console.log(JSON.stringify(u,null,2));console.log(M.Ay.bold("\nWorkspace Information")),console.log("─".repeat(60)),console.log(`Name: ${M.Ay.green(u.name)}`),console.log(`ID: ${M.Ay.gray(u._id)}`),console.log(`Description: ${u.description||M.Ay.gray("N/A")}`),console.log(`\n${M.Ay.bold("Data")}`),console.log(`Remote Update: ${u.bank?.enable_remote_update?M.Ay.green("Enabled"):M.Ay.gray("Disabled")}`),console.log(`Spacename: ${u.bank?.spacename||M.Ay.gray("N/A")}`),console.log("─".repeat(60))}catch(e){p.fail(`Failed to get workspace: ${e.message}`),process.exit(1)}});return function(t){return e.apply(this,arguments)}}()),A.on("--help",()=>{console.log(""),console.log(M.Ay.bold("Examples:")),console.log(""),console.log(M.Ay.gray(" # Login with a one-time passcode (recommended)")),console.log(" $ bricks auth login <passcode>"),console.log(""),console.log(M.Ay.gray(" # List all devices")),console.log(" $ bricks device list"),console.log(""),console.log(M.Ay.gray(" # Monitor devices in real-time")),console.log(" $ bricks device monitor"),console.log(""),console.log(M.Ay.gray(" # Control a device")),console.log(" $ bricks device refresh <device-id>"),console.log(" $ bricks device control <device-id> clear-cache"),console.log(""),console.log(M.Ay.gray(" # Bind a new device")),console.log(' $ bricks device bind <passcode> -n "My Device"'),console.log(""),console.log(M.Ay.gray(" # List applications")),console.log(" $ bricks app list"),console.log(""),console.log(M.Ay.gray(" # Start interactive mode")),console.log(" $ bricks interactive"),console.log(""),console.log(M.Ay.gray(" # Change API endpoint")),console.log(" $ bricks config endpoint beta"),console.log(""),console.log(M.Ay.gray("Get workspace token from BRICKS Controller:")),console.log(M.Ay.cyan(" https://control.bricks.tools")),console.log(M.Ay.gray(" Go to Workspace Settings > API Token"))}),0===process.argv.slice(2).length)try{return void(0,(yield m.e(612).then(m.bind(m,9612))).runInteractiveMode)()}catch(e){console.error(M.Ay.red(`Failed to start interactive mode: ${e.message}`)),process.exit(1)}yield A.parseAsync(process.argv)});return function(){return e.apply(this,arguments)}}();const Ly=xy;export{Ly as default,xy as run};
3144
+ `,vy={query:"query",mutation:"mutate"},Ry=(e,t,a)=>([n,r])=>{if(e[n])throw new Error(`Overwriting client.${n}`);e[n]=async(i,o={})=>{let s,p;const l={[t]:r,variables:i,...o};if(a&&(l.variables={...a,...l.variables}),o.readQuery)s=e.readQuery(l);else if(o.writeQuery)e.writeQuery({...l,data:o.writeQuery});else{const a=await e[vy[t]](l);({data:s,errors:p}=a||{})}if(p)throw new Error(p.map(e=>e.message).join("\n"));return s?s[n]:null}},by=e=>({data:t,errors:a})=>{const n=((e,t)=>e?.length?new Error(e.map(e=>e.message).join("\n")):t?new Error(t):null)(a,!t?.mediaBoxChanged&&"Missing mediaBoxChanged payload");return n?e(n):e(null,t.mediaBoxChanged)},Oy=(e={})=>{const t=(({endpoint:e="http://localhost:3002",accessToken:t,boxId:a,passcode:n,enableSubscription:r=!0,enableRetry:i=!0,subscriptionOnConnectionOrError:o,onNetworkError:s}={})=>{const p=a&&n;let l=`${e}/api/graphql`;return p&&(l=`${e}/api/graphql_with_passcode`),Kh({endpointURL:l,subscriptionEndpointURL:l.replace("http:","ws:"),accessToken:t,enableSubscription:!p&&r,enableRetry:i,subscriptionOnConnectionOrError:o,onNetworkError:s})})(e);if(e.boxId&&e.passcode){t.type="passcode",t.queries=R,t.mutations=b;const a={boxId:e.boxId,passcode:e.passcode};Object.entries(R).forEach(Ry(t,"query",a)),Object.entries(b).forEach(Ry(t,"mutation",a)),t.listenBoxChanged=(e,n)=>t.subscribe({query:gy,variables:{...a,...e}}).subscribe({next:by(n),error(e){n(e)}})}else t.accessToken=e.accessToken,t.type="token",t.queries=g,t.mutations=v,Object.entries(g).forEach(Ry(t,"query")),Object.entries(v).forEach(Ry(t,"mutation")),t.listenBoxChanged=(e,a)=>t.subscribe({query:cy,variables:e}).subscribe({next:by(a),error(e){a(e)}});return t};function Ny(e,t,a){switch(a){case"user":return new yf(e,t);case"workspace":return new ah(e,t);default:throw new Error(`Invalid token type: ${a}.`)}}process.env.STAGE,process.env.URL_BASE;var Ay="bricks-mcp",Sy={bricks:process.env.BRICKS_API_SERVER||"https://display-beta.bricks.tools",media:process.env.MEDIA_API_SERVER||"https://media-beta.bricks.tools"},wy=(process.env.AUTH0_DOMAIN,process.env.CACHE_URL,m(1639));const Iy=({type:e,title:t,template_key:a})=>{var n,r,i=(0,wy.makeId)(e);switch(e){case"subspace":n={title:t,layout:{width:"number",height:"number"},root_canvas_id:"CANVAS_<UUID>",canvas_map:{},brick_map:{},animation_map:{},generator_map:{},property_bank_map:{},property_bank_calc_map:{}},r={"canvas_map.CANVAS_<UUID>.item_list":[{type:"subspace",subspace_id:"SUBSPACE_<UUID>",$note:"If not a root subspace, it can be linked to canvas in other subspace"}]};break;case"canvas":var o=oc(ic.canvas);n={title:t,item_list:[],property:{$definitions:Object.fromEntries(Object.entries(o.propTypes).map(([e,t])=>[e,{...t,description:o.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(o.eventTypes).map(([e])=>[e,{description:o.brickEventDescriptions[e]}]))}},r={property_bank_map:{[(0,wy.makeId)("property_bank")]:{title:`Canvas ID: ${t}`,type:"string",value:i,routing:"read-only",kind:"auto-generated-item-id",idType:"canvas"}}};break;case"brick":var s=oc(ic.components.Basic),p=oc(ic.brickMapping[a]);if(!p)throw new Error(`Brick ${a} not found`);var l={...p,propTypes:{...s.propTypes,...p.propTypes},brickPropDescriptions:{...s.brickPropDescriptions,...p.brickPropDescriptions},eventTypes:{...s.eventTypes,...p.eventTypes},brickEventDescriptions:{...s.brickEventDescriptions,...p.brickEventDescriptions}};n={title:t,template_key:a,property:{$definitions:Object.fromEntries(Object.entries(l.propTypes).map(([e,t])=>[e,{...t,description:l.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(l.eventTypes).map(([e])=>[e,{description:l.brickEventDescriptions[e]}]))},outlet:{$definitions:Object.fromEntries(Object.entries(l.outletTypes).map(([e])=>[e,{description:l.brickOutletDescriptions[e]}]))},state_group:{"BRICK_STATE_GROUP_<UUID>":{}}},r={canvas_map:{"CANVAS_<UUID WHICH NEED DISPLAY THIS BRICK>":{item_list:[{type:"brick",brick_id:i,frame:{x:"number",y:"number",width:"number",height:"number",standby_mode:"custom|top|left|right|bottom",standby_delay:"number",standby_easing:{default:{method:"ease",duration:"number"}}}}]}}};break;case"state_group":n={title:t,description:"State Group Description",conds:[{type:"property_bank|inner_state",key:"PROPERTY_BANK#<Data Node ID>|[current_canvas|BRICK_<OUTLET NAME>]|",method:"==|!=|>|>=|<|<=",value:"value_to_compare"}],override:{property:!1,event:!1,outlet:!1},commented:!1,break:!1,property:{},outlet:{},animation:{}};case"generator":var u=oc(ic.generatorMapping[a]);if(!u)throw new Error(`Generator ${a} not found`);n={title:t,template_key:a,property:{$definitions:Object.fromEntries(Object.entries(u.propTypes).map(([e,t])=>[e,{...t,description:u.brickPropDescriptions[e]}]))},event_map:{$definitions:Object.fromEntries(Object.entries(u.eventTypes).map(([e])=>[e,{description:u.brickEventDescriptions[e]}]))},outlet:{$definitions:Object.fromEntries(Object.entries(u.outletTypes).map(([e])=>[e,{description:u.brickOutletDescriptions[e]}]))}};break;case"animation":n={title:t,type:"timing|decay|spring",property:"opacity|transform.translateX|transform.scale|etc",config:{$note:"Config for the animation"},compose_type:"parallel|sequence",item_list:[{animation_id:"ANIMATION_<SUB ANIMATION UUID>"}]};break;case"property_bank":n={title:t,description:"Property Bank Description",linkedFrom:"SUBSPACE_<UUID WHICH IS CROSS SUBSPACE>",type:"string|number|bool|object|array|any",kind:"color|datetime|id|media-resource-*|lottie-file-uri",unit:"grid|px|ms",routing:"read-only|default",value:"fit-to-type",event_map:{$note:`Available events: ${Object.keys(ic.propertyBank.eventTypes).join(", ")}`},local_sync:{update_mode:"all|main-only|minor-only|dont-sync"},$remote_update_additional:{$note:"Configure remote update behavior",enable_remote_update:!0,bank_type:"create|create-device-specific"}};break;case"property_bank_command":break;case"property_bank_calc":var d=(0,wy.makeId)("property_bank_command"),c=(0,wy.makeId)("property_bank_command"),m=(0,wy.makeId)("property_bank_command"),f="const { arg_name } = inputs;\n\nreturn { arg_name };";n={title:t,map:{$note:"Required, actual implementation","PROPERTY_BANK_DATA_NODE_<UUID>":{type:"data-node",properties:{},in:{change:null},out:{value:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID>",port:"value"}]},$note:"Use this to input data to the sandbox"},"PROPERTY_BANK_COMMAND_NODE_<UUID FIRST>":{type:"command-node-object",title:"Command: OBJECT_SET",properties:{command:"OBJECT_SET",args:{path:"arg_name"}},in:{obj:null,path:null,value:[{id:"PROPERTY_BANK_DATA_NODE_<UUID>",port:"value"}]},out:{result:[{id:`PROPERTY_BANK_COMMAND_NODE_<UUID NEXT> | ${d}`,port:"obj | inputs"}]}},"PROPERTY_BANK_COMMAND_NODE_<UUID SECOND>":{type:"command-node-object",title:"Command: OBJECT_SET",properties:{command:"OBJECT_SET",args:{path:"arg_name"}},in:{obj:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID PREVIOUS>",port:"result"}],path:null,value:[{id:"PROPERTY_BANK_DATA_NODE_<UUID SECOND>",port:"value"}]},out:{result:[{id:`PROPERTY_BANK_COMMAND_NODE_<UUID NEXT> | ${d}`,port:"obj | inputs"}]}},[d]:{type:"command-node-sandbox",title:"Command: SANDBOX_RUN_JAVASCRIPT",properties:{command:"SANDBOX_RUN_JAVASCRIPT",args:{code:f,enable_async:!1}},in:{code:null,inputs:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID FINAL>",port:"result"}]},out:{result:[{id:m,port:"result"},{id:c,port:"result"}]}},[m]:{type:"command-node-sandbox",title:"Command: SANDBOX_GET_ERROR",properties:{command:"SANDBOX_GET_ERROR"},in:{result:[{id:d,port:"result"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE ERROR>",port:"change"}],$note:"Set `result` as null if there is no error"}},[c]:{type:"command-node-sandbox",title:"Command: SANDBOX_GET_RETURN_VALUE",properties:{command:"SANDBOX_GET_RETURN_VALUE"},in:{result:[{id:d,port:"result"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT> | PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT> | null",port:"change"}]}},"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT>":{type:"data-node",properties:{},in:{change:[{id:c,port:"result"}]},out:{value:null},$note:"Put full result into data node"},"PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT>":{type:"command-node-object",title:"Command: OBJECT_GET",properties:{command:"OBJECT_GET",args:{path:"obj_key"}},in:{obj:[{id:c,port:"obj"}]},out:{result:[{id:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>",port:"change"}]},$note:"Parse result object into data node"},"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>":{type:"data-node",properties:{},in:{change:[{id:"PROPERTY_BANK_COMMAND_NODE_<UUID PARSE RESULT>",port:"result"}]},out:{value:null},$note:"Put partial result into data node"}},editor_info:{},type:"script",script_config:{title:t,enable_async:!1,inputs:{"PROPERTY_BANK_DATA_NODE_<UUID>":"arg_name"},disabled_triggers:{},error:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE ERROR> | null",output:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE RESULT> | null",outputs:{obj_key:"PROPERTY_BANK_DATA_NODE_<UUID RECEIVE PARTIAL RESULT>"},code:f,$note:"Required, info for GUI editor"}}}return ad({id:i,example:n,extraInfo:r})};function Cy(e,t){var a,n,r,i,o,s,p,l,u,d,c,m,f,h="user"===t.tokenType,y=((e,t=null)=>({name:a,description:n,inputSchema:r,permission:i},o)=>{cc(t,i)&&e.tool(a,n,r,o)})(e,t),_=e=>({...e,...h?{workspace_id:sa().describe("Workspace ID")}:{}}),E=t.client,T=h?function(e){var t=e.endpoint,a=e.accessToken;if(!t)throw new Error("Media API endpoint is required");if(!a)throw new Error("Access token is required");return Oy({endpoint:t,accessToken:a,enableSubscription:!1,enableRetry:!0})}({endpoint:Sy.media,accessToken:t.token}):E;h&&e.tool("list_workspaces","List all workspaces",{},O(function*(){return ad(yield E.workspaces())})),y({name:"get_workspace_overview",description:"Get comprehensive overview of the BRICKS workspace including stats and summary",inputSchema:_({}),permission:"info"},function(){var e=O(function*({workspace_id:e}){var t=yield Promise.all([E.workspace({id:e}),E.applications({workspaceId:e,paginate:{limit:50,offset:0}}),E.modules({workspaceId:e,paginate:{limit:50,offset:0}}),E.devices({workspaceId:e,paginate:{limit:50,offset:0}}),h?T.mediaWorkspace({workspaceId:e}).catch(()=>null):T.mediaWorkspace().catch(()=>null),h?T.mediaBoxes({workspaceId:e}).catch(()=>[]):T.mediaBoxes().catch(()=>[])]),a=de(t,6),n=a[0],r=a[1],i=a[2],o=a[3],s=a[4],p=a[5];if(!n)throw new Error("Authentication failed, please check your token");return ad({workspace:n,stats:{applications:r?.length??"No permission",modules:i?.length??"No permission",devices:o?.length??"No permission",running_apps:r?.filter(e=>e.status?.running).length??"No permission",media_boxes:p?.length??"No permission",media_enabled:!!s,notes:"Note: The stats are based on the first 50 applications, modules, and devices in the workspace."},recent_activity:{latest_apps:r?.slice(0,5).map(e=>({id:e._id,name:e.name,status:e.status?.running?"running":"stopped",last_update:e.last_modify_datetime}))||[]},media_info:s?{workspace_id:s.id,name:s.name,size_used:s.size,size_limit:s.sizeLimit,boxes:p?.slice(0,5).map(e=>({id:e.id,name:e.name,size:e.size,description:e.description}))||[]}:{enabled:!1,note:"Media workspace is not enabled for this workspace"}})});return function(t){return e.apply(this,arguments)}}()),y({name:"get_applications",description:"List all applications in the workspace",inputSchema:_({limit:pa().describe("Maximum number of applications to return").optional().default(50),offset:pa().describe("Number of applications to skip").optional().default(0)}),permission:"query_application"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.applications({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_application",description:"Get detailed info and config of a specific application",inputSchema:_({id:sa().describe("Application ID")}),permission:"query_application"},function(){var e=O(function*({workspace_id:e,id:t}){return ad(yield E.application({workspaceId:e,id:t}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_modules",description:"List all modules in the workspace",inputSchema:_({limit:pa().describe("Maximum number of modules to return").optional().default(50),offset:pa().describe("Number of modules to skip").optional().default(0)}),permission:"query_module"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.modules({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_module",description:"Get detailed info and config of a specific module",inputSchema:_({id:sa().describe("Module ID")}),permission:"query_module"},function(){var e=O(function*({workspace_id:e,id:t}){return ad(yield E.module({workspaceId:e,id:t}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_module_info",description:"Update a specific module info",inputSchema:_({id:sa().describe("Module ID"),name:sa().describe("Module name"),description:sa().describe("Module description")}),permission:"update_module"},function(){var e=O(function*({workspace_id:e,id:t,name:a,description:n}){return ad(yield E.updateModule({workspaceId:e,id:t,name:a,description:n}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_module_config",description:"Update a specific module configuration",inputSchema:_({id:sa().describe("Module ID"),config:ua({}).passthrough().describe("New configuration object, see file://docs/config-schema.md for schema reference")}),permission:"update_module"},function(){var e=O(function*({workspace_id:e,id:t,config:a}){var n=yield nc(a);if(!n.valid)throw new Error(`Config validation failed: ${n.errors.join(", ")}`);return ad(yield E.updateModule({workspaceId:e,id:t,config:JSON.stringify(a),validateConfig:!0}))});return function(t){return e.apply(this,arguments)}}()),y({name:"get_devices",description:"List all devices in the workspace",inputSchema:_({limit:pa().describe("Maximum number of devices to return").optional().default(50),offset:pa().describe("Number of devices to skip").optional().default(0)}),permission:"query_device"},function(){var e=O(function*({workspace_id:e,limit:t=50,offset:a=0}){return ad(yield E.devices({workspaceId:e,paginate:{limit:t,offset:a}}))});return function(t){return e.apply(this,arguments)}}()),y({name:"create_application",description:"Create a new BRICKS application with default grid layout",inputSchema:_({name:sa().describe("Application name"),description:sa().describe("Application description").optional(),grid_width:pa().describe("Grid width in units").optional().default(96),grid_height:pa().describe("Grid height in units").optional().default(54)}),permission:"create_application"},function(){var e=O(function*({workspace_id:e,name:t,description:a,grid_width:n,grid_height:r}){return ad(yield E.createApplication({workspaceId:e,name:t,description:a,gridWidth:n,gridHeight:r}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_application_info",description:"Update application info",inputSchema:{id:sa().describe("Application ID"),name:sa().describe("Application name"),description:sa().describe("Application description")},permission:"update_application"},function(){var e=O(function*({id:e,name:t,description:a}){return ad(yield E.updateApplication({id:e,name:t,description:a}))});return function(t){return e.apply(this,arguments)}}()),y({name:"update_application_config",description:"Update application configuration with validation",inputSchema:{id:sa().describe("Application ID"),config:ua({}).passthrough().describe("New application configuration. Please read `getting-started` for BRICKS concepts before changing")},permission:"update_application"},function(){var e=O(function*({id:e,config:t}){var a=yield nc(t);if(!a.valid)throw new Error(`Config validation failed: ${a.errors.join(", ")}`);return ad(yield E.updateApplication({id:e,config:JSON.stringify(t)}))});return function(t){return e.apply(this,arguments)}}()),y({name:"bind_application",description:"Bind application to device with viewport configuration",inputSchema:{app_id:sa().describe("Application ID"),viewports:la(ua({device_id:sa().describe("Device ID"),x:pa().describe("X coordinate"),y:pa().describe("Y coordinate"),width:pa().describe("Width"),height:pa().describe("Height"),rotate:pa().describe("Rotation"),rotateType:sa().describe("Rotation type")})).describe("Viewport configuration")},permission:"bind_application"},(a=O(function*({app_id:e,viewports:t}){return ad(yield E.bindApplication({id:e,bind_devices:t.map(e=>e.device_id),device_frames:t.reduce((e,t)=>({...e,[t.device_id]:{x:t.x,y:t.y,width:t.width,height:t.height,rotate:t.rotate,rotateType:t.rotateType}}),{})}))}),function(e){return a.apply(this,arguments)})),y({name:"unbind_application",description:"Unbind application from device",inputSchema:{app_id:sa().describe("Application ID"),device_id:sa().describe("Device ID")},permission:"bind_application"},(n=O(function*({app_id:e,device_id:t}){return ad(yield E.bindApplication({id:e,unbindDevices:[t]}))}),function(e){return n.apply(this,arguments)})),h&&y({name:"list_media_workspaces",description:"List all media workspaces",inputSchema:{},permission:"query_media_flow"},O(function*(){return ad(yield T.mediaWorkspaces())})),y({name:"get_media_workspace",description:"Get media workspace information and status",inputSchema:_({}),permission:"query_media_flow"},(r=O(function*({workspace_id:e}){return ad(yield T.mediaWorkspace({workspaceId:e}))}),function(e){return r.apply(this,arguments)})),y({name:"list_media_boxes",description:"List all media boxes in the workspace",inputSchema:_({}),permission:"query_media_flow"},(i=O(function*({workspace_id:e}){return ad(yield T.mediaBoxes({workspaceId:e}))}),function(e){return i.apply(this,arguments)})),y({name:"get_media_box",description:"Get detailed information about a specific media box",inputSchema:{box_id:sa().describe("Media box ID")},permission:"query_media_flow"},(o=O(function*({box_id:e}){return ad(yield T.mediaBox({boxId:e}))}),function(e){return o.apply(this,arguments)})),y({name:"list_media_files",description:"List media files in a specific box with filtering options",inputSchema:{box_id:sa().describe("Media box ID"),include_types:la(sa()).optional().describe('Filter by file types (e.g., ["image", "video", "audio"])'),user_tags:la(sa()).optional().describe("Filter by user tags"),limit:pa().optional().default(50).describe("Maximum number of files to return"),offset:pa().optional().default(0).describe("Number of files to skip")},permission:"query_media_flow"},(s=O(function*({box_id:e,include_types:t,user_tags:a,limit:n,offset:r}){return ad(yield T.mediaFiles({boxId:e,includeTypes:t,userTags:a,limit:n,offset:r}))}),function(e){return s.apply(this,arguments)})),y({name:"get_media_file_meta",description:"Get detailed information about a specific media file",inputSchema:{file_id:sa().describe("Media file ID")},permission:"query_media_flow"},(p=O(function*({file_id:e}){return ad(yield T.mediaFile({fileId:e}))}),function(e){return p.apply(this,arguments)})),y({name:"media_box_upload",description:"Upload a file to a media box from URL or base64 data",inputSchema:{box_id:sa().describe("Target media box ID"),name:sa().describe("File name"),description:sa().optional().default("").describe("File description"),file_type:da(["image","video","audio","file"]).describe("File type"),source_url:sa().optional().describe("URL to download the file from"),base64_data:sa().optional().describe("Base64 encoded file data"),user_tags:la(sa()).optional().default([]).describe("User-defined tags for the file")},permission:"write_media_flow"},(l=O(function*({box_id:e,name:t,description:a,source_url:n,base64_data:r,file_type:i,user_tags:o}){if(!n&&!r)throw new Error("Either source_url or base64_data must be provided");if(n&&r)throw new Error("Provide either source_url OR base64_data, not both");var s=n?null:"application/octet-stream",p=n?yield(0,nd.Ay)(n,{agent:yd(n)}).then(e=>(s=e.headers.get("content-type"),e.blob())):new Blob([td.Buffer.from(r,"base64")],{type:s}),l=yield T.requestFileUpload({name:t,description:a,boxId:e,fileType:h?i.toUpperCase():i,contentType:s,userTags:o,meta:{}}),u=JSON.parse(l?.meta.uploadInfo),d=new FormData;d.append("file",p),d.append("Content-Type",s),d.append("AWSAccessKeyId",u.AWSAccessKeyId),d.append("Signature",u.Signature),d.append("Policy",u.Policy),d.append("acl",u.acl),d.append("key",u.key);var c=yield(0,nd.Ay)(u.url,{method:"POST",body:d}).then(e=>e.ok).catch(()=>!1);return ad({file_id:l.id,upload_success:c,upload_info:{content_type:s,file_type:i,source_type:n?"url":"base64",processing_note:"File will be processed automatically. Use get_media_file to check processing status."}})}),function(e){return l.apply(this,arguments)})),y({name:"update_media_file_meta",description:"Update media file information",inputSchema:{file_id:sa().describe("Media file ID"),name:sa().optional().describe("New file name"),description:sa().optional().describe("New file description"),user_tags:la(sa()).optional().describe("New user tags")},permission:"write_media_flow"},(u=O(function*({file_id:e,name:t,description:a,user_tags:n}){return ad(yield T.updateMediaFile({fileId:e,name:t,description:a,userTags:n,requestUploadAgain:!1}))}),function(e){return u.apply(this,arguments)})),y({name:"copy_media_files",description:"Copy media files from one box to another",inputSchema:{from_box_id:sa().describe("Source media box ID"),to_box_id:sa().describe("Target media box ID"),file_ids:la(sa()).describe("Array of media file IDs to copy")},permission:"write_media_flow"},(d=O(function*({from_box_id:e,to_box_id:t,file_ids:a}){return ad(yield T.copyMediaFiles({fromBoxId:e,toBoxId:t,list:a}))}),function(e){return d.apply(this,arguments)})),y({name:"delete_media_files",description:"Delete specific media files from a box",inputSchema:{box_id:sa().describe("Media box ID"),file_ids:la(sa()).describe("Array of media file IDs to delete")},permission:"write_media_flow"},(c=O(function*({box_id:e,file_ids:t}){return ad(yield T.deleteMediaFiles({boxId:e,list:t}))}),function(e){return c.apply(this,arguments)})),y({name:"cleanup_media_box",description:"Delete all files in a media box, optionally filtered by type",inputSchema:{box_id:sa().describe("Media box ID"),include_types:la(sa()).optional().describe('Only delete files of these types (e.g., ["image", "video"])')},permission:"write_media_flow"},(m=O(function*({box_id:e,include_types:t}){if("deleteMediaBoxFiles"in T)return ad(yield T.deleteMediaBoxFiles({boxId:e,includeTypes:t}));var a=yield T.mediaFiles({boxId:e,includeTypes:t});return ad(yield T.deleteMediaFiles({boxId:e,list:a.map(e=>e.id)}))}),function(e){return m.apply(this,arguments)})),e.tool("calculate_grid_layout","Calculate grid layout and pixel conversions for different device resolutions",{device_width:pa().describe("Device width in pixels"),device_height:pa().describe("Device height in pixels"),app_grid_width:pa().describe("Application grid width").optional().default(96),app_grid_height:pa().describe("Application grid height").optional().default(54)},(f=O(function*({device_width:e,device_height:t,app_grid_width:a,app_grid_height:n}){var r,i,o={deviceBrickWidth:(r=e)/(i=r/a),deviceBrickHeight:t/i,deviceBrickUnit:i},s=function(e,t,a=96){var n=e/a;return t>e&&(n=t/a),{deviceBrickWidth:Math.round(e/n),deviceBrickHeight:Math.round(t/n),deviceBrickUnit:n}}(e,t,a);return ad({device_resolution:{width:e,height:t,aspect_ratio:(e/t).toFixed(2)},current_grid:{width:a,height:n,unit_size_px:o.deviceBrickUnit.toFixed(2),total_pixels:{width:o.deviceBrickWidth.toFixed(2),height:o.deviceBrickHeight.toFixed(2)}},recommended_grid:{width:s.deviceBrickWidth,height:s.deviceBrickHeight,unit_size_px:s.deviceBrickUnit.toFixed(2),note:"Optimized for device aspect ratio"}})}),function(e){return f.apply(this,arguments)})),e.tool("create_item","Use this tool to create new item that you can put in application configuration",{type:da(["subspace","canvas","brick","generator","property_bank","property_bank_calc","property_bank_command","animation","state_group","automation_map"]).describe("Item type"),title:sa().describe("Item title"),template_key:sa().optional().describe("Template key for brick or generator")},Iy),e.tool("getting_started","Get documentation content for getting started",{},O(function*(){return ad(dc)}))}var Dy="2.24.0-beta.19";function Py(){return Py=O(function*(e={}){var t=e.token||process.env.BRICKS_API_TOKEN;if(!t)throw console.error("Error: API token is required"),console.error("Please provide a token via options or set BRICKS_API_TOKEN environment variable"),new Error("API token is required");var a=Zu({queryStringParameters:{token:t}});if(!a.success)throw console.error("Error: Invalid BRICKS_API_TOKEN"),console.error(a.message),new Error("Invalid BRICKS_API_TOKEN");var n,r=new Mu({name:Ay,version:Dy}),i={...a,client:Ny(Sy.bricks,a.token,a.tokenType)};(n=r).prompt("getting-started","Getting started with BRICKS",{},O(function*(){return{messages:[{role:"user",content:{type:"text",text:'Welcome to BRICKS — start here.\n\nBefore doing any complex work (application design, deployments, etc.),\nalways consult the official docs rather than guessing.\n\nIMPORTANT: BRICKS users interact through a GUI editor, not raw config files.\nNever show users JSON config details, schema fields, or technical implementation.\nFocus on user-friendly descriptions of what the app will do and how it will look.\n\nGolden rules for working with BRICKS:\n1) Read before you act\n - Open these resources first, then proceed:\n - `getting-started` — overview & architecture\n - `config-schema` — canonical schema for apps, subspaces, bricks, generators, etc.\n - `components-index` — available bricks/generators\n2) Source of truth\n - Rely on the docs above; do not invent fields not present in the schema\n3) No guessing\n - If names, constraints, or device details are missing, ask to fetch them first\n4) Plan then execute\n - Propose a clear step-by-step plan and wait for approval before writing or mutating data\n5) User-friendly communication\n - Describe features in terms of what users see and do, not technical config\n - Use visual/functional language: "text display", "button", "screen transition"\n - Avoid exposing JSON, IDs, or schema details to end users\n\nBRICKS essentials:\n- Applications: interactive digital signage experiences\n- Devices: deployment targets (screens/players)\n- Modules: Reusable module across applications\n- Grid system: default 96×54; 1 unit = device_width/96 (e.g., 20px at 1920×1080)\n- Key primitives: Subspaces, Canvas, Bricks, Generators, Property Banks (Data)\n\nQuick actions:\n- "Create a new application" → use the `create-application` prompt\n- "Deploy an application to a device" → use the `deploy-to-device` prompt\n\nTry asking:\n- "Draft a plan to create an app with a text display and deploy it; ask any missing questions first"'}}]}})),n.prompt("create-application","Create a new BRICKS application with guided setup",{app_name:sa().describe("Name for the new application"),description:sa().describe("Short description for the new application").optional()},function(){var e=O(function*(e){var t=e?.app_name||"New Application",a=e?.description||"";return{messages:[{role:"user",content:{type:"text",text:`Help me create a new BRICKS application called "${t}".\n\n${a?`Goal: ${a}`:""}\n\nIMPORTANT: Users see a visual GUI editor, not raw config. Describe features in user-friendly terms:\n- "text display" not "BRICK_TEXT"\n- "image" not "BRICK_IMAGE"\n- "canvas name" not "CANVAS_xxx"\n- "data storage" not "PROPERTY_BANK"\n- Focus on what users see and do, not technical implementation\n\nHow we'll proceed (no guessing, schema-first):\n1) Confirm intent\n - Restate objectives and success criteria in 1–3 bullets\n2) Consult docs (as needed)\n - getting-started, config-schema, components-index\n - Ensure proposed fields exist in the schema\n3) Ask missing questions before changes\n - Target device(s) and resolution(s)\n - Layout needs (pages/screens), content types, data sources\n - Localization, scheduling, or interaction needs\n4) Propose a minimal viable design (After confirming intent)\n - App structure: screens → visual elements\n - Initial component selection with rationale\n - Grid usage: default 96×54 (≈20px at 1920×1080)\n5) Produce a schema-valid skeleton (no side effects yet)\n - Include only fields defined by config-schema\n - Use clear placeholders for text/assets/URLs/ids\n\nWhat I'll produce first:\n- Short recap of requirements\n- Clarifying questions (only what's necessary)\n- High-level architecture plan\n- Minimal config skeleton that validates against the schema`}}]}});return function(t){return e.apply(this,arguments)}}()),function(e){e.resource("getting-started-docs","file://docs/getting-started.md",{mimeType:"text/markdown",title:"Getting Started with BRICKS",description:"Comprehensive guide to BRICKS architecture, concepts, and development workflow"},O(function*(){return ad(ed,{uri:"file://docs/getting-started.md",mimeType:"text/markdown"})}))}(r),Cy(r,i);var o=new Wu;try{yield r.connect(o),console.error("BRICKS MCP Server running on STDIO"),console.error(`Server: ${Ay} v${Dy}`),console.error(`Token Type: ${a.tokenType}`),console.error(`Permissions: ${a.tokenInfo.permissions.join(", ")}`),console.error("Ready to accept requests...")}catch(e){throw console.error("Failed to start MCP server:",e),e}}),Py.apply(this,arguments)}var jy=new j("mcp").description("MCP server management");jy.command("start").description("Start the BRICKS MCP server in STDIO mode").option("-t, --token <token>","API token (overrides saved token)").action(function(){var e=O(function*(e){var t=(0,G.getCurrentProfile)(),a=e.token||(0,G.getToken)(t);a||(console.error(M.Ay.red("Error: No API token found.")),console.error(M.Ay.gray("Please login first with: bricks auth login <passcode>")),console.error(M.Ay.gray("Or provide a token with: bricks mcp start --token <token>")),process.exit(1));try{yield function(){return Py.apply(this,arguments)}({token:a})}catch(e){console.error(M.Ay.red(`Failed to start MCP server: ${e.message}`)),process.exit(1)}});return function(t){return e.apply(this,arguments)}}());var ky=new j("devtools").description("DevTools server discovery and connection");ky.command("scan").description("Scan LAN for DevTools servers via UDP + HTTP").option("-t, --timeout <ms>","Scan timeout in milliseconds","3000").option("-j, --json","Output as JSON").option("--verify","Verify each discovered server via HTTP").option("--udp-only","Skip HTTP subnet probe (UDP only)").option("-p, --port <port>","Port for HTTP probe","19851").action(function(){var e=O(function*(e){var t=(yield Promise.resolve().then(m.bind(m,9790))).default,a=yield m.e(44).then(m.bind(m,2044)),n=a.discoverDevToolsServers,r=a.verifyDevToolsServer,i=a.httpProbeSubnet,o=yield Promise.resolve().then(m.bind(m,8765)),s=o.getCurrentProfile,p=o.getTokenInfo,l=parseInt(e.timeout,10),u=t(`Scanning for DevTools servers (${l}ms)...`).start();try{var d=n({timeout:l}),c=e.udpOnly?Promise.resolve([]):(u.text="Scanning via UDP + HTTP probe...",i({port:parseInt(e.port,10)})),f=yield Promise.all([d,c]),h=de(f,2),y=h[0],_=h[1],E=[...y,..._],T=new Map;for(var g of E){var v=g.deviceId||`${g.address}:${g.port}`,R=T.get(v);if(R)for(var b of(R.addresses.includes(g.address)||R.addresses.push(g.address),"127.0.0.1"===R.address&&"127.0.0.1"!==g.address&&(R.address=g.address),g.protocols||[]))R.protocols?.includes(b)||R.protocols?.push(b);else T.set(v,{...g,addresses:[g.address]})}var N=[...T.values()];if(0===N.length)return void u.info("No DevTools servers found on the network.");if(e.verify){u.text=`Verifying ${N.length} server(s)...`;var A=yield Promise.all(N.map(function(){var e=O(function*(e){var t=yield r(e.address,e.port);return{...e,verified:!!t}});return function(t){return e.apply(this,arguments)}}()));N.splice(0,N.length,...A)}if(u.stop(),e.json)return void console.log(JSON.stringify(N,null,2));var S=p(s()),w=S?.workspaceId||null;console.log(M.Ay.bold(`\nFound ${N.length} DevTools server(s)`)),console.log("─".repeat(80));var I=function*(e){var t=!1===e.verified?M.Ay.red("unverified"):M.Ay.green("online"),a=e.hasPasscode?M.Ay.yellow("passcode"):M.Ay.gray("open"),n=(e.protocols||[]).map(e=>M.Ay.cyan(e)).join(", "),r=e.workspaceId&&w&&e.workspaceId===w,i=e.addresses||[e.address],o=i.filter(t=>t!==e.address),s=o.length>0?`${e.address}:${e.port} +${o.length} more`:`${e.address}:${e.port}`;console.log(` ${M.Ay.bold(e.name||"Unknown")} ${M.Ay.gray(`(${s})`)} [${t}]`),o.length>0&&console.log(` Addresses: ${i.map(e=>M.Ay.gray(e)).join(", ")}`);var p=` Protocols: ${n||M.Ay.gray("none")} Auth: ${a}`;if(e.deviceId&&(p+=` Device: ${M.Ay.gray(e.deviceId)}`),console.log(p),e.workspaceId){var l=r?M.Ay.green(`${e.workspaceId} (current profile)`):M.Ay.gray(e.workspaceId);console.log(` Workspace: ${l}`)}};for(var C of N)yield*I(C);console.log("─".repeat(80)),console.log(M.Ay.gray(`\nConnect via: devtools://devtools/bundled/js_app.html?ws=<address>:${N[0]?.port||19851}/ws?p=<passcode>`)),process.exit(0)}catch(e){u.fail(`Scan failed: ${e.message}`),process.exit(1)}});return function(t){return e.apply(this,arguments)}}()),ky.command("open <address>").description("Show connection URLs for a DevTools server").option("-p, --port <port>","Server port","19851").option("--verify","Verify server is reachable first").action(function(){var e=O(function*(e,t){var a=parseInt(t.port,10),n=`${e}:${a}`;if(t.verify){var r=(yield Promise.resolve().then(m.bind(m,9790))).default,i=(yield m.e(44).then(m.bind(m,2044))).verifyDevToolsServer,o=r(`Verifying ${n}...`).start(),s=yield i(e,a);s||(o.fail(`Could not reach DevTools server at ${n}`),process.exit(1)),o.succeed(`${s.name||"DevTools"} is reachable`),console.log()}console.log(M.Ay.bold("Connection URLs")),console.log("─".repeat(60)),console.log(` Web UI: ${M.Ay.cyan(`http://${n}`)}`),console.log(` CDP: ${M.Ay.cyan(`devtools://devtools/bundled/js_app.html?ws=${n}/ws?p=<passcode>`)}`),console.log(` MCP: ${M.Ay.cyan(`http://${n}/mcp`)}`),console.log(` MCP SSE: ${M.Ay.cyan(`http://${n}/sse`)}`),console.log(` Info: ${M.Ay.cyan(`http://${n}/devtools/info`)}`),console.log("─".repeat(60)),console.log(),console.log(M.Ay.bold("Authorization")),console.log(" MCP and MCP SSE require a Bearer token header with the device passcode:"),console.log(` ${M.Ay.gray("Authorization: Bearer <passcode>")}`)});return function(t,a){return e.apply(this,arguments)}}());var xy=function(){var e=O(function*(){var e=process.argv.findIndex(e=>"--auth-profile"===e||"-ap"===e);if(-1!==e&&process.argv[e+1]&&((0,G.setProfileOverride)(process.argv[e+1]),process.argv.splice(e,2)),A.name("bricks").description("BRICKS CLI - Command-line interface for BRICKS Workspace API").version("2.24.0-beta.19").enablePositionalOptions(),A.addCommand(H),A.addCommand(ee),A.addCommand(pe),A.addCommand(ue),A.addCommand(he),A.addCommand(be),A.addCommand(De),A.addCommand(jy),A.addCommand(ky),A.command("interactive").alias("i").description("Start interactive mode with Ink UI").action(O(function*(){try{(0,(yield m.e(612).then(m.bind(m,9612))).runInteractiveMode)()}catch(e){console.error(M.Ay.red(`Failed to start interactive mode: ${e.message}`)),process.exit(1)}})),A.command("workspace").alias("ws").description("Show current workspace information").option("-j, --json","Output as JSON").action(function(){var e=O(function*(e){var t=yield Promise.resolve().then(m.bind(m,8765)),a=t.getToken,n=t.getBaseUrl,r=t.getCurrentProfile,i=(yield Promise.resolve().then(m.bind(m,700))).createClient,o=(yield Promise.resolve().then(m.bind(m,9790))).default,s=a(r());s||(console.error(M.Ay.red("Not logged in. Use `bricks auth login` first.")),process.exit(1));var p=o("Fetching workspace info...").start();try{var l=i(n(),s),u=yield l.workspace();if(p.stop(),e.json)return void console.log(JSON.stringify(u,null,2));console.log(M.Ay.bold("\nWorkspace Information")),console.log("─".repeat(60)),console.log(`Name: ${M.Ay.green(u.name)}`),console.log(`ID: ${M.Ay.gray(u._id)}`),console.log(`Description: ${u.description||M.Ay.gray("N/A")}`),console.log(`\n${M.Ay.bold("Data")}`),console.log(`Remote Update: ${u.bank?.enable_remote_update?M.Ay.green("Enabled"):M.Ay.gray("Disabled")}`),console.log(`Spacename: ${u.bank?.spacename||M.Ay.gray("N/A")}`),console.log("─".repeat(60))}catch(e){p.fail(`Failed to get workspace: ${e.message}`),process.exit(1)}});return function(t){return e.apply(this,arguments)}}()),A.on("--help",()=>{console.log(""),console.log(M.Ay.bold("Examples:")),console.log(""),console.log(M.Ay.gray(" # Login with a one-time passcode (recommended)")),console.log(" $ bricks auth login <passcode>"),console.log(""),console.log(M.Ay.gray(" # List all devices")),console.log(" $ bricks device list"),console.log(""),console.log(M.Ay.gray(" # Monitor devices in real-time")),console.log(" $ bricks device monitor"),console.log(""),console.log(M.Ay.gray(" # Control a device")),console.log(" $ bricks device refresh <device-id>"),console.log(" $ bricks device control <device-id> clear-cache"),console.log(""),console.log(M.Ay.gray(" # Bind a new device")),console.log(' $ bricks device bind <passcode> -n "My Device"'),console.log(""),console.log(M.Ay.gray(" # List applications")),console.log(" $ bricks app list"),console.log(""),console.log(M.Ay.gray(" # Start interactive mode")),console.log(" $ bricks interactive"),console.log(""),console.log(M.Ay.gray(" # Change API endpoint")),console.log(" $ bricks config endpoint beta"),console.log(""),console.log(M.Ay.gray("Get workspace token from BRICKS Controller:")),console.log(M.Ay.cyan(" https://control.bricks.tools")),console.log(M.Ay.gray(" Go to Workspace Settings > API Token"))}),0===process.argv.slice(2).length)try{return void(0,(yield m.e(612).then(m.bind(m,9612))).runInteractiveMode)()}catch(e){console.error(M.Ay.red(`Failed to start interactive mode: ${e.message}`)),process.exit(1)}yield A.parseAsync(process.argv)});return function(){return e.apply(this,arguments)}}();const Ly=xy;export{Ly as default,xy as run};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fugood/bricks-cli",
3
- "version": "2.24.0-beta.18",
3
+ "version": "2.24.0-beta.19",
4
4
  "description": "BRICKS CLI - Command-line interface for BRICKS Workspace API",
5
5
  "keywords": [
6
6
  "bricks",
@@ -39,7 +39,7 @@
39
39
  },
40
40
  "devDependencies": {
41
41
  "@apollo/client": "^3.13.8",
42
- "@fugood/bricks-config-core": "^2.24.0-beta.18",
42
+ "@fugood/bricks-config-core": "^2.24.0-beta.19",
43
43
  "@inquirer/prompts": "^7.0.0",
44
44
  "chalk": "^5.3.0",
45
45
  "commander": "^12.1.0",
@@ -58,5 +58,5 @@
58
58
  "engines": {
59
59
  "node": ">=18.0.0"
60
60
  },
61
- "gitHead": "c7d8e3252e72c78d8b356e3f366e24f072c12521"
61
+ "gitHead": "17d967ae3718529b5b47e76b800874bcb2b22277"
62
62
  }