@inkeep/open-knowledge 0.0.0-dev-20260421192027 → 0.0.0-dev-20260422092332
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 +9 -9
- package/dist/constants-DigVOZ9o.mjs +2 -0
- package/dist/index.mjs +1 -1
- package/dist/init-BPHczY2k.mjs +6 -0
- package/dist/{init-DeoOI04P.mjs → init-DiUw5TDX.mjs} +2 -2
- package/dist/{init-CyxGRu4t.mjs → init-EiMNbiMk.mjs} +1 -1
- package/dist/init-bL3p670c.mjs +1 -0
- package/dist/{loader-BNuhNFOT.mjs → loader-BOYrnnNP.mjs} +2 -2
- package/dist/loader-CecgSwbH.mjs +1 -0
- package/dist/paths-8lEuqzzC.mjs +1 -0
- package/dist/paths-Ub0bMbwu.mjs +2 -0
- package/dist/preview-CCBPkWf0.mjs +1 -0
- package/dist/{preview-oS_HbHIz.mjs → preview-DlFxxSWj.mjs} +2 -2
- package/dist/public/assets/index-DVyr5aVx.css +1 -0
- package/dist/public/assets/index-e4QpKJH0.js +381 -0
- package/dist/public/index.html +2 -2
- package/dist/{src-ViJPkmPW.mjs → src-CdcLi3q2.mjs} +8 -8
- package/dist/{src-DcVg7_6f.mjs → src-Cgk_X3wh.mjs} +51 -54
- package/dist/src-DYjDx2Br.mjs +1 -0
- package/dist/src-Dh_UJnt4.mjs +1 -0
- package/dist/start-BocQMsT6.mjs +1 -0
- package/dist/start-D6ddaQ_D.mjs +2 -0
- package/package.json +1 -1
- package/dist/constants-BLW6shM6.mjs +0 -2
- package/dist/init-B6g8iwyX.mjs +0 -1
- package/dist/init-WENor_lZ.mjs +0 -5
- package/dist/loader-bM_eCxHL.mjs +0 -1
- package/dist/paths-DxI4FHOZ.mjs +0 -2
- package/dist/paths-xS3o7pK2.mjs +0 -1
- package/dist/preview-BGOwfgOL.mjs +0 -1
- package/dist/public/assets/index-BqGPiKcl.js +0 -381
- package/dist/public/assets/index-DfpTuEYh.css +0 -1
- package/dist/src-D9A_jCdV.mjs +0 -1
- package/dist/src-NsJfsnSl.mjs +0 -1
- package/dist/start-BPpXybFr.mjs +0 -1
- package/dist/start-CNULXoun.mjs +0 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./loader-BOYrnnNP.mjs";export{};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./src-CdcLi3q2.mjs";import{$ as e,Q as t,X as n,Z as r,et as i,n as a,pt as o,r as s,t as c}from"./src-Cgk_X3wh.mjs";import{f as l,r as u}from"./server-lock-B4frNnOB.mjs";export{c as ProjectGitInitError,n as UiLockCollisionError,r as acquireUiLock,s as bootServer,a as ensureProjectGit,o as getLogger,l as isProcessAlive,u as readServerLock,t as readUiLock,e as releaseUiLock,i as updateUiLockPort};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as e}from"./start-D6ddaQ_D.mjs";export{e as startCommand};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a as e}from"./constants-DigVOZ9o.mjs";import{D as t}from"./src-CdcLi3q2.mjs";import{Command as n}from"commander";import{closeSync as r,existsSync as i,mkdirSync as a,openSync as o}from"node:fs";import{join as s}from"node:path";import{spawn as c}from"node:child_process";function l(){let e=process.execPath,t=process.argv[1];return t?{command:e,prefixArgs:[t]}:(console.warn(`[self-spawn] process.argv[1] is empty — falling back to \`npx @inkeep/open-knowledge\`. This re-introduces the version-drift surface that re-exec was fixing. Observed argv: ${JSON.stringify(process.argv)}`),{command:`npx`,prefixArgs:[`@inkeep/open-knowledge`]})}function u(e){return e.uiLock?e.isAlive(e.uiLock.pid)?{action:`skip`,reason:`alive`,pid:e.uiLock.pid,port:e.uiLock.port}:{action:`spawn`,reason:`stale`,stalePid:e.uiLock.pid}:{action:`spawn`,reason:`absent`}}function d(e){i(e.lockDir)||a(e.lockDir,{recursive:!0});let t=o(s(e.lockDir,`last-spawn-error.log`),`w`),n=e.spawn??c,{PORT:u,...d}=process.env,f=l();try{let r=n(f.command,[...f.prefixArgs,...e.args??[`ui`]],{detached:!0,stdio:[`ignore`,`ignore`,t],cwd:e.cwd,env:d});return r.unref(),r}finally{try{r(t)}catch{}}}function f(e){let t=e.sigtermGraceMs??1e4,n=e.sigtermPollIntervalMs??200,r=e.sleep??(e=>new Promise(t=>setTimeout(t,e)));return async()=>{try{let i=e.readUiLock();if(i&&e.isAlive(i.pid))try{e.killPid(i.pid,`SIGTERM`),e.log?.info({pid:i.pid,port:i.port},`idle-shutdown: SIGTERM UI sibling`);let a=Date.now()+t;for(;Date.now()<a&&e.isAlive(i.pid);)await r(n);if(e.isAlive(i.pid))try{e.killPid(i.pid,`SIGKILL`),e.log?.warn({pid:i.pid,graceMs:t},`idle-shutdown: SIGTERM grace expired — escalated to SIGKILL`)}catch(t){e.log?.error({pid:i.pid,err:t instanceof Error?t.message:String(t)},`idle-shutdown: SIGKILL failed`)}}catch(t){e.log?.warn({pid:i.pid,err:t instanceof Error?t.message:String(t)},`idle-shutdown: failed to SIGTERM UI sibling`)}}catch(t){e.log?.warn({err:t instanceof Error?t.message:String(t)},`idle-shutdown: UI lookup failed; proceeding with destroy`)}await e.destroy()}}async function p(e){let{config:n,cwd:r}=e,i=e.skipAutoInit??!1,a=e.skipUiAutoSpawn??!1,o=e.idleThresholdMs??18e5,{existsSync:s,mkdirSync:c}=await import(`node:fs`),{resolve:l}=await import(`node:path`),{bootServer:p,ensureProjectGit:m,getLogger:h,isProcessAlive:g,readUiLock:_}=await import(`./src-Dh_UJnt4.mjs`),{resolveContentDir:v}=await import(`./paths-8lEuqzzC.mjs`),y=e.log??h(`start`),b=v(n,r);s(b)||(c(b,{recursive:!0}),y.info({contentDir:b},`Created content directory`));let x=!s(l(r,t)),S=i?void 0:async()=>{try{let{initContent:e}=await import(`./init-EiMNbiMk.mjs`),t=e(r);return x||t.created.length>0}catch(e){return console.warn(`Auto-init failed:`,e instanceof Error?e.message:e),!1}},C=!1,w=l(b,t),T=n.server.openOnAgentEdit?()=>{if(C)return;let e=_(w);if(!e||e.port<=0||!g(e.pid))return;C=!0;let t=`http://localhost:${e.port}`;import(`./open-browser-CfwaLBtR.mjs`).then(({openBrowser:e})=>e(t)).catch(()=>{})}:void 0,E=null,D=await p({contentDir:b,projectDir:r,contentRoot:n.content.dir,port:n.server.port,host:n.server.host,quiet:!1,debounce:n.persistence.debounceMs,maxDebounce:n.persistence.maxDebounceMs,includePatterns:n.content.include,excludePatterns:n.content.exclude,onAgentWrite:T,localOpCliArgs:[process.execPath,process.argv[1]],attachUiSibling:!0,idleShutdownMs:o,skipAutoInit:i,autoInitFn:S,ensureProjectGitFn:i?void 0:()=>m(r),spawnUiSiblingFn:async({lockDir:t})=>{if(E=u({uiLock:_(t),isAlive:g}),E.action===`spawn`&&!a)try{d({lockDir:t,cwd:r,spawn:e.spawn}),y.info({reason:E.reason},`[start] auto-spawned ok ui sibling`)}catch(e){console.warn(`[start] failed to auto-spawn ok ui: ${e instanceof Error?e.message:String(e)}`)}else E.action===`skip`&&y.info({port:E.port,pid:E.pid},`UI already running at port ${E.port}`)},idleShutdownHandler:e=>f({readUiLock:()=>_(D.lockDir),isAlive:g,killPid:(e,t)=>{process.kill(e,t)},destroy:e,log:y}),log:y});return E||={action:`skip`,reason:`alive`,pid:0,port:0},{httpServer:D.httpServer,destroy:D.destroy,lockDir:D.lockDir,contentDir:b,port:D.port,ready:D.ready,degraded:D.degraded,uiSpawnDecision:E,didAutoInit:D.didAutoInit,didGitInit:D.didGitInit}}function m(r){return new n(`start`).description(`Start the knowledge base collab server`).option(`-p, --port <port>`,`Server port`,void 0).option(`-H, --host <host>`,`Server host`,void 0).option(`--open`,`Open browser after start`).option(`--no-init`,`Skip auto-scaffolding of ${t}/`).action(async n=>{let{renderBanner:i}=await import(`./banner-sRCRfb7A.mjs`),{dim:a,error:o,info:s,warning:c}=await import(`./colors-BNRrOlZZ.mjs`),l=r(),u=process.cwd();n.port!==void 0&&(l.server.port=Number(n.port)),n.host!==void 0&&(l.server.host=n.host);let d;try{d=await p({config:l,cwd:u,skipAutoInit:n.init===!1})}catch(e){let{ProjectGitInitError:t}=await import(`./src-Dh_UJnt4.mjs`);e instanceof t&&(console.error(o(`open-knowledge requires git to initialize a parent repo. Install git or run 'git init' yourself, then re-run.`)),e.stderr&&console.error(a(e.stderr.trim())),process.exit(1)),console.error(`${o(`Failed to start:`)} ${e instanceof Error?e.stack??e.message:String(e)}`),process.exit(1)}let f=!1,m=async e=>{if(!f){f=!0,console.log(a(`\nShutting down (${e})...`));try{await d.destroy()}catch(e){console.error(`${o(`destroy() failed:`)} ${e instanceof Error?e.stack??e.message:String(e)}`),process.exitCode=1}process.exit(process.exitCode??0)}};process.once(`SIGINT`,()=>{m(`SIGINT`)}),process.once(`SIGTERM`,()=>{m(`SIGTERM`)});let h=`http://${l.server.host}:${d.port}`,g=l.server.host===`0.0.0.0`||l.server.host===`::`?`http://0.0.0.0:${d.port}`:void 0,_=d.uiSpawnDecision,v=_.action===`skip`?_.port:3e3,y=v>0?`http://${l.server.host}:${v}`:h;console.log(i({name:`open-knowledge`,version:e,localUrl:y,apiUrl:y===h?void 0:h,networkUrl:g})),d.didAutoInit&&(console.log(` ${s(`✓`)} Scaffolded ${t}/ (first run)`),console.log(` ${a("Tip: Run `open-knowledge init` to register MCP tools for Claude Code")}\n`));let b={"shadow-repo":`Version history and branch-switch safety unavailable`,"file-watcher":`External file changes will not sync to the editor`,"head-watcher":`Git branch switches may cause document inconsistency`};d.ready.then(async()=>{if(d.degraded.length>0){console.log();for(let e of d.degraded){let t=b[e]??`${e} (check server logs for details)`;console.warn(` ${c(`⚠`)} ${c(e)}: ${a(t)}`)}console.log()}if(d.didAutoInit||d.didGitInit)if(d.didGitInit&&console.log(`\n ${s(`✓`)} Initialized git repo at ${u}/.git/ (default branch: main)`),d.didAutoInit)try{let{previewContent:e,formatPreviewBlock:t}=await import(`./preview-CCBPkWf0.mjs`),n=e({projectDir:u,contentDir:d.contentDir,include:l.content.include,exclude:l.content.exclude});console.log(`\n${t(n,u)}\n`)}catch(e){console.warn(`Content preview unavailable: ${e instanceof Error?e.message:String(e)}`)}else console.log();if(n.open){let{openBrowser:e}=await import(`./open-browser-CfwaLBtR.mjs`);e(y)}}).catch(e=>{console.error(` ${o(`Server initialization failed:`)} ${e instanceof Error?e.message:String(e)}`)})})}export{m as a,d as i,f as n,l as o,u as r,p as t};
|
|
2
|
+
//# sourceMappingURL=start-D6ddaQ_D.mjs.map
|
package/package.json
CHANGED
package/dist/init-B6g8iwyX.mjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{a as e,i as t,n,r,t as i}from"./init-WENor_lZ.mjs";export{i as detectInstalledEditors,n as formatInitResult,r as initCommand,t as parseEditorFlag,e as runInit};
|
package/dist/init-WENor_lZ.mjs
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import{i as e}from"./constants-BLW6shM6.mjs";import{D as t}from"./src-ViJPkmPW.mjs";import{o as n,s as r}from"./init-DeoOI04P.mjs";import{t as i}from"./preview-oS_HbHIz.mjs";import{o as a}from"./colors-CoV_NlQL.mjs";import{t as o}from"./is-object-B4GcZahG.mjs";import{Command as s}from"commander";import{existsSync as c,mkdirSync as l,readFileSync as u,writeFileSync as d}from"node:fs";import{homedir as f}from"node:os";import{basename as p,dirname as m,isAbsolute as h,join as g,posix as _,relative as v,resolve as y,sep as b,win32 as x}from"node:path";import{parse as ee,stringify as S}from"smol-toml";const C=[`claude`,`claude-desktop`,`cursor`,`vscode`,`windsurf`,`codex`],w=[`@inkeep/open-knowledge`,`mcp`],T={MCP_DEBUG:`1`,OK_LOG_FILE:`/tmp/ok-mcp.log`};function E(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=y(e);if(p(t)===`cli.mjs`&&p(m(t))===`dist`)return t;let n=t.split(b),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 g(i.length===0?b:i.join(b),`packages`,`cli`,`dist`,`cli.mjs`)}function D(e={}){return e.mode===`dev`?{command:`node`,args:[E(e.cliEntryPath),`mcp`],env:{...T}}:{command:`npx`,args:[...w]}}function O(e){return e===`win32`?x:_}function k(e={}){let t=e.platformName??process.platform,n=e.home??f(),r=e.env??process.env,i=O(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 te(e={}){let t=e.platformName??process.platform,n=e.home??f();return O(t).join(n,`.claude.json`)}function A(e={}){let t=e.platformName??process.platform,n=e.home??f(),r=e.env??process.env;if(t===`darwin`)return _.join(n,`Library`,`Application Support`,`Claude`,`claude_desktop_config.json`);if(t===`win32`){let e=r.APPDATA??x.join(n,`AppData`,`Roaming`);return x.join(e,`Claude`,`claude_desktop_config.json`)}throw Error(`Claude Desktop is not available on ${t}. Supported: macOS, Windows.`)}function j(e={}){let t=e.platformName??process.platform,n=e.home??f();return O(t).join(n,`.cursor`,`mcp.json`)}function M(e={}){return O(e.platformName??process.platform).join(k(e),`Code`,`User`,`mcp.json`)}function N(e={}){let t=e.platformName??process.platform,n=e.home??f();return O(t).join(n,`.codeium`,`windsurf`,`mcp_config.json`)}function P(e={}){let t=e.platformName??process.platform,n=e.home??f();return(e.env??process.env).CODEX_HOME??O(t).join(n,`.codex`)}function F(e={}){return O(e.platformName??process.platform).join(P(e),`config.toml`)}function I(e,t){if(e===t)return!0;if(Array.isArray(e)&&Array.isArray(t))return e.length===t.length&&e.every((e,n)=>I(e,t[n]));if(o(e)&&o(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=>I(e[n],t[n]))}return!1}function ne(e,t){return Object.entries(t).every(([t,n])=>I(e[t],n))}function re(e,t){return{...e,...t}}function L(e){return{...e,isCompatible(t,n,r){return ne(t,e.buildEntry(n,r))},mergeManagedFields(t,n,r){return re(t,e.buildEntry(n,r))}}}const R={claude:L({id:`claude`,label:`Claude Code`,configPath:(e,t)=>te({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>e,buildEntry:(e,t)=>D(t),scope:`global`,detectPath:(e,t)=>g(t??f(),`.claude`),legacyProjectConfigPath:e=>g(e,`.mcp.json`),instructionsPath:e=>g(e,`CLAUDE.md`)}),"claude-desktop":L({id:`claude-desktop`,label:`Claude Desktop`,configPath:(e,t)=>A({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>e,buildEntry:(e,t)=>D(t),scope:`global`,detectPath:(e,t)=>m(A({home:t}))}),cursor:L({id:`cursor`,label:`Cursor`,configPath:(e,t)=>j({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>e,buildEntry:(e,t)=>D(t),scope:`global`,detectPath:(e,t)=>m(j({home:t})),legacyProjectConfigPath:e=>g(e,`.cursor`,`mcp.json`)}),vscode:L({id:`vscode`,label:`VS Code`,configPath:(e,t)=>M({home:t}),format:`json`,topLevelKey:`servers`,serverName:()=>e,buildEntry:(e,t)=>({type:`stdio`,...D(t)}),scope:`global`,detectPath:(e,t)=>m(M({home:t})),legacyProjectConfigPath:e=>g(e,`.vscode`,`mcp.json`)}),windsurf:L({id:`windsurf`,label:`Windsurf`,configPath:(e,t)=>N({home:t}),format:`json`,topLevelKey:`mcpServers`,serverName:()=>e,buildEntry:(e,t)=>D(t),scope:`global`,detectPath:(e,t)=>m(N({home:t}))}),codex:L({id:`codex`,label:`Codex`,configPath:(e,t)=>F({home:t}),format:`toml`,topLevelKey:`mcp_servers`,serverName:()=>e,buildEntry:(e,t)=>D(t),scope:`global`,detectPath:(e,t)=>m(F({home:t})),legacyProjectConfigPath:e=>g(e,`.codex`,`config.toml`)})};function z(e){let t=e.filter(e=>!(e in R));if(t.length>0)throw Error(`Unknown editor(s): ${t.join(`, `)}. Valid options: ${C.join(`, `)}`);return e.map(e=>R[e])}function B(e){if(!c(e))return{};let t=u(e,`utf-8`).trim();if(t===``)return{};try{let n=JSON.parse(t);if(o(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 V(e){if(!c(e))return{};let t=u(e,`utf-8`).trim();if(t===``)return{};try{let n=ee(t);if(o(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 H(e,t){l(m(e),{recursive:!0}),d(e,`${JSON.stringify(t,null,2)}\n`,`utf-8`)}function U(e,t){l(m(e),{recursive:!0});let n=S(t);d(e,n.endsWith(`
|
|
2
|
-
`)?n:`${n}\n`,`utf-8`)}const W=`0.0.1`,G=`open-knowledge-ui`;function K(e,t){let n=[];e.runtimeExecutable!==t.runtimeExecutable&&n.push(`runtimeExecutable`);let r=e.runtimeArgs;return Array.isArray(r)&&r.length===t.runtimeArgs.length&&r.every((e,n)=>e===t.runtimeArgs[n])||n.push(`runtimeArgs`),e.port!==t.port&&n.push(`port`),n}function q(e,t,n={}){let r=g(e,`.claude`,`launch.json`),i=n.mode===`dev`,a=n.mode===`dev`?{name:G,runtimeExecutable:`node`,runtimeArgs:[E(n.cliEntryPath),`ui`],port:3e3}:{name:G,runtimeExecutable:`npx`,runtimeArgs:[`@inkeep/open-knowledge`,`ui`],port:3e3};try{if(!c(r))return l(m(r),{recursive:!0}),d(r,`${JSON.stringify({version:W,configurations:[a]},null,2)}\n`,`utf-8`),{action:`created`,configPath:r};let e=u(r,`utf-8`).trim(),n=e?JSON.parse(e):{};if(!o(n))return{action:`failed`,configPath:r,error:`launch.json root is not an object`};let s=Array.isArray(n.configurations)?n.configurations:[],f=s.findIndex(e=>o(e)&&e.name===G);if(f>=0&&!t){let e=s[f],t=K(e,a);if(t.length>0){if(!i)return{action:`skipped-stale`,configPath:r,staleFields:t}}else return{action:`skipped-existing`,configPath:r}}f>=0?s[f]=a:s.push(a);let p={...n,version:n.version??W,configurations:s};return d(r,`${JSON.stringify(p,null,2)}\n`,`utf-8`),{action:`merged`,configPath:r}}catch(e){return{action:`failed`,configPath:r,error:e instanceof Error?e.message:String(e)}}}function J(e,t,n,r,i){let a=e.serverName(t),s;try{s=e.configPath(t,i)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:``,serverName:a,error:t instanceof Error?t.message:String(t)}}let c;try{c=e.format===`toml`?V(s):B(s)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:s,serverName:a,error:t instanceof Error?t.message:String(t)}}let l=c[e.topLevelKey]??{},u=l[a],d=r.mode===`dev`,f;try{if(u!==void 0&&!n){if(o(u)&&e.isCompatible(u,t,r))return{editorId:e.id,label:e.label,action:`skipped-existing`,configPath:s,serverName:a};if(!d)return{editorId:e.id,label:e.label,action:`skipped-conflict`,configPath:s,serverName:a}}f=o(u)&&(n||d)?e.mergeManagedFields(u,t,r):e.buildEntry(t,r)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:s,serverName:a,error:t instanceof Error?t.message:String(t)}}let p={...c,[e.topLevelKey]:{...l,[a]:f}};try{e.format===`toml`?U(s,p):H(s,p)}catch(t){return{editorId:e.id,label:e.label,action:`failed`,configPath:s,serverName:a,error:t instanceof Error?t.message:String(t)}}return{editorId:e.id,label:e.label,action:u===void 0?`written`:`overwritten`,configPath:s,serverName:a}}function Y(e,t){let n=e.legacyProjectConfigPath?.(t);if(!(!n||!c(n)))return{editorId:e.id,label:e.label,path:n}}function X(e={}){let t=y(e.cwd??process.cwd()),i={mode:e.devMcp?`dev`:`published`,cliEntryPath:e.cliEntryPath},a;try{a=n(t)}catch(n){return{contentCreated:[],contentSkipped:[],editors:[],legacyProjectConfigs:[],rootInstructions:[],mcpAction:`failed`,mcpPath:R.claude.configPath(t,e.home),mcpError:`Content scaffolding failed: ${n instanceof Error?n.message:String(n)}`}}let o=e.editors??[`claude`],s=z(o),c=[];for(let n of s){if(e.mcp===!1){let r=``;try{r=n.configPath(t,e.home)}catch{}c.push({editorId:n.id,label:n.label,action:`skipped-flag`,configPath:r,serverName:n.serverName(t)});continue}c.push(J(n,t,e.force??!1,i,e.home))}let l=e.mcp===!1?[]:s.map(e=>Y(e,t)).filter(e=>e!==void 0),u=o.includes(`claude`)&&e.mcp!==!1?q(t,e.force??!1,i):void 0,d=s.map(e=>e.instructionsPath?.(t)).filter(e=>e!==void 0).map(e=>h(e)?v(t,e):e),f=e.rootInstructions===!1?[]:r(t,e.force??!1,d),p=c.find(e=>e.editorId===`claude`)??c[0]??{action:`skipped-flag`,configPath:R.claude.configPath(t,e.home)};return{contentCreated:a.created,contentSkipped:a.skipped,editors:c,legacyProjectConfigs:l,rootInstructions:f,launchJson:u,mcpAction:p.action,mcpPath:p.configPath,mcpError:`error`in p?p.error:void 0}}function Z(e,n){let r=[],o=g(n,t);if(e.contentCreated.length>0?(r.push(`Content scaffolded at ${o}/`),r.push(` Created: ${e.contentCreated.join(`, `)}`)):r.push(`Content already present at ${o}/`),e.contentSkipped.length>0&&r.push(` Skipped (already exist): ${e.contentSkipped.join(`, `)}`),r.push(``),e.editors.length===0)e.mcpError&&r.push(`Warning: ${e.mcpError}`);else{let t=e.editors.some(e=>e.action===`written`||e.action===`overwritten`),o=e.editors.some(e=>e.action===`failed`);if(e.editors.every(e=>e.action===`skipped-flag`))r.push(`MCP config not written — use without --no-mcp to configure editors`);else{r.push(`MCP server configuration:`);for(let t of e.editors){let e=t.configPath.startsWith(n)?v(n,t.configPath):t.configPath.replace(/^\/Users\/[^/]+/,`~`),i=t.serverName===`open-knowledge`?``:` (${t.serverName})`,a=` `.repeat(Math.max(1,14-t.label.length)),o=t.editorId===`claude-desktop`&&(t.action===`written`||t.action===`overwritten`)?` — quit and relaunch Claude Desktop to activate`:``;switch(t.action){case`written`:r.push(` ${t.label}${a}${e} registered${i}${o}`);break;case`overwritten`:r.push(` ${t.label}${a}${e} updated${i}${o}`);break;case`skipped-existing`:r.push(` ${t.label}${a}${e} already configured${i}`);break;case`skipped-conflict`:r.push(` ${t.label}${a}${e} managed MCP fields differ from current defaults${i}; re-run with --force to update`);break;case`failed`:r.push(` ${t.label}${a}${e} FAILED: ${t.error}`);break;case`skipped-flag`:break}}}if(o&&(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(`Legacy project MCP configs detected:`);for(let t of e.legacyProjectConfigs)r.push(` ${t.label} ${v(n,t.path)}`);r.push(` These project-local files may override the new global config. Remove them if you want fully user-scoped MCP setup in this project.`)}if(e.launchJson){let t=e.launchJson,i=t.configPath.startsWith(n)?v(n,t.configPath):t.configPath;switch(t.action){case`created`:r.push(` launch.json ${i} created (preview_start("${G}") ready)`);break;case`merged`:r.push(` launch.json ${i} merged open-knowledge entry`);break;case`skipped-existing`:r.push(` launch.json ${i} already has open-knowledge entry`);break;case`skipped-stale`:r.push(` launch.json ${i} ${a(`⚠ existing open-knowledge entry is out of date`)}`),t.staleFields&&t.staleFields.length>0&&r.push(` ${a(`${t.staleFields.join(`, `)} differ from current defaults`)}`),r.push(` ${a(`re-run with --force to update`)}`);break;case`failed`:r.push(` launch.json ${i} FAILED: ${t.error}`);break}}if(e.rootInstructions.length>0){let t=e.rootInstructions.filter(e=>e.action!==`skipped-symlink`);if(t.length>0){r.push(``),r.push(`Root instructions:`);for(let e of t){let t=e.path.startsWith(n)?v(n,e.path):e.path,i=` `.repeat(Math.max(1,14-e.file.length));switch(e.action){case`created`:r.push(` ${e.file}${i}${t} created`);break;case`appended`:r.push(` ${e.file}${i}${t} appended Open Knowledge section`);break;case`replaced`:r.push(` ${e.file}${i}${t} replaced Open Knowledge section (--force)`);break;case`skipped-existing`:r.push(` ${e.file}${i}${t} already has Open Knowledge section`);break}}}}if(e.preview?(r.push(``),r.push(i(e.preview,n))):e.previewWarning&&(r.push(``),r.push(`Content preview unavailable: ${e.previewWarning}`)),t){let t=e.editors.filter(e=>e.action===`written`||e.action===`overwritten`).map(e=>e.label);r.push(``),r.push(`Next steps:`),r.push(` 1. Open your editor (${t.join(` / `)})`),r.push(` 2. Approve the MCP server when prompted`),r.push(` 3. The knowledge base is ready — use the three workflow tools:`),r.push(` - mcp__open-knowledge__init-content — bootstrap articles from the codebase`),r.push(` - mcp__open-knowledge__ingest — capture an external source`),r.push(` - mcp__open-knowledge__research — gather sources and write findings`)}}return r.join(`
|
|
3
|
-
`)}function ie(e){switch(e){case`claude_desktop`:return`claude-desktop`;default:return e}}function Q(e){if(e===`all`)return[...C];let t=e.split(`,`).map(e=>e.trim()).map(ie);return z(t),t}function $(e,t){let n=[];for(let r of C){let i=R[r],a;try{a=i.detectPath?.(e,t)??m(i.configPath(e,t))}catch{continue}c(a)&&n.push(r)}return n}function ae(){return new s(`init`).description(`Scaffold ${t}/ 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 ${t}/ directory but do not touch MCP config`).option(`--force`,`Overwrite existing open-knowledge MCP entries (default: skip)`).option(`--dev-mcp`,`Register a local dev MCP entry using node + packages/cli/dist/cli.mjs with debug logging`).option(`--editor <editors>`,`Target editor(s): ${C.join(`, `)}, all (comma-separated) — default: all detected editors (non-TTY) / preselects detected editors (TTY)`).action(async e=>{let t=process.cwd(),n;if(e.editor)try{n=Q(e.editor)}catch(e){process.stderr.write(`${e instanceof Error?e.message:String(e)}\n`),process.exitCode=1;return}else if(e.mcp!==!1&&process.stdin.isTTY){let{multiselect:e,isCancel:r}=await import(`@clack/prompts`),i=new Set($(t));i.size===0&&process.stdout.write(`No MCP-capable editors detected — select manually, or cancel and use --editor <all|${C.join(`|`)}>.\n`);let a=await e({message:`Which tools do you use? (space to toggle, enter to confirm)`,options:C.flatMap(e=>{let n=R[e];try{let r=n.configPath(t),a=n.scope===`global`?r.replace(/^\/Users\/[^/]+/,`~`):v(t,r);return[{value:e,label:n.label,hint:a,initialValue:i.has(e)}]}catch{return[]}}),required:!0});if(r(a)){process.stdout.write(`Init cancelled.
|
|
4
|
-
`);return}n=a}else if(n=$(t),n.length===0){process.stderr.write(`No MCP-capable editors detected. Use --editor <all|${C.join(`|`)}> to force.\n`),process.exitCode=1;return}let r=X({cwd:t,mcp:e.mcp,force:e.force,devMcp:e.devMcp,editors:n});try{let{previewContent:e}=await import(`./preview-BGOwfgOL.mjs`),{loadConfig:n}=await import(`./loader-bM_eCxHL.mjs`),{resolveContentDir:i}=await import(`./paths-xS3o7pK2.mjs`),{config:a}=n(t);r.preview=e({projectDir:t,contentDir:i(a,t),include:a.content.include,exclude:a.content.exclude})}catch(e){r.previewWarning=e instanceof Error?e.message:String(e)}process.stdout.write(`${Z(r,t)}\n`),(r.editors.some(e=>e.action===`failed`)||r.mcpAction===`failed`)&&(process.exitCode=1)})}export{X as a,Q as i,Z as n,ae as r,$ as t};
|
|
5
|
-
//# sourceMappingURL=init-WENor_lZ.mjs.map
|
package/dist/loader-bM_eCxHL.mjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{n as e}from"./loader-BNuhNFOT.mjs";export{e as loadConfig};
|
package/dist/paths-DxI4FHOZ.mjs
DELETED
package/dist/paths-xS3o7pK2.mjs
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{n as e,t}from"./paths-DxI4FHOZ.mjs";export{t as resolveContentDir,e as resolveLockDir};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{n as e,t}from"./preview-oS_HbHIz.mjs";export{t as formatPreviewBlock,e as previewContent};
|