@inkeep/open-knowledge 0.0.0-dev-20260501054734 → 0.0.0-dev-20260501055434
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.
- package/dist/cli.mjs +255 -256
- package/dist/constants-Csaa4YGL.mjs +2 -0
- package/dist/dist-B0koAhBW.mjs +1 -0
- package/dist/{dist-BKxD-v-w.mjs → dist-C8iO0ddp.mjs} +9 -9
- package/dist/index.mjs +1 -1
- package/dist/init-1oapVq0V.mjs +1 -0
- package/dist/{init-DEHyWHMa.mjs → init-BUnpt_ZF.mjs} +5 -5
- package/dist/init-C5RZF4cZ.mjs +1 -0
- package/dist/{init-DVZtt6e-.mjs → init-tG0EK1Je.mjs} +2 -2
- package/dist/loader-C5AIUzdN.mjs +1 -0
- package/dist/{loader-DD2NITvw.mjs → loader-CZE2QlA_.mjs} +2 -2
- package/dist/paths-C5pgWwxG.mjs +1 -0
- package/dist/paths-DfmL-9oM.mjs +2 -0
- package/dist/preview-BbFOb5YQ.mjs +1 -0
- package/dist/{preview-C86aCB1t.mjs → preview-BlPt157K.mjs} +2 -2
- package/dist/public/assets/{index-joGKm2Br.js → index-BnZvzQ-9.js} +69 -69
- package/dist/public/index.html +1 -1
- package/dist/src-0PRCLtO_.mjs +1 -0
- package/dist/start-ID3eMpDo.mjs +1 -0
- package/dist/{start-D5tAdx92.mjs → start-eK3J-xIV.mjs} +2 -2
- package/package.json +1 -1
- package/dist/constants-C_Xn28oM.mjs +0 -2
- package/dist/dist-BuWOuGGO.mjs +0 -1
- package/dist/init-BrZlKzcx.mjs +0 -1
- package/dist/init-gZdio8Wt.mjs +0 -1
- package/dist/loader-CEV6AVlU.mjs +0 -1
- package/dist/paths-Dwr32i3p.mjs +0 -1
- package/dist/paths-ajeOK0uP.mjs +0 -2
- package/dist/preview-D6fWJCDu.mjs +0 -1
- package/dist/src-D6R3jg-t.mjs +0 -1
- package/dist/start-DG0Lr5vX.mjs +0 -1
package/dist/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{n as e,r as t}from"./loader-
|
|
1
|
+
import{n as e,r as t}from"./loader-CZE2QlA_.mjs";import{c as n,i as r,l as i,s as a,t as o,u as s}from"./init-BUnpt_ZF.mjs";import"./src-0PRCLtO_.mjs";export{i as ALL_EDITOR_IDS,t as ConfigSchema,s as EDITOR_TARGETS,o as detectInstalledEditors,e as loadConfig,r as readExistingMcpEntry,a as writeEditorMcpConfig,n as writeUserMcpConfigs};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{o as e}from"./init-BUnpt_ZF.mjs";export{e as runInit};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{n as e,t}from"./esm-wByiX8MO.mjs";import{$ as n}from"./dist-Bk22-nn7.mjs";import{r}from"./constants-
|
|
1
|
+
import{n as e,t}from"./esm-wByiX8MO.mjs";import{$ as n}from"./dist-Bk22-nn7.mjs";import{r}from"./constants-Csaa4YGL.mjs";import{Q as i,_ as a,et as o,ft as s}from"./dist-C8iO0ddp.mjs";import{t as c}from"./is-object-CEU0BgQ5.mjs";import{n as l}from"./init-tG0EK1Je.mjs";import{t as u}from"./preview-BlPt157K.mjs";import{i as d,o as f,r as p,s as m,t as h}from"./colors-BdAXRiXe.mjs";import{basename as g,dirname as _,join as v,posix as y,relative as b,resolve as x,sep as S,win32 as C}from"node:path";import{existsSync as w,mkdirSync as T,readFileSync as E,writeFileSync as D}from"node:fs";import{homedir as O}from"node:os";import ee from"@inquirer/checkbox";
|
|
2
2
|
/*!
|
|
3
3
|
* Copyright (c) Squirrel Chat et al., All rights reserved.
|
|
4
4
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
@@ -249,7 +249,7 @@ let L=/^[a-z0-9-_]+$/i;function R(e){let t=typeof e;if(t===`object`){if(Array.is
|
|
|
249
249
|
`?r:r+`
|
|
250
250
|
`}const H=[`claude`,`claude-desktop`,`cursor`,`vscode`,`windsurf`,`codex`],we=[`@inkeep/open-knowledge`,`mcp`],Te={MCP_DEBUG:`1`,OK_LOG_FILE:`/tmp/ok-mcp.log`};function U(e=process.argv[1]){if(!e)throw Error(`Cannot infer the local CLI entry for --dev-mcp because process.argv[1] is empty.`);let t=x(e);if(g(t)===`cli.mjs`&&g(_(t))===`dist`)return t;let n=t.split(S),r=n.lastIndexOf(`packages`);if(r===-1||n[r+1]!==`cli`)throw Error(`Cannot infer the repo root for --dev-mcp from ${t}. Run the local CLI from this repo so the built dist path can be derived.`);let i=n.slice(0,r);return v(i.length===0?S:i.join(S),`packages`,`cli`,`dist`,`cli.mjs`)}function W(e={}){if(e.cliPath)return{command:e.cliPath,args:[`mcp`]};if(e.mode===`pinned`){let t=e.cliEntryPath??process.argv[1];if(!t)throw Error("Cannot pin MCP entry — process.argv[1] is empty. Pass --no-pin to use the default `npx` entry.");return{command:`node`,args:[x(t),`mcp`]}}return e.mode===`dev`?{command:`node`,args:[U(e.cliEntryPath),`mcp`],env:{...Te}}:{command:`npx`,args:[...we]}}function G(e){return e===`win32`?C:y}function Ee(e={}){let t=e.platformName??process.platform,n=e.home??O(),r=e.env??process.env,i=G(t);return t===`darwin`?i.join(n,`Library`,`Application Support`):t===`win32`?r.APPDATA??i.join(n,`AppData`,`Roaming`):r.XDG_CONFIG_HOME??i.join(n,`.config`)}function De(e={}){let t=e.platformName??process.platform,n=e.home??O();return G(t).join(n,`.claude.json`)}function Oe(e={}){let t=e.platformName??process.platform,n=e.home??O(),r=e.env??process.env;if(t===`darwin`)return y.join(n,`Library`,`Application Support`,`Claude`,`claude_desktop_config.json`);if(t===`win32`){let e=r.APPDATA??C.join(n,`AppData`,`Roaming`);return C.join(e,`Claude`,`claude_desktop_config.json`)}throw Error(`Claude Desktop is not available on ${t}. Supported: macOS, Windows.`)}function ke(e={}){let t=e.platformName??process.platform,n=e.home??O();return G(t).join(n,`.cursor`,`mcp.json`)}function Ae(e={}){return G(e.platformName??process.platform).join(Ee(e),`Code`,`User`,`mcp.json`)}function je(e={}){let t=e.platformName??process.platform,n=e.home??O();return G(t).join(n,`.codeium`,`windsurf`,`mcp_config.json`)}function Me(e={}){let t=e.platformName??process.platform,n=e.home??O();return(e.env??process.env).CODEX_HOME??G(t).join(n,`.codex`)}function Ne(e={}){return G(e.platformName??process.platform).join(Me(e),`config.toml`)}function K(e,t){if(e===t)return!0;if(Array.isArray(e)&&Array.isArray(t))return e.length===t.length&&e.every((e,n)=>K(e,t[n]));if(c(e)&&c(t)){let n=Object.keys(e).sort(),r=Object.keys(t).sort();return n.length===r.length&&n.every((e,t)=>e===r[t])&&n.every(n=>K(e[n],t[n]))}return!1}function Pe(e,t){return Object.entries(t).every(([t,n])=>K(e[t],n))}function Fe(e,t){return{...e,...t}}function q(e){return{...e,isCompatible(t,n,r){return Pe(t,e.buildEntry(n,r))},mergeManagedFields(t,n,r){return Fe(t,e.buildEntry(n,r))}}}const J={claude:q({id:`claude`,label:`Claude Code`,configPath:(e,t)=>De({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>r,buildEntry:(e,t)=>W(t),scope:`global`,detectPath:(e,t)=>v(t??O(),`.claude`),projectConfigPath:e=>v(e,`.mcp.json`)}),"claude-desktop":q({id:`claude-desktop`,label:`Claude Desktop`,configPath:(e,t)=>Oe({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>r,buildEntry:(e,t)=>W(t),scope:`global`,detectPath:(e,t)=>_(Oe({home:t}))}),cursor:q({id:`cursor`,label:`Cursor`,configPath:(e,t)=>ke({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>r,buildEntry:(e,t)=>W(t),scope:`global`,detectPath:(e,t)=>_(ke({home:t})),projectConfigPath:e=>v(e,`.cursor`,`mcp.json`)}),vscode:q({id:`vscode`,label:`VS Code`,configPath:(e,t)=>Ae({home:t}),format:`json`,topLevelKey:`servers`,serverName:()=>r,buildEntry:(e,t)=>({type:`stdio`,...W(t)}),scope:`global`,detectPath:(e,t)=>_(Ae({home:t})),projectConfigPath:e=>v(e,`.vscode`,`mcp.json`)}),windsurf:q({id:`windsurf`,label:`Windsurf`,configPath:(e,t)=>je({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>r,buildEntry:(e,t)=>W(t),scope:`global`,detectPath:(e,t)=>_(je({home:t}))}),codex:q({id:`codex`,label:`Codex`,configPath:(e,t)=>Ne({home:t}),format:`toml`,topLevelKey:`mcp_servers`,serverName:()=>r,buildEntry:(e,t)=>W(t),scope:`global`,detectPath:(e,t)=>_(Ne({home:t})),projectConfigPath:e=>v(e,`.codex`,`config.toml`)})};function Y(e){let t=e.filter(e=>!(e in J));if(t.length>0)throw Error(`Unknown editor(s): ${t.join(`, `)}. Valid options: ${H.join(`, `)}`);return e.map(e=>J[e])}function Ie(e){if(!w(e))return{};let t=E(e,`utf-8`).trim();if(t===``)return{};try{let n=JSON.parse(t);if(c(n))return n;throw Error(`${e} root must be a JSON object`)}catch(t){throw t instanceof SyntaxError?Error(`${e} contains invalid JSON: ${t.message}`):t}}function Le(e){if(!w(e))return{};let t=E(e,`utf-8`).trim();if(t===``)return{};try{let n=ve(t);if(c(n))return n;throw Error(`${e} root must be a TOML table`)}catch(t){throw Error(`${e} contains invalid TOML: ${t instanceof Error?t.message:String(t)}`)}}function Re(e,t){T(_(e),{recursive:!0}),D(e,`${JSON.stringify(t,null,2)}\n`,`utf-8`)}function ze(e,t){T(_(e),{recursive:!0});let n=Ce(t);D(e,n.endsWith(`
|
|
251
251
|
`)?n:`${n}\n`,`utf-8`)}const Be=e=>e!==`project`,Ve=e=>e!==`user`;async function He(){let e=await ee({message:`Where should the MCP server be configured?
|
|
252
|
-
`,required:!1,theme:{icon:{checked:`[x]`,unchecked:`[ ]`}},choices:[{name:`User-level (~/.claude.json, ~/.cursor/mcp.json, …)`,value:`user`,checked:!0},{name:`Project-level (.mcp.json, .cursor/mcp.json, …)`,value:`project`,checked:!0}]});return e.includes(`user`)&&e.includes(`project`)?`both`:e.includes(`user`)?`user`:e.includes(`project`)?`project`:null}async function Ue(e){return e.mcp===!1?null:e.scope?e.scope:e.isTTY??process.stdout.isTTY?(e.promptFn??He)():`both`}const We=`0.0.1`,X=`open-knowledge-ui`;function Ge(e,t={}){let n=v(e,`.claude`,`launch.json`),r=t.mode===`dev`?{name:X,runtimeExecutable:`node`,runtimeArgs:[U(t.cliEntryPath),`ui`],port:3e3}:{name:X,runtimeExecutable:`npx`,runtimeArgs:[`@inkeep/open-knowledge`,`ui`],port:3e3};try{if(!w(n))return T(_(n),{recursive:!0}),D(n,`${JSON.stringify({version:We,configurations:[r]},null,2)}\n`,`utf-8`),{action:`created`,configPath:n};let e=E(n,`utf-8`).trim(),t=e?JSON.parse(e):{};if(!c(t))return{action:`failed`,configPath:n,error:`launch.json root is not an object`};let i=Array.isArray(t.configurations)?t.configurations:[],a=i.findIndex(e=>c(e)&&e.name===X);a>=0?i[a]=r:i.push(r);let o={...t,version:t.version??We,configurations:i};return D(n,`${JSON.stringify(o,null,2)}\n`,`utf-8`),{action:a>=0?`merged`:`created`,configPath:n}}catch(e){return{action:`failed`,configPath:n,error:e instanceof Error?e.message:String(e)}}}function Z(e,t,n){try{return w(e.detectPath?.(t,n)??_(e.configPath(t,n)))}catch{return!1}}function Q(e,t,n,r,i){let a=e.serverName(t),o;try{o=i??e.configPath(t,r)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:``,serverName:a,error:t instanceof Error?t.message:String(t)}}if(!i&&!n.skipAvailabilityCheck&&!Z(e,t,r))return{editorId:e.id,label:e.label,action:`skipped-missing`,configPath:o,serverName:a};let s;try{s=e.format===`toml`?Le(o):Ie(o)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}let c=s[e.topLevelKey]??{},l=c[a],u;try{u=e.buildEntry(t,n)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}let d={...s,[e.topLevelKey]:{...c,[a]:u}};try{e.format===`toml`?ze(o,d):Re(o,d)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}return{editorId:e.id,label:e.label,action:l===void 0?`written`:`overwritten`,configPath:o,serverName:a,...i===void 0?{}:{configScope:`project`}}}function Ke(e,t){let n=e.projectConfigPath?.(t);if(!(!n||!w(n)))return{editorId:e.id,label:e.label,path:n}}async function qe(e){let t=Y(e.editors),n={mode:`published`,cliPath:e.cliPath,skipAvailabilityCheck:!0};return t.map(t=>Q(t,``,n,e.home))}function Je(e,t,n){let r;try{r=e.configPath(t,n)}catch{return null}let i;try{i=e.format===`toml`?Le(r):Ie(r)}catch{return null}let a=i[e.topLevelKey];if(!c(a))return null;let o=a[e.serverName(t)];return c(o)?o:null}async function Ye(e={}){let t=x(e.cwd??process.cwd()),n={mode:e.pin?`pinned`:e.devMcp?`dev`:`published`,cliEntryPath:e.cliEntryPath},r=await
|
|
253
|
-
`)}function $(e,t){let n=[];for(let r of H)Z(J[r],e,t)&&n.push(r);return n}function Ze(){return new t(`init`).description(`Scaffold ${n}/ in the current directory and register the MCP server for your editor(s)`).option(`--mcp`,`Register the MCP server for selected editors (default: true)`,!0).option(`--no-mcp`,`Scaffold the ${n}/ directory but do not touch MCP config`).option(`--dev-mcp`,`Register a local dev MCP entry using node + packages/cli/dist/cli.mjs with debug logging`).addOption(new e(`--scope <scope>`,`Write MCP config at user level, project level, or both`).choices([`user`,`project`,`both`])).option(`--pin`,"Pin the MCP entry to the absolute path of the current CLI binary instead of `npx`. Use a stable shim like /usr/local/bin/ok for upgrade-safe pinning; npx-cache or worktree paths will go stale on reinstall.").option(`--no-pin`,"Use the default unpinned `npx @inkeep/open-knowledge mcp` MCP entry").action(async e=>{let t=process.cwd(),n;try{n=await Ye({cwd:t,mcp:e.mcp,devMcp:e.devMcp,scope:e.scope,pin:e.pin})}catch(e){if(e instanceof
|
|
254
|
-
`),e.stderr&&process.stderr.write(`${e.stderr.trim()}\n`),process.exitCode=1;return}throw e}try{let{previewContent:e}=await import(`./preview-
|
|
255
|
-
//# sourceMappingURL=init-
|
|
252
|
+
`,required:!1,theme:{icon:{checked:`[x]`,unchecked:`[ ]`}},choices:[{name:`User-level (~/.claude.json, ~/.cursor/mcp.json, …)`,value:`user`,checked:!0},{name:`Project-level (.mcp.json, .cursor/mcp.json, …)`,value:`project`,checked:!0}]});return e.includes(`user`)&&e.includes(`project`)?`both`:e.includes(`user`)?`user`:e.includes(`project`)?`project`:null}async function Ue(e){return e.mcp===!1?null:e.scope?e.scope:e.isTTY??process.stdout.isTTY?(e.promptFn??He)():`both`}const We=`0.0.1`,X=`open-knowledge-ui`;function Ge(e,t={}){let n=v(e,`.claude`,`launch.json`),r=t.mode===`dev`?{name:X,runtimeExecutable:`node`,runtimeArgs:[U(t.cliEntryPath),`ui`],port:3e3}:{name:X,runtimeExecutable:`npx`,runtimeArgs:[`@inkeep/open-knowledge`,`ui`],port:3e3};try{if(!w(n))return T(_(n),{recursive:!0}),D(n,`${JSON.stringify({version:We,configurations:[r]},null,2)}\n`,`utf-8`),{action:`created`,configPath:n};let e=E(n,`utf-8`).trim(),t=e?JSON.parse(e):{};if(!c(t))return{action:`failed`,configPath:n,error:`launch.json root is not an object`};let i=Array.isArray(t.configurations)?t.configurations:[],a=i.findIndex(e=>c(e)&&e.name===X);a>=0?i[a]=r:i.push(r);let o={...t,version:t.version??We,configurations:i};return D(n,`${JSON.stringify(o,null,2)}\n`,`utf-8`),{action:a>=0?`merged`:`created`,configPath:n}}catch(e){return{action:`failed`,configPath:n,error:e instanceof Error?e.message:String(e)}}}function Z(e,t,n){try{return w(e.detectPath?.(t,n)??_(e.configPath(t,n)))}catch{return!1}}function Q(e,t,n,r,i){let a=e.serverName(t),o;try{o=i??e.configPath(t,r)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:``,serverName:a,error:t instanceof Error?t.message:String(t)}}if(!i&&!n.skipAvailabilityCheck&&!Z(e,t,r))return{editorId:e.id,label:e.label,action:`skipped-missing`,configPath:o,serverName:a};let s;try{s=e.format===`toml`?Le(o):Ie(o)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}let c=s[e.topLevelKey]??{},l=c[a],u;try{u=e.buildEntry(t,n)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}let d={...s,[e.topLevelKey]:{...c,[a]:u}};try{e.format===`toml`?ze(o,d):Re(o,d)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:o,serverName:a,error:t instanceof Error?t.message:String(t)}}return{editorId:e.id,label:e.label,action:l===void 0?`written`:`overwritten`,configPath:o,serverName:a,...i===void 0?{}:{configScope:`project`}}}function Ke(e,t){let n=e.projectConfigPath?.(t);if(!(!n||!w(n)))return{editorId:e.id,label:e.label,path:n}}async function qe(e){let t=Y(e.editors),n={mode:`published`,cliPath:e.cliPath,skipAvailabilityCheck:!0};return t.map(t=>Q(t,``,n,e.home))}function Je(e,t,n){let r;try{r=e.configPath(t,n)}catch{return null}let i;try{i=e.format===`toml`?Le(r):Ie(r)}catch{return null}let a=i[e.topLevelKey];if(!c(a))return null;let o=a[e.serverName(t)];return c(o)?o:null}async function Ye(e={}){let t=x(e.cwd??process.cwd()),n={mode:e.pin?`pinned`:e.devMcp?`dev`:`published`,cliEntryPath:e.cliEntryPath},r=await o(t),a;try{a=l(t)}catch(n){let i=J.claude.configPath(t,e.home);return{contentCreated:[],contentUpdated:[],contentSkipped:[],editors:[],legacyProjectConfigs:[],didGitInit:r.didInit,claudeDesktopDetected:!1,mcpAction:`failed`,mcpPath:i,mcpError:`Content scaffolding failed: ${n instanceof Error?n.message:String(n)}`}}let c=await Ue({scope:e.scope,mcp:e.mcp,isTTY:e.isTTY,promptFn:e.promptFn}),u=e.editors??$(t,e.home),d=e.editors??H.filter(e=>J[e].projectConfigPath!==void 0),f=Y(u),p=Y(d),m=e.mcp===!1||c===null,h=Array.from(new Map([...f,...m?[]:p].map(e=>[e.id,e])).values()),g=f.filter(n=>Z(n,t,e.home)),_=[],v=new Set;for(let r of h){if(m){let n=``;try{n=r.configPath(t,e.home)}catch{}_.push({editorId:r.id,label:r.label,action:`skipped-flag`,configPath:n,serverName:r.serverName(t)});continue}if(Be(c)&&f.includes(r)&&_.push(Q(r,t,n,e.home)),Ve(c)&&p.includes(r)&&r.projectConfigPath){let i=r.projectConfigPath(t),a=Q(r,t,n,e.home,i);_.push(a),(a.action===`written`||a.action===`overwritten`)&&v.add(i)}}let y=!m&&c!==null&&Ve(c)?p.filter(e=>!e.projectConfigPath).map(e=>e.label):void 0,b=m?[]:g.map(e=>Ke(e,t)).filter(e=>e!==void 0).filter(e=>!v.has(e.path)),S=g.some(e=>e.id===`claude`)&&!m?Ge(t,n):void 0,C=await(e.installUserSkill??s)({home:e.home}),w=i({home:e.home}),T=m?`skipped-flag`:`skipped-missing`,E=_.find(e=>e.editorId===`claude`)??_[0]??{action:T,configPath:J.claude.configPath(t,e.home)};return{contentCreated:a.created,contentUpdated:a.updated,contentSkipped:a.skipped,editors:_,legacyProjectConfigs:b,launchJson:S,skillInstall:C,didGitInit:r.didInit,claudeDesktopDetected:w,mcpAction:E.action,mcpPath:E.configPath,mcpError:`error`in E?E.error:void 0,projectScopeUnsupportedLabels:y}}function Xe(e,t){let r=[],i=e.editors.some(e=>e.action===`written`||e.action===`overwritten`),a=e.editors.some(e=>e.action===`failed`),o=e.editors.length>0&&e.editors.every(e=>e.action===`skipped-flag`),s=e.editors.length>0&&e.editors.every(e=>e.action===`skipped-missing`),c=e=>{let n=e.configPath.startsWith(t)?b(t,e.configPath):e.configPath;switch(e.action){case`created`:return` app preview server ${n} configured for Claude Code Desktop embedded browser`;case`merged`:return` app preview server ${n} updated for Claude Code Desktop embedded browser`;case`failed`:return` app preview server ${n} FAILED: ${e.error}`}};e.didGitInit&&r.push(`Initialized git repo at ${t}/.git/ (default branch: main)`);let l=v(t,n);if(e.contentCreated.length>0||e.contentUpdated.length>0?(r.push(h(`Content scaffolded at ${l}/`)),e.contentCreated.length>0&&r.push(` Created: ${e.contentCreated.join(`, `)}`),e.contentUpdated.length>0&&r.push(` Updated: ${e.contentUpdated.join(`, `)}`)):r.push(h(`Content already present at ${l}/`)),e.contentSkipped.length>0&&r.push(` Skipped (already exist): ${e.contentSkipped.join(`, `)}`),r.push(``),e.mcpError&&e.editors.length===0)r.push(`Warning: ${e.mcpError}`);else if(e.editors.length===0)if(r.push(h(`MCP server configuration:`)),e.mcpAction===`skipped-flag`)r.push(` MCP config not written — use without --no-mcp to configure editors`);else if(e.projectScopeUnsupportedLabels&&e.projectScopeUnsupportedLabels.length>0){let t=e.projectScopeUnsupportedLabels.join(`, `),n=e.projectScopeUnsupportedLabels.length===1?`does`:`do`;r.push(` ${t} ${n} not support project-level config; skipped`)}else r.push(` No supported editor config directories detected; skipped MCP registration`);else if(o)r.push(`MCP config not written — use without --no-mcp to configure editors`);else if(s)r.push(h(`MCP server configuration:`)),r.push(` No supported editor config directories detected; skipped MCP registration`);else{r.push(h(`MCP server configuration:`));for(let n of e.editors){let i=n.configPath.startsWith(t)?b(t,n.configPath):n.configPath.replace(/^\/Users\/[^/]+/,`~`),a=n.serverName===`open-knowledge`?``:` (${n.serverName})`,o=n.configScope===`project`?` (project)`:``,s=`${n.label}${o}`,l=` `.repeat(Math.max(1,20-s.length)),u=n.editorId===`claude-desktop`&&(n.action===`written`||n.action===`overwritten`)?` — quit and relaunch Claude Desktop to activate`:``;switch(n.action){case`written`:r.push(` ${s}${l}${i} ${f(`registered`)}${a}${u}`);break;case`overwritten`:r.push(` ${s}${l}${i} ${f(`updated`)}${a}${u}`);break;case`skipped-missing`:r.push(` ${s}${l}${i} config root missing; skipped`);break;case`failed`:r.push(` ${s}${l}${i} ${p(`FAILED`)}: ${n.error}`);break;case`skipped-flag`:break}n.editorId===`claude`&&e.launchJson&&r.push(c(e.launchJson))}if(e.projectScopeUnsupportedLabels&&e.projectScopeUnsupportedLabels.length>0){let t=e.projectScopeUnsupportedLabels.join(`, `),n=e.projectScopeUnsupportedLabels.length===1?`does`:`do`;r.push(` ${t} ${n} not support project-level config; skipped`)}}if(a&&(r.push(``),r.push(`For failed editors, add the MCP server entry manually. See:`),r.push(` https://github.com/inkeep/open-knowledge#mcp-setup`)),e.legacyProjectConfigs.length>0){r.push(``),r.push(`Project MCP configs found:`);for(let n of e.legacyProjectConfigs)r.push(` ${n.label} ${b(t,n.path)}`);r.push(` These project-local files may override the global config. Remove them if you want fully user-scoped MCP setup in this project.`)}if(e.skillInstall)switch(r.push(``),r.push(h(`User-global skill:`)),e.skillInstall){case`installed`:r.push(` open-knowledge ${f(`installed to detected agent hosts`)} via \`npx skills\``);break;case`skip-current`:r.push(` open-knowledge ${f(`already installed at current version`)}`);break;case`failed`:r.push(` ${m(`open-knowledge install failed — MCP still configured; run manually:`)}`),r.push(` ${m(` npx skills@~1.5.0 add <bundled-path> --agent '*' -g -y --copy`)}`);break}if(e.claudeDesktopDetected&&(r.push(``),r.push(`Claude Desktop App detected. To enable in Claude Chat & Cowork, run: ${h(`ok install-skill`)}`)),e.preview?(r.push(``),r.push(u(e.preview,t))):e.previewWarning&&(r.push(``),r.push(`Content preview unavailable: ${e.previewWarning}`)),i){let t=new Set,n=e.editors.filter(e=>e.action===`written`||e.action===`overwritten`).filter(e=>!t.has(e.editorId)&&t.add(e.editorId)).map(e=>e.label);r.push(``),r.push(`${f(`✓`)} ${h(`Next steps:`)}`),r.push(` 1. Open your editor (${d(n.join(` / `))})`),r.push(` 2. Approve the MCP server when prompted`),r.push(` 3. (Optional) scaffold the starter knowledge-base structure:`),r.push(` - ${d(`ok seed`)}`),r.push(` 4. Use the three MCP workflow tools as you build the wiki:`),r.push(` - ${d(`mcp__open-knowledge__ingest`)} — capture an external source`),r.push(` - ${d(`mcp__open-knowledge__research`)} — gather sources and write findings`),r.push(` - ${d(`mcp__open-knowledge__consolidate`)} — promote research to canonical articles`)}return r.join(`
|
|
253
|
+
`)}function $(e,t){let n=[];for(let r of H)Z(J[r],e,t)&&n.push(r);return n}function Ze(){return new t(`init`).description(`Scaffold ${n}/ in the current directory and register the MCP server for your editor(s)`).option(`--mcp`,`Register the MCP server for selected editors (default: true)`,!0).option(`--no-mcp`,`Scaffold the ${n}/ directory but do not touch MCP config`).option(`--dev-mcp`,`Register a local dev MCP entry using node + packages/cli/dist/cli.mjs with debug logging`).addOption(new e(`--scope <scope>`,`Write MCP config at user level, project level, or both`).choices([`user`,`project`,`both`])).option(`--pin`,"Pin the MCP entry to the absolute path of the current CLI binary instead of `npx`. Use a stable shim like /usr/local/bin/ok for upgrade-safe pinning; npx-cache or worktree paths will go stale on reinstall.").option(`--no-pin`,"Use the default unpinned `npx @inkeep/open-knowledge mcp` MCP entry").action(async e=>{let t=process.cwd(),n;try{n=await Ye({cwd:t,mcp:e.mcp,devMcp:e.devMcp,scope:e.scope,pin:e.pin})}catch(e){if(e instanceof a){process.stderr.write(`open-knowledge requires git to initialize a parent repo. Install git or run 'git init' yourself, then re-run.
|
|
254
|
+
`),e.stderr&&process.stderr.write(`${e.stderr.trim()}\n`),process.exitCode=1;return}throw e}try{let{previewContent:e}=await import(`./preview-BbFOb5YQ.mjs`),{loadConfig:r}=await import(`./loader-C5AIUzdN.mjs`),{resolveContentDir:i}=await import(`./paths-C5pgWwxG.mjs`),{config:a}=r(t),o=i(a,t);n.preview=e({projectDir:t,contentDir:o,include:a.content.include,exclude:a.content.exclude})}catch(e){n.previewWarning=e instanceof Error?e.message:String(e)}process.stdout.write(`${Xe(n,t)}\n`),(n.editors.some(e=>e.action===`failed`)||n.mcpAction===`failed`)&&(process.exitCode=1)})}export{Ue as a,qe as c,Je as i,H as l,Xe as n,Ye as o,Ze as r,Q as s,$ as t,J as u};
|
|
255
|
+
//# sourceMappingURL=init-BUnpt_ZF.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./init-tG0EK1Je.mjs";export{e as initContent};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{$ as e,X as t}from"./dist-Bk22-nn7.mjs";import{i as n,n as r,t as i}from"./constants-
|
|
1
|
+
import{$ as e,X as t}from"./dist-Bk22-nn7.mjs";import{i as n,n as r,t as i}from"./constants-Csaa4YGL.mjs";import{join as a,resolve as o}from"node:path";import{existsSync as s,mkdirSync as c,readFileSync as l,writeFileSync as u}from"node:fs";function d(n){return`# yaml-language-server: $schema=https://unpkg.com/@inkeep/open-knowledge@latest/dist/schemas/${t}/config.project.schema.json
|
|
2
2
|
# Open Knowledge — project configuration
|
|
3
3
|
#
|
|
4
4
|
# This file overrides built-in defaults for this project. Every key below
|
|
@@ -141,4 +141,4 @@ state.json
|
|
|
141
141
|
# MCP spawn diagnostics
|
|
142
142
|
last-spawn-error.log
|
|
143
143
|
`;function h(t){let s=o(t,e),l=[],u=[],h=[];c(s,{recursive:!0}),c(a(s,i),{recursive:!0});let g=p(a(s,`.gitignore`),m);return g===`created`?l.push(`.gitignore`):g===`updated`?u.push(`.gitignore`):h.push(`.gitignore`),f(a(s,`config.yml`),d(n))?l.push(r):h.push(r),{created:l,updated:u,skipped:h}}export{h as n,d as t};
|
|
144
|
-
//# sourceMappingURL=init-
|
|
144
|
+
//# sourceMappingURL=init-tG0EK1Je.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./loader-CZE2QlA_.mjs";export{e as loadConfig};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{$ as e,F as t,Rt as n,Z as r,nt as i}from"./dist-Bk22-nn7.mjs";import{n as a}from"./constants-
|
|
2
|
-
//# sourceMappingURL=loader-
|
|
1
|
+
import{$ as e,F as t,Rt as n,Z as r,nt as i}from"./dist-Bk22-nn7.mjs";import{n as a}from"./constants-Csaa4YGL.mjs";import{r as o}from"./server-CYax-BjV.mjs";import{t as s}from"./is-object-CEU0BgQ5.mjs";import{resolve as c}from"node:path";import{existsSync as l,readFileSync as u}from"node:fs";import{homedir as d}from"node:os";import{realpath as f}from"node:fs/promises";async function p(e){let t=c(e);try{return await f(t)}catch(e){if(e.code!==`ENOENT`){let n=e instanceof Error?e.message:String(e);console.warn(`[normalize-cwd] realpath failed for ${t}: ${n}`)}return t}}const m=r;var h=n();function g(e,t){let n={...e};for(let r of Object.keys(t)){let i=e[r],a=t[r];s(a)&&s(i)?n[r]=g(i,a):a!==void 0&&(n[r]=a)}return n}function _(e){if(!l(e))return{value:null,path:e,source:null,doc:null};let t;try{t=u(e,`utf-8`)}catch(t){return console.warn(`[config] Failed to read ${e}: ${t instanceof Error?t.message:t}`),{value:null,path:e,source:null,doc:null}}let n=(0,h.parseDocument)(t);if(n.errors.length>0)return console.warn(`[config] Failed to parse ${e}: ${n.errors.map(e=>e.message).join(`; `)}`),{value:null,path:e,source:t,doc:null};let r=n.toJSON();return s(r)?{value:r,path:e,source:t,doc:n}:{value:null,path:e,source:t,doc:n}}function v(e,t){return e.map(e=>{let n=e.path.map(e=>typeof e==`symbol`?String(e):e),r={path:n,message:e.message,issueCode:e.code};if(t.doc!==null&&t.source!==null){let e=i({file:t.path,source:t.source,doc:t.doc,path:n});if(e!==void 0)return{...r,source:e}}return r})}function y(n){let r=n??process.cwd(),i=[],l=c(d(),e,a),u=o({absPath:l}),f={};u.valid&&u.source!==void 0?(f=g(f,u.value),i.push(l)):u.valid;let p=c(r,e,a),h=_(p);h.value!==null&&(f=g(f,h.value),i.push(p));let y=f.upload;s(y)&&y.maxBytes!==void 0&&console.warn(`[config] upload.maxBytes is deprecated and ignored — streaming uploads have no user-facing cap. Remove the key to silence this warning.`);let b=m.safeParse(f);if(!b.success){let e={code:`SCHEMA_INVALID`,issues:v(b.error.issues,h)};throw Error(t(e))}return{config:b.data,sources:i}}function b(e,t=process.env){let n=e;return t.HOST&&(n={...n,server:{...n.server,host:t.HOST}}),n}function x(e){let t=e.env??process.env,n=e.cacheMs??1e3,r=e.loadConfigFn??y,i=new Map,a=new Map,o=p(e.startupCwd);return async s=>{let c=await p(s??e.startupCwd),l=Date.now(),u=i.get(c);if(u&&u.expiresAt>l)return u.config;let d=a.get(c);if(d)return await d;let f=(async()=>{if(c===await o){let r=b(e.startupConfig,t);return i.set(c,{config:r,expiresAt:Date.now()+n}),r}let a=b(r(c).config,t);return i.set(c,{config:a,expiresAt:Date.now()+n}),a})();a.set(c,f);try{return await f}finally{a.delete(c)}}}export{p as i,y as n,m as r,x as t};
|
|
2
|
+
//# sourceMappingURL=loader-CZE2QlA_.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e,t}from"./paths-DfmL-9oM.mjs";export{t as resolveContentDir,e as resolveLockDir};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e,t}from"./preview-BlPt157K.mjs";export{t as formatPreviewBlock,e as previewContent};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{$ as e}from"./dist-Bk22-nn7.mjs";import"./constants-
|
|
1
|
+
import{$ as e}from"./dist-Bk22-nn7.mjs";import"./constants-Csaa4YGL.mjs";import{q as t}from"./dist-C8iO0ddp.mjs";import{join as n,relative as r}from"node:path";import{existsSync as i,lstatSync as a,readdirSync as o,realpathSync as s,statSync as c}from"node:fs";function l(e){let{projectDir:i,contentDir:l,include:u,exclude:d,sampleCap:f=5}=e,p=[],m=[];try{a(l)}catch(e){return{totalCount:0,sample:[],contentDir:l,include:u,exclude:d,warnings:[`cannot access content directory ${l}: ${e instanceof Error?e.message:String(e)}`]}}let h;try{h=t({projectDir:i,contentDir:l,includePatterns:u,excludePatterns:d})}catch(e){return{totalCount:0,sample:[],contentDir:l,include:u,exclude:d,warnings:[e instanceof Error?e.message:String(e)]}}function g(e){let t;try{t=o(e,{withFileTypes:!0})}catch(t){let n=t instanceof Error?t.message:String(t);p.push(`could not read directory ${r(l,e)||`.`}: ${n}`);return}for(let i of t){let t=n(e,i.name);if(i.isSymbolicLink()){let e;try{e=s(t)}catch(e){let n=e.code;n===`ENOENT`||n===`ELOOP`?p.push(`broken or cyclic symlink: ${r(l,t)}`):p.push(`cannot resolve symlink ${r(l,t)}: ${n??`unknown error`}`);continue}let n;try{n=c(e)}catch{continue}if(n.isDirectory()){let e=r(l,t);if(h.isDirExcluded(e))continue;g(t)}else if(n.isFile()){let e=r(l,t);if(h.isExcluded(e))continue;m.push(e)}}else if(i.isDirectory()){let e=r(l,t);if(h.isDirExcluded(e))continue;g(t)}else if(i.isFile()){let e=r(l,t);if(h.isExcluded(e))continue;m.push(e)}}}return g(l),{totalCount:m.length,sample:m.slice(0,f),contentDir:l,include:u,exclude:d,warnings:p}}function u(t,a){let o=[],s=r(a,t.contentDir),c=s===``?`./`:`./${s}`;o.push(`Content:`),o.push(` Found ${t.totalCount} markdown files in ${c}`);let l=t.include.join(`, `),u=t.exclude.length>0?t.exclude.join(`, `):`(none)`;if(o.push(` Scope: include=${l} exclude=${u}`),t.sample.length>0){let e=t.sample.join(`, `),n=t.totalCount>t.sample.length?`, …`:``;o.push(` Sample: ${e}${n}`)}if(t.warnings.length>0)for(let e of t.warnings)o.push(` Warning: ${e}`);return o.push(``),i(n(a,`.open-knowledge`,`config.yml`))?(o.push(` To adjust, edit ${e}/config.yml:`),o.push(` content:`),o.push(` include: ${JSON.stringify(t.include)}`),o.push(` exclude: ${JSON.stringify(t.exclude)}`)):(o.push(" Run `open-knowledge init` to scaffold config, then adjust:"),o.push(` ${e}/config.yml → content.include / content.exclude`)),o.push(``),o.push(` Re-check anytime: open-knowledge preview`),o.join(`
|
|
2
2
|
`)}export{l as n,u as t};
|
|
3
|
-
//# sourceMappingURL=preview-
|
|
3
|
+
//# sourceMappingURL=preview-BlPt157K.mjs.map
|