vite-plugin-opencode-assistant 1.0.0 → 1.0.2

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/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import type { Plugin } from 'vite';
2
- import { OpenCodeOptions } from './types';
2
+ import { OpenCodeOptions } from './types.js';
3
3
  /**
4
4
  * OpenCode Vite 插件
5
5
  * @param options - 插件配置选项
package/dist/index.js CHANGED
@@ -1,10 +1,13 @@
1
1
  import path from 'path';
2
2
  import fs from 'fs';
3
3
  import http from 'http';
4
- import { startOpenCodeWeb } from './web';
5
- import { injectWidget } from './injector';
6
- import { checkOpenCodeInstalled, findAvailablePort, killProcessOnPort, checkOpenCodeProcess } from './utils';
7
- import { DEFAULT_CONFIG, DEFAULT_RETRIES, RETRY_DELAY, PROCESS_KILL_DELAY, LOG_PREFIX, WIDGET_SCRIPT_PATH, CONTEXT_API_PATH, START_API_PATH, SESSIONS_API_PATH, } from './constants';
4
+ import { fileURLToPath } from 'url';
5
+ const __filename = fileURLToPath(import.meta.url);
6
+ const __dirname = path.dirname(__filename);
7
+ import { startOpenCodeWeb } from './web.js';
8
+ import { injectWidget } from './injector.js';
9
+ import { checkOpenCodeInstalled, findAvailablePort, killProcessOnPort, checkOpenCodeProcess } from './utils.js';
10
+ import { DEFAULT_CONFIG, DEFAULT_RETRIES, RETRY_DELAY, PROCESS_KILL_DELAY, LOG_PREFIX, WIDGET_SCRIPT_PATH, CONTEXT_API_PATH, START_API_PATH, SESSIONS_API_PATH, } from './constants.js';
8
11
  /**
9
12
  * OpenCode Vite 插件
10
13
  * @param options - 插件配置选项
@@ -445,4 +448,4 @@ Please install OpenCode first:
445
448
  },
446
449
  };
447
450
  }
448
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Plugin, ViteDevServer } from 'vite'\nimport { spawn, ChildProcess } from 'child_process'\nimport path from 'path'\nimport fs from 'fs'\nimport http from 'http'\nimport { startOpenCodeWeb } from './web'\nimport { injectWidget } from './injector'\nimport { checkOpenCodeInstalled, findAvailablePort, killProcessOnPort, checkOpenCodeProcess } from './utils'\nimport { OpenCodeOptions, SessionInfo, PageContext } from './types'\nimport {\n  DEFAULT_CONFIG,\n  DEFAULT_RETRIES,\n  RETRY_DELAY,\n  PROCESS_KILL_DELAY,\n  LOG_PREFIX,\n  WIDGET_SCRIPT_PATH,\n  CONTEXT_API_PATH,\n  START_API_PATH,\n  SESSIONS_API_PATH,\n} from './constants'\n\n/**\n * OpenCode Vite 插件\n * @param options - 插件配置选项\n * @returns Vite 插件实例\n * @example\n * ```ts\n * // vite.config.ts\n * import opencode from 'vite-plugin-opencode'\n *\n * export default {\n *   plugins: [\n *     opencode({\n *       webPort: 4097,\n *       position: 'bottom-right',\n *       theme: 'auto'\n *     })\n *   ]\n * }\n * ```\n */\nexport default function opencodePlugin(options: OpenCodeOptions = {}): Plugin {\n  let webProcess: ChildProcess | null = null\n  let sessionUrl: string | null = null\n  let actualWebPort: number = DEFAULT_CONFIG.webPort\n  let isStarted = false\n  let startPromise: Promise<void> | null = null\n  let pageContext: PageContext = { url: '', title: '' }\n\n  const config = { ...DEFAULT_CONFIG, ...options }\n\n  /**\n   * 输出日志（仅在 verbose 模式下）\n   */\n  function log(message: string, ...args: unknown[]): void {\n    if (config.verbose) {\n      console.log(`${LOG_PREFIX} ${message}`, ...args)\n    }\n  }\n\n  /**\n   * 输出错误日志\n   */\n  function logError(message: string, ...args: unknown[]): void {\n    console.error(`${LOG_PREFIX} ${message}`, ...args)\n  }\n\n  /**\n   * Base64 编码字符串\n   */\n  function base64Encode(str: string): string {\n    return Buffer.from(str).toString('base64')\n  }\n\n  /**\n   * 延迟执行\n   */\n  function sleep(ms: number): Promise<void> {\n    return new Promise(resolve => setTimeout(resolve, ms))\n  }\n\n  /**\n   * 创建 HTTP 请求 Promise\n   */\n  function createHttpRequest<T>(options: http.RequestOptions, body?: string): Promise<T> {\n    return new Promise((resolve, reject) => {\n      const req = http.request(options, (res) => {\n        let data = ''\n        res.on('data', chunk => data += chunk)\n        res.on('end', () => {\n          try {\n            resolve(JSON.parse(data))\n          } catch {\n            reject(new Error(`JSON parse error: ${data.substring(0, 100)}`))\n          }\n        })\n      })\n      req.on('error', reject)\n      if (body) req.write(body)\n      req.end()\n    })\n  }\n\n  /**\n   * 获取会话列表\n   */\n  async function getSessions(retries = DEFAULT_RETRIES): Promise<SessionInfo[]> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        return await createHttpRequest<SessionInfo[]>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: '/session',\n        })\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 创建新会话\n   */\n  async function createSession(retries = DEFAULT_RETRIES): Promise<SessionInfo> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        return await createHttpRequest<SessionInfo>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: '/session',\n          method: 'POST',\n        })\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 删除会话\n   */\n  async function deleteSession(sessionId: string, retries = DEFAULT_RETRIES): Promise<void> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        await createHttpRequest<void>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: `/session/${sessionId}`,\n          method: 'DELETE',\n        })\n        return\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 获取或创建会话\n   */\n  async function getOrCreateSession(): Promise<string> {\n    const projectDir = process.cwd()\n    log('Getting sessions...')\n    const sessions = await getSessions()\n    log(`Found ${sessions.length} sessions`)\n\n    const matchingSession = sessions.find(s => s.directory === projectDir)\n\n    if (matchingSession) {\n      return `http://${config.hostname}:${actualWebPort}/${base64Encode(projectDir)}/session/${matchingSession.id}`\n    }\n\n    log('Creating new session...')\n    const newSession = await createSession()\n    return `http://${config.hostname}:${actualWebPort}/${base64Encode(projectDir)}/session/${newSession.id}`\n  }\n\n  /**\n   * 设置 OpenCode 插件\n   */\n  function setupOpenCodePlugin(): string {\n    const projectDir = process.cwd()\n    const cacheDir = path.join(projectDir, 'node_modules', '.cache', 'opencode')\n    const pluginsDir = path.join(cacheDir, 'plugins')\n\n    if (!fs.existsSync(pluginsDir)) {\n      fs.mkdirSync(pluginsDir, { recursive: true })\n    }\n\n    const pluginSourcePath = path.join(__dirname, 'plugins', 'page-context.js')\n    const pluginTargetPath = path.join(pluginsDir, 'page-context.js')\n\n    if (fs.existsSync(pluginSourcePath)) {\n      fs.copyFileSync(pluginSourcePath, pluginTargetPath)\n      log(`Plugin installed to ${pluginTargetPath}`)\n    } else {\n      console.warn(`${LOG_PREFIX} Plugin source not found: ${pluginSourcePath}`)\n    }\n\n    return cacheDir\n  }\n\n  /**\n   * 启动服务\n   */\n  async function startServices(corsOrigins?: string[], contextApiUrl?: string): Promise<void> {\n    if (isStarted) return\n    if (startPromise) return startPromise\n\n    startPromise = (async () => {\n      log('Starting OpenCode services...')\n\n      if (!await checkOpenCodeInstalled()) {\n        logError(`OpenCode is not installed!\n\nPlease install OpenCode first:\n\n  # Using Homebrew (macOS)\n  brew install opencode-ai/tap/opencode\n\n  # Or using the install script\n  curl -fsSL https://opencode.ai/install | bash\n        `)\n        return\n      }\n\n      actualWebPort = await findAvailablePort(config.webPort, config.hostname)\n      if (actualWebPort !== config.webPort) {\n        log(`Port ${config.webPort} is in use, using ${actualWebPort} instead`)\n      }\n\n      const existingProcess = await checkOpenCodeProcess(actualWebPort)\n      if (existingProcess) {\n        log(`Found existing OpenCode process on port ${actualWebPort}`)\n      } else {\n        const killed = await killProcessOnPort(actualWebPort, config.hostname)\n        if (killed) {\n          log(`Killed stale process on port ${actualWebPort}`)\n          await sleep(PROCESS_KILL_DELAY)\n        }\n      }\n\n      const configDir = setupOpenCodePlugin()\n\n      if (!existingProcess) {\n        webProcess = await startOpenCodeWeb({\n          port: actualWebPort,\n          hostname: config.hostname,\n          serverUrl: '',\n          cwd: process.cwd(),\n          configDir,\n          corsOrigins,\n          contextApiUrl,\n        })\n        log(`OpenCode Web started at http://${config.hostname}:${actualWebPort}`)\n      }\n\n      try {\n        sessionUrl = await getOrCreateSession()\n        log(`Session URL: ${sessionUrl}`)\n      } catch (e) {\n        console.warn(`${LOG_PREFIX} Failed to get/create session:`, e)\n      }\n\n      isStarted = true\n    })()\n\n    return startPromise\n  }\n\n  /**\n   * 停止服务\n   */\n  async function stopServices(): Promise<void> {\n    log('Stopping OpenCode services...')\n    \n    if (webProcess) {\n      webProcess.kill('SIGTERM')\n      await new Promise<void>(resolve => {\n        webProcess?.on('exit', () => resolve())\n        setTimeout(() => {\n          webProcess?.kill('SIGKILL')\n          resolve()\n        }, 3000)\n      })\n      webProcess = null\n    }\n    \n    if (isStarted) {\n      await killProcessOnPort(actualWebPort, config.hostname)\n    }\n    \n    isStarted = false\n    startPromise = null\n  }\n\n  /**\n   * 处理上下文 API 请求\n   */\n  function handleContextRequest(req: http.IncomingMessage, res: http.ServerResponse): void {\n    res.setHeader('Content-Type', 'application/json')\n    res.setHeader('Access-Control-Allow-Origin', '*')\n    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, DELETE, OPTIONS')\n    res.setHeader('Access-Control-Allow-Headers', 'Content-Type')\n\n    if (req.method === 'OPTIONS') {\n      res.writeHead(200)\n      res.end()\n      return\n    }\n\n    if (req.method === 'GET') {\n      res.writeHead(200)\n      res.end(JSON.stringify(pageContext))\n      return\n    }\n\n    if (req.method === 'DELETE') {\n      pageContext.selectedElements = []\n      log('Selected elements cleared')\n      res.writeHead(200)\n      res.end(JSON.stringify({ success: true }))\n      return\n    }\n\n    if (req.method === 'POST') {\n      let body = ''\n      req.on('data', chunk => body += chunk)\n      req.on('end', () => {\n        try {\n          const data = JSON.parse(body)\n          pageContext = {\n            url: data.url || '',\n            title: data.title || '',\n            selectedElements: data.selectedElements || [],\n          }\n          log(`Context updated: ${pageContext.url}`, data.selectedElements?.length ? `elements: ${data.selectedElements.length}` : '')\n          res.writeHead(200)\n          res.end(JSON.stringify({ success: true }))\n        } catch {\n          res.writeHead(400)\n          res.end(JSON.stringify({ error: 'Invalid JSON' }))\n        }\n      })\n      return\n    }\n\n    res.writeHead(405)\n    res.end(JSON.stringify({ error: 'Method not allowed' }))\n  }\n\n  return {\n    name: 'vite-plugin-opencode',\n\n    async configureServer(server: ViteDevServer) {\n      if (!config.enabled) return\n\n      const vitePort = server.config.server.port || 5173\n      const viteHost = server.config.server.host || 'localhost'\n      const viteOrigin = `http://${viteHost}:${vitePort}`\n      const contextApiUrl = `http://${viteHost}:${vitePort}${CONTEXT_API_PATH}`\n\n      if (!config.lazy) {\n        await startServices([viteOrigin], contextApiUrl)\n      }\n\n      server.middlewares.use(WIDGET_SCRIPT_PATH, async (_req, res) => {\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n\n        const widgetPath = path.join(__dirname, 'client.js')\n        if (fs.existsSync(widgetPath)) {\n          res.setHeader('Content-Type', 'application/javascript')\n          res.setHeader('Access-Control-Allow-Origin', '*')\n          fs.createReadStream(widgetPath).pipe(res)\n        } else {\n          res.writeHead(404)\n          res.end('Widget script not found')\n        }\n      })\n\n      server.middlewares.use(CONTEXT_API_PATH, async (req, res) => {\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n        handleContextRequest(req as http.IncomingMessage, res)\n      })\n\n      server.middlewares.use(START_API_PATH, async (_req, res) => {\n        res.setHeader('Content-Type', 'application/json')\n        res.setHeader('Access-Control-Allow-Origin', '*')\n\n        if (config.lazy && !isStarted) {\n          try {\n            await startServices([viteOrigin], contextApiUrl)\n            res.writeHead(200)\n            res.end(JSON.stringify({ success: true, sessionUrl }))\n          } catch (e) {\n            res.writeHead(500)\n            res.end(JSON.stringify({ error: String(e) }))\n          }\n        } else {\n          res.writeHead(200)\n          res.end(JSON.stringify({ success: true, sessionUrl }))\n        }\n      })\n\n      server.middlewares.use(SESSIONS_API_PATH, async (req, res) => {\n        res.setHeader('Content-Type', 'application/json')\n        res.setHeader('Access-Control-Allow-Origin', '*')\n        res.setHeader('Access-Control-Allow-Methods', 'GET, POST, DELETE, OPTIONS')\n        res.setHeader('Access-Control-Allow-Headers', 'Content-Type')\n\n        if (req.method === 'OPTIONS') {\n          res.writeHead(200)\n          res.end()\n          return\n        }\n\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n\n        try {\n          if (req.method === 'GET') {\n            const sessions = await getSessions()\n            res.writeHead(200)\n            res.end(JSON.stringify(sessions))\n          } else if (req.method === 'POST') {\n            const newSession = await createSession()\n            res.writeHead(200)\n            res.end(JSON.stringify(newSession))\n          } else if (req.method === 'DELETE') {\n            const url = new URL(req.url || '', `http://${req.headers.host}`)\n            const sessionId = url.searchParams.get('id')\n            \n            if (!sessionId) {\n              res.writeHead(400)\n              res.end(JSON.stringify({ error: 'Session ID is required' }))\n              return\n            }\n            \n            await deleteSession(sessionId)\n            res.writeHead(200)\n            res.end(JSON.stringify({ success: true }))\n          } else {\n            res.writeHead(405)\n            res.end(JSON.stringify({ error: 'Method not allowed' }))\n          }\n        } catch (e) {\n          res.writeHead(500)\n          res.end(JSON.stringify({ error: String(e) }))\n        }\n      })\n\n      server.httpServer?.on('close', stopServices)\n      \n      const cleanup = async () => {\n        await stopServices()\n        process.exit(0)\n      }\n      \n      process.on('SIGINT', cleanup)\n      process.on('SIGTERM', cleanup)\n      process.on('exit', () => {\n        webProcess?.kill('SIGKILL')\n      })\n    },\n\n    transformIndexHtml(html) {\n      const widget = injectWidget({\n        webUrl: `http://${config.hostname}:${actualWebPort}`,\n        serverUrl: `http://${config.hostname}:${actualWebPort}`,\n        position: config.position,\n        theme: config.theme,\n        open: config.open,\n        autoReload: config.autoReload,\n        cwd: process.cwd(),\n        sessionUrl: sessionUrl || undefined,\n        lazy: config.lazy,\n        hotkey: config.hotkey,\n      })\n      return html.replace('</body>', `${widget}</body>`)\n    },\n  }\n}\n"]}
451
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Plugin, ViteDevServer } from 'vite'\nimport { spawn, ChildProcess } from 'child_process'\nimport path from 'path'\nimport fs from 'fs'\nimport http from 'http'\nimport { fileURLToPath } from 'url'\n\nconst __filename = fileURLToPath(import.meta.url)\nconst __dirname = path.dirname(__filename)\n\nimport { startOpenCodeWeb } from './web.js'\nimport { injectWidget } from './injector.js'\nimport { checkOpenCodeInstalled, findAvailablePort, killProcessOnPort, checkOpenCodeProcess } from './utils.js'\nimport { OpenCodeOptions, SessionInfo, PageContext } from './types.js'\nimport {\n  DEFAULT_CONFIG,\n  DEFAULT_RETRIES,\n  RETRY_DELAY,\n  PROCESS_KILL_DELAY,\n  LOG_PREFIX,\n  WIDGET_SCRIPT_PATH,\n  CONTEXT_API_PATH,\n  START_API_PATH,\n  SESSIONS_API_PATH,\n} from './constants.js'\n\n/**\n * OpenCode Vite 插件\n * @param options - 插件配置选项\n * @returns Vite 插件实例\n * @example\n * ```ts\n * // vite.config.ts\n * import opencode from 'vite-plugin-opencode'\n *\n * export default {\n *   plugins: [\n *     opencode({\n *       webPort: 4097,\n *       position: 'bottom-right',\n *       theme: 'auto'\n *     })\n *   ]\n * }\n * ```\n */\nexport default function opencodePlugin(options: OpenCodeOptions = {}): Plugin {\n  let webProcess: ChildProcess | null = null\n  let sessionUrl: string | null = null\n  let actualWebPort: number = DEFAULT_CONFIG.webPort\n  let isStarted = false\n  let startPromise: Promise<void> | null = null\n  let pageContext: PageContext = { url: '', title: '' }\n\n  const config = { ...DEFAULT_CONFIG, ...options }\n\n  /**\n   * 输出日志（仅在 verbose 模式下）\n   */\n  function log(message: string, ...args: unknown[]): void {\n    if (config.verbose) {\n      console.log(`${LOG_PREFIX} ${message}`, ...args)\n    }\n  }\n\n  /**\n   * 输出错误日志\n   */\n  function logError(message: string, ...args: unknown[]): void {\n    console.error(`${LOG_PREFIX} ${message}`, ...args)\n  }\n\n  /**\n   * Base64 编码字符串\n   */\n  function base64Encode(str: string): string {\n    return Buffer.from(str).toString('base64')\n  }\n\n  /**\n   * 延迟执行\n   */\n  function sleep(ms: number): Promise<void> {\n    return new Promise(resolve => setTimeout(resolve, ms))\n  }\n\n  /**\n   * 创建 HTTP 请求 Promise\n   */\n  function createHttpRequest<T>(options: http.RequestOptions, body?: string): Promise<T> {\n    return new Promise((resolve, reject) => {\n      const req = http.request(options, (res) => {\n        let data = ''\n        res.on('data', chunk => data += chunk)\n        res.on('end', () => {\n          try {\n            resolve(JSON.parse(data))\n          } catch {\n            reject(new Error(`JSON parse error: ${data.substring(0, 100)}`))\n          }\n        })\n      })\n      req.on('error', reject)\n      if (body) req.write(body)\n      req.end()\n    })\n  }\n\n  /**\n   * 获取会话列表\n   */\n  async function getSessions(retries = DEFAULT_RETRIES): Promise<SessionInfo[]> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        return await createHttpRequest<SessionInfo[]>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: '/session',\n        })\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 创建新会话\n   */\n  async function createSession(retries = DEFAULT_RETRIES): Promise<SessionInfo> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        return await createHttpRequest<SessionInfo>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: '/session',\n          method: 'POST',\n        })\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 删除会话\n   */\n  async function deleteSession(sessionId: string, retries = DEFAULT_RETRIES): Promise<void> {\n    let lastError: Error | null = null\n\n    for (let i = 0; i < retries; i++) {\n      try {\n        await createHttpRequest<void>({\n          hostname: config.hostname,\n          port: actualWebPort,\n          path: `/session/${sessionId}`,\n          method: 'DELETE',\n        })\n        return\n      } catch (e) {\n        lastError = e instanceof Error ? e : new Error(String(e))\n        if (i < retries - 1) await sleep(RETRY_DELAY)\n      }\n    }\n\n    throw lastError\n  }\n\n  /**\n   * 获取或创建会话\n   */\n  async function getOrCreateSession(): Promise<string> {\n    const projectDir = process.cwd()\n    log('Getting sessions...')\n    const sessions = await getSessions()\n    log(`Found ${sessions.length} sessions`)\n\n    const matchingSession = sessions.find(s => s.directory === projectDir)\n\n    if (matchingSession) {\n      return `http://${config.hostname}:${actualWebPort}/${base64Encode(projectDir)}/session/${matchingSession.id}`\n    }\n\n    log('Creating new session...')\n    const newSession = await createSession()\n    return `http://${config.hostname}:${actualWebPort}/${base64Encode(projectDir)}/session/${newSession.id}`\n  }\n\n  /**\n   * 设置 OpenCode 插件\n   */\n  function setupOpenCodePlugin(): string {\n    const projectDir = process.cwd()\n    const cacheDir = path.join(projectDir, 'node_modules', '.cache', 'opencode')\n    const pluginsDir = path.join(cacheDir, 'plugins')\n\n    if (!fs.existsSync(pluginsDir)) {\n      fs.mkdirSync(pluginsDir, { recursive: true })\n    }\n\n    const pluginSourcePath = path.join(__dirname, 'plugins', 'page-context.js')\n    const pluginTargetPath = path.join(pluginsDir, 'page-context.js')\n\n    if (fs.existsSync(pluginSourcePath)) {\n      fs.copyFileSync(pluginSourcePath, pluginTargetPath)\n      log(`Plugin installed to ${pluginTargetPath}`)\n    } else {\n      console.warn(`${LOG_PREFIX} Plugin source not found: ${pluginSourcePath}`)\n    }\n\n    return cacheDir\n  }\n\n  /**\n   * 启动服务\n   */\n  async function startServices(corsOrigins?: string[], contextApiUrl?: string): Promise<void> {\n    if (isStarted) return\n    if (startPromise) return startPromise\n\n    startPromise = (async () => {\n      log('Starting OpenCode services...')\n\n      if (!await checkOpenCodeInstalled()) {\n        logError(`OpenCode is not installed!\n\nPlease install OpenCode first:\n\n  # Using Homebrew (macOS)\n  brew install opencode-ai/tap/opencode\n\n  # Or using the install script\n  curl -fsSL https://opencode.ai/install | bash\n        `)\n        return\n      }\n\n      actualWebPort = await findAvailablePort(config.webPort, config.hostname)\n      if (actualWebPort !== config.webPort) {\n        log(`Port ${config.webPort} is in use, using ${actualWebPort} instead`)\n      }\n\n      const existingProcess = await checkOpenCodeProcess(actualWebPort)\n      if (existingProcess) {\n        log(`Found existing OpenCode process on port ${actualWebPort}`)\n      } else {\n        const killed = await killProcessOnPort(actualWebPort, config.hostname)\n        if (killed) {\n          log(`Killed stale process on port ${actualWebPort}`)\n          await sleep(PROCESS_KILL_DELAY)\n        }\n      }\n\n      const configDir = setupOpenCodePlugin()\n\n      if (!existingProcess) {\n        webProcess = await startOpenCodeWeb({\n          port: actualWebPort,\n          hostname: config.hostname,\n          serverUrl: '',\n          cwd: process.cwd(),\n          configDir,\n          corsOrigins,\n          contextApiUrl,\n        })\n        log(`OpenCode Web started at http://${config.hostname}:${actualWebPort}`)\n      }\n\n      try {\n        sessionUrl = await getOrCreateSession()\n        log(`Session URL: ${sessionUrl}`)\n      } catch (e) {\n        console.warn(`${LOG_PREFIX} Failed to get/create session:`, e)\n      }\n\n      isStarted = true\n    })()\n\n    return startPromise\n  }\n\n  /**\n   * 停止服务\n   */\n  async function stopServices(): Promise<void> {\n    log('Stopping OpenCode services...')\n    \n    if (webProcess) {\n      webProcess.kill('SIGTERM')\n      await new Promise<void>(resolve => {\n        webProcess?.on('exit', () => resolve())\n        setTimeout(() => {\n          webProcess?.kill('SIGKILL')\n          resolve()\n        }, 3000)\n      })\n      webProcess = null\n    }\n    \n    if (isStarted) {\n      await killProcessOnPort(actualWebPort, config.hostname)\n    }\n    \n    isStarted = false\n    startPromise = null\n  }\n\n  /**\n   * 处理上下文 API 请求\n   */\n  function handleContextRequest(req: http.IncomingMessage, res: http.ServerResponse): void {\n    res.setHeader('Content-Type', 'application/json')\n    res.setHeader('Access-Control-Allow-Origin', '*')\n    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, DELETE, OPTIONS')\n    res.setHeader('Access-Control-Allow-Headers', 'Content-Type')\n\n    if (req.method === 'OPTIONS') {\n      res.writeHead(200)\n      res.end()\n      return\n    }\n\n    if (req.method === 'GET') {\n      res.writeHead(200)\n      res.end(JSON.stringify(pageContext))\n      return\n    }\n\n    if (req.method === 'DELETE') {\n      pageContext.selectedElements = []\n      log('Selected elements cleared')\n      res.writeHead(200)\n      res.end(JSON.stringify({ success: true }))\n      return\n    }\n\n    if (req.method === 'POST') {\n      let body = ''\n      req.on('data', chunk => body += chunk)\n      req.on('end', () => {\n        try {\n          const data = JSON.parse(body)\n          pageContext = {\n            url: data.url || '',\n            title: data.title || '',\n            selectedElements: data.selectedElements || [],\n          }\n          log(`Context updated: ${pageContext.url}`, data.selectedElements?.length ? `elements: ${data.selectedElements.length}` : '')\n          res.writeHead(200)\n          res.end(JSON.stringify({ success: true }))\n        } catch {\n          res.writeHead(400)\n          res.end(JSON.stringify({ error: 'Invalid JSON' }))\n        }\n      })\n      return\n    }\n\n    res.writeHead(405)\n    res.end(JSON.stringify({ error: 'Method not allowed' }))\n  }\n\n  return {\n    name: 'vite-plugin-opencode',\n\n    async configureServer(server: ViteDevServer) {\n      if (!config.enabled) return\n\n      const vitePort = server.config.server.port || 5173\n      const viteHost = server.config.server.host || 'localhost'\n      const viteOrigin = `http://${viteHost}:${vitePort}`\n      const contextApiUrl = `http://${viteHost}:${vitePort}${CONTEXT_API_PATH}`\n\n      if (!config.lazy) {\n        await startServices([viteOrigin], contextApiUrl)\n      }\n\n      server.middlewares.use(WIDGET_SCRIPT_PATH, async (_req, res) => {\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n\n        const widgetPath = path.join(__dirname, 'client.js')\n        if (fs.existsSync(widgetPath)) {\n          res.setHeader('Content-Type', 'application/javascript')\n          res.setHeader('Access-Control-Allow-Origin', '*')\n          fs.createReadStream(widgetPath).pipe(res)\n        } else {\n          res.writeHead(404)\n          res.end('Widget script not found')\n        }\n      })\n\n      server.middlewares.use(CONTEXT_API_PATH, async (req, res) => {\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n        handleContextRequest(req as http.IncomingMessage, res)\n      })\n\n      server.middlewares.use(START_API_PATH, async (_req, res) => {\n        res.setHeader('Content-Type', 'application/json')\n        res.setHeader('Access-Control-Allow-Origin', '*')\n\n        if (config.lazy && !isStarted) {\n          try {\n            await startServices([viteOrigin], contextApiUrl)\n            res.writeHead(200)\n            res.end(JSON.stringify({ success: true, sessionUrl }))\n          } catch (e) {\n            res.writeHead(500)\n            res.end(JSON.stringify({ error: String(e) }))\n          }\n        } else {\n          res.writeHead(200)\n          res.end(JSON.stringify({ success: true, sessionUrl }))\n        }\n      })\n\n      server.middlewares.use(SESSIONS_API_PATH, async (req, res) => {\n        res.setHeader('Content-Type', 'application/json')\n        res.setHeader('Access-Control-Allow-Origin', '*')\n        res.setHeader('Access-Control-Allow-Methods', 'GET, POST, DELETE, OPTIONS')\n        res.setHeader('Access-Control-Allow-Headers', 'Content-Type')\n\n        if (req.method === 'OPTIONS') {\n          res.writeHead(200)\n          res.end()\n          return\n        }\n\n        if (config.lazy && !isStarted) {\n          await startServices([viteOrigin], contextApiUrl)\n        }\n\n        try {\n          if (req.method === 'GET') {\n            const sessions = await getSessions()\n            res.writeHead(200)\n            res.end(JSON.stringify(sessions))\n          } else if (req.method === 'POST') {\n            const newSession = await createSession()\n            res.writeHead(200)\n            res.end(JSON.stringify(newSession))\n          } else if (req.method === 'DELETE') {\n            const url = new URL(req.url || '', `http://${req.headers.host}`)\n            const sessionId = url.searchParams.get('id')\n            \n            if (!sessionId) {\n              res.writeHead(400)\n              res.end(JSON.stringify({ error: 'Session ID is required' }))\n              return\n            }\n            \n            await deleteSession(sessionId)\n            res.writeHead(200)\n            res.end(JSON.stringify({ success: true }))\n          } else {\n            res.writeHead(405)\n            res.end(JSON.stringify({ error: 'Method not allowed' }))\n          }\n        } catch (e) {\n          res.writeHead(500)\n          res.end(JSON.stringify({ error: String(e) }))\n        }\n      })\n\n      server.httpServer?.on('close', stopServices)\n      \n      const cleanup = async () => {\n        await stopServices()\n        process.exit(0)\n      }\n      \n      process.on('SIGINT', cleanup)\n      process.on('SIGTERM', cleanup)\n      process.on('exit', () => {\n        webProcess?.kill('SIGKILL')\n      })\n    },\n\n    transformIndexHtml(html) {\n      const widget = injectWidget({\n        webUrl: `http://${config.hostname}:${actualWebPort}`,\n        serverUrl: `http://${config.hostname}:${actualWebPort}`,\n        position: config.position,\n        theme: config.theme,\n        open: config.open,\n        autoReload: config.autoReload,\n        cwd: process.cwd(),\n        sessionUrl: sessionUrl || undefined,\n        lazy: config.lazy,\n        hotkey: config.hotkey,\n      })\n      return html.replace('</body>', `${widget}</body>`)\n    },\n  }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { WidgetOptions } from './types';
1
+ import { WidgetOptions } from './types.js';
2
2
  /**
3
3
  * 生成挂件注入脚本标签
4
4
  * @param options - 挂件配置选项
package/dist/injector.js CHANGED
@@ -1,4 +1,4 @@
1
- import { WIDGET_SCRIPT_PATH, CONFIG_DATA_ATTR } from './constants';
1
+ import { WIDGET_SCRIPT_PATH, CONFIG_DATA_ATTR } from './constants.js';
2
2
  /**
3
3
  * 生成挂件注入脚本标签
4
4
  * @param options - 挂件配置选项
@@ -21,4 +21,4 @@ export function injectWidget(options) {
21
21
  const configBase64 = Buffer.from(JSON.stringify(options)).toString('base64');
22
22
  return `<script src="${WIDGET_SCRIPT_PATH}" ${CONFIG_DATA_ATTR}="${configBase64}"></script>`;
23
23
  }
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5qZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFBO0FBRWxFOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQU0sVUFBVSxZQUFZLENBQUMsT0FBc0I7SUFDakQsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFBO0lBQzVFLE9BQU8sZ0JBQWdCLGtCQUFrQixLQUFLLGdCQUFnQixLQUFLLFlBQVksYUFBYSxDQUFBO0FBQzlGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXaWRnZXRPcHRpb25zIH0gZnJvbSAnLi90eXBlcydcbmltcG9ydCB7IFdJREdFVF9TQ1JJUFRfUEFUSCwgQ09ORklHX0RBVEFfQVRUUiB9IGZyb20gJy4vY29uc3RhbnRzJ1xuXG4vKipcbiAqIOeUn+aIkOaMguS7tuazqOWFpeiEmuacrOagh+etvlxuICogQHBhcmFtIG9wdGlvbnMgLSDmjILku7bphY3nva7pgInpoblcbiAqIEByZXR1cm5zIEhUTUwg6ISa5pys5qCH562+5a2X56ym5LiyXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGNvbnN0IHdpZGdldCA9IGluamVjdFdpZGdldCh7XG4gKiAgIHdlYlVybDogJ2h0dHA6Ly8xMjcuMC4wLjE6NDA5NycsXG4gKiAgIHNlcnZlclVybDogJ2h0dHA6Ly8xMjcuMC4wLjE6NDA5NycsXG4gKiAgIHBvc2l0aW9uOiAnYm90dG9tLXJpZ2h0JyxcbiAqICAgdGhlbWU6ICdhdXRvJyxcbiAqICAgb3BlbjogZmFsc2UsXG4gKiAgIGF1dG9SZWxvYWQ6IHRydWUsXG4gKiAgIGN3ZDogcHJvY2Vzcy5jd2QoKVxuICogfSlcbiAqIC8vIOi/lOWbnjogJzxzY3JpcHQgc3JjPVwiL19fb3BlbmNvZGVfd2lkZ2V0X18uanNcIiBkYXRhLW9wZW5jb2RlLWNvbmZpZz1cIi4uLlwiPjwvc2NyaXB0PidcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0V2lkZ2V0KG9wdGlvbnM6IFdpZGdldE9wdGlvbnMpOiBzdHJpbmcge1xuICBjb25zdCBjb25maWdCYXNlNjQgPSBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShvcHRpb25zKSkudG9TdHJpbmcoJ2Jhc2U2NCcpXG4gIHJldHVybiBgPHNjcmlwdCBzcmM9XCIke1dJREdFVF9TQ1JJUFRfUEFUSH1cIiAke0NPTkZJR19EQVRBX0FUVFJ9PVwiJHtjb25maWdCYXNlNjR9XCI+PC9zY3JpcHQ+YFxufVxuIl19
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5qZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFFckU7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJHO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FBQyxPQUFzQjtJQUNqRCxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDNUUsT0FBTyxnQkFBZ0Isa0JBQWtCLEtBQUssZ0JBQWdCLEtBQUssWUFBWSxhQUFhLENBQUE7QUFDOUYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFdpZGdldE9wdGlvbnMgfSBmcm9tICcuL3R5cGVzLmpzJ1xuaW1wb3J0IHsgV0lER0VUX1NDUklQVF9QQVRILCBDT05GSUdfREFUQV9BVFRSIH0gZnJvbSAnLi9jb25zdGFudHMuanMnXG5cbi8qKlxuICog55Sf5oiQ5oyC5Lu25rOo5YWl6ISa5pys5qCH562+XG4gKiBAcGFyYW0gb3B0aW9ucyAtIOaMguS7tumFjee9rumAiemhuVxuICogQHJldHVybnMgSFRNTCDohJrmnKzmoIfnrb7lrZfnrKbkuLJcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogY29uc3Qgd2lkZ2V0ID0gaW5qZWN0V2lkZ2V0KHtcbiAqICAgd2ViVXJsOiAnaHR0cDovLzEyNy4wLjAuMTo0MDk3JyxcbiAqICAgc2VydmVyVXJsOiAnaHR0cDovLzEyNy4wLjAuMTo0MDk3JyxcbiAqICAgcG9zaXRpb246ICdib3R0b20tcmlnaHQnLFxuICogICB0aGVtZTogJ2F1dG8nLFxuICogICBvcGVuOiBmYWxzZSxcbiAqICAgYXV0b1JlbG9hZDogdHJ1ZSxcbiAqICAgY3dkOiBwcm9jZXNzLmN3ZCgpXG4gKiB9KVxuICogLy8g6L+U5ZueOiAnPHNjcmlwdCBzcmM9XCIvX19vcGVuY29kZV93aWRnZXRfXy5qc1wiIGRhdGEtb3BlbmNvZGUtY29uZmlnPVwiLi4uXCI+PC9zY3JpcHQ+J1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RXaWRnZXQob3B0aW9uczogV2lkZ2V0T3B0aW9ucyk6IHN0cmluZyB7XG4gIGNvbnN0IGNvbmZpZ0Jhc2U2NCA9IEJ1ZmZlci5mcm9tKEpTT04uc3RyaW5naWZ5KG9wdGlvbnMpKS50b1N0cmluZygnYmFzZTY0JylcbiAgcmV0dXJuIGA8c2NyaXB0IHNyYz1cIiR7V0lER0VUX1NDUklQVF9QQVRIfVwiICR7Q09ORklHX0RBVEFfQVRUUn09XCIke2NvbmZpZ0Jhc2U2NH1cIj48L3NjcmlwdD5gXG59XG4iXX0=
package/dist/utils.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import http from 'http';
2
2
  import { spawn } from 'child_process';
3
3
  import net from 'net';
4
- import { DEFAULT_HOSTNAME, SERVER_CHECK_INTERVAL, HEALTH_CHECK_TIMEOUT, MAX_PORT_TRIES, } from './constants';
4
+ import { DEFAULT_HOSTNAME, SERVER_CHECK_INTERVAL, HEALTH_CHECK_TIMEOUT, MAX_PORT_TRIES, } from './constants.js';
5
5
  /**
6
6
  * 等待服务器就绪
7
7
  * @param url - 服务器 URL
@@ -153,4 +153,4 @@ export async function checkOpenCodeProcess(port) {
153
153
  req.end();
154
154
  });
155
155
  }
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import http from 'http'\nimport { spawn } from 'child_process'\nimport net from 'net'\nimport {\n  DEFAULT_HOSTNAME,\n  SERVER_CHECK_INTERVAL,\n  HEALTH_CHECK_TIMEOUT,\n  MAX_PORT_TRIES,\n} from './constants'\n\n/**\n * 等待服务器就绪\n * @param url - 服务器 URL\n * @param timeout - 超时时间（毫秒），默认 10000\n * @returns Promise，服务器就绪时 resolve\n * @throws 超时后抛出错误\n */\nexport function waitForServer(url: string, timeout = 10000): Promise<void> {\n  return new Promise((resolve, reject) => {\n    const startTime = Date.now()\n\n    const check = (): void => {\n      const req = http.get(url, (res) => {\n        if (res.statusCode && res.statusCode < 500) {\n          resolve()\n        } else {\n          retryOrReject()\n        }\n      })\n\n      req.on('error', retryOrReject)\n    }\n\n    const retryOrReject = (): void => {\n      if (Date.now() - startTime < timeout) {\n        setTimeout(check, SERVER_CHECK_INTERVAL)\n      } else {\n        reject(new Error(`Server not ready after ${timeout}ms`))\n      }\n    }\n\n    check()\n  })\n}\n\n/**\n * 检查 OpenCode 是否已安装\n * @returns 是否已安装\n */\nexport async function checkOpenCodeInstalled(): Promise<boolean> {\n  return new Promise((resolve) => {\n    const proc = spawn('opencode', ['--version'], { stdio: 'ignore' })\n    proc.on('close', (code) => resolve(code === 0))\n    proc.on('error', () => resolve(false))\n  })\n}\n\n/**\n * 检查端口是否可用\n * @param port - 端口号\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @returns 端口是否可用\n */\nexport async function isPortAvailable(port: number, hostname = DEFAULT_HOSTNAME): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = net.createServer()\n    server.once('error', () => resolve(false))\n    server.once('listening', () => {\n      server.close()\n      resolve(true)\n    })\n    server.listen(port, hostname)\n  })\n}\n\n/**\n * 查找可用端口\n * @param startPort - 起始端口\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @param maxTries - 最大尝试次数，默认 10\n * @returns 可用的端口号\n * @throws 找不到可用端口时抛出错误\n */\nexport async function findAvailablePort(\n  startPort: number,\n  hostname = DEFAULT_HOSTNAME,\n  maxTries = MAX_PORT_TRIES\n): Promise<number> {\n  for (let port = startPort; port < startPort + maxTries; port++) {\n    if (await isPortAvailable(port, hostname)) {\n      return port\n    }\n  }\n  throw new Error(`No available port found after ${maxTries} tries starting from ${startPort}`)\n}\n\n/**\n * 终止占用指定端口的进程\n * @param port - 端口号\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @returns 是否成功终止进程\n */\nexport async function killProcessOnPort(port: number, hostname = DEFAULT_HOSTNAME): Promise<boolean> {\n  return new Promise((resolve) => {\n    if (process.platform === 'win32') {\n      killProcessOnWindows(port, resolve)\n    } else {\n      killProcessOnUnix(port, resolve)\n    }\n  })\n}\n\n/**\n * 在 Windows 上终止占用端口的进程\n */\nfunction killProcessOnWindows(port: number, resolve: (value: boolean) => void): void {\n  const proc = spawn('cmd', ['/c', `netstat -ano | findstr :${port}`], { stdio: 'pipe' })\n  let output = ''\n\n  proc.stdout?.on('data', (data) => {\n    output += data.toString()\n  })\n\n  proc.on('close', () => {\n    const match = output.match(/LISTENING\\s+(\\d+)/)\n    if (match) {\n      spawn('taskkill', ['/F', '/PID', match[1]], { stdio: 'ignore' })\n        .on('close', (code) => resolve(code === 0))\n    } else {\n      resolve(false)\n    }\n  })\n}\n\n/**\n * 在 Unix 系统上终止占用端口的进程\n */\nfunction killProcessOnUnix(port: number, resolve: (value: boolean) => void): void {\n  const proc = spawn('lsof', ['-ti', `tcp:${port}`, '-sTCP:LISTEN'], { stdio: 'pipe' })\n  let output = ''\n\n  proc.stdout?.on('data', (data) => {\n    output += data.toString()\n  })\n\n  proc.on('close', () => {\n    const pids = output.trim().split('\\n').filter(Boolean)\n    if (pids.length > 0) {\n      const killProc = spawn('kill', ['-9', ...pids], { stdio: 'ignore' })\n      killProc.on('close', (code) => resolve(code === 0))\n    } else {\n      resolve(false)\n    }\n  })\n}\n\n/**\n * 检查 OpenCode 进程是否在运行\n * @param port - 服务端口\n * @returns 进程是否在运行\n */\nexport async function checkOpenCodeProcess(port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const req = http.get({\n      hostname: DEFAULT_HOSTNAME,\n      port,\n      path: '/health',\n      timeout: HEALTH_CHECK_TIMEOUT,\n    }, (res) => {\n      resolve(res.statusCode === 200)\n    })\n    req.on('error', () => resolve(false))\n    req.end()\n  })\n}\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import http from 'http'\nimport { spawn } from 'child_process'\nimport net from 'net'\nimport {\n  DEFAULT_HOSTNAME,\n  SERVER_CHECK_INTERVAL,\n  HEALTH_CHECK_TIMEOUT,\n  MAX_PORT_TRIES,\n} from './constants.js'\n\n/**\n * 等待服务器就绪\n * @param url - 服务器 URL\n * @param timeout - 超时时间（毫秒），默认 10000\n * @returns Promise，服务器就绪时 resolve\n * @throws 超时后抛出错误\n */\nexport function waitForServer(url: string, timeout = 10000): Promise<void> {\n  return new Promise((resolve, reject) => {\n    const startTime = Date.now()\n\n    const check = (): void => {\n      const req = http.get(url, (res) => {\n        if (res.statusCode && res.statusCode < 500) {\n          resolve()\n        } else {\n          retryOrReject()\n        }\n      })\n\n      req.on('error', retryOrReject)\n    }\n\n    const retryOrReject = (): void => {\n      if (Date.now() - startTime < timeout) {\n        setTimeout(check, SERVER_CHECK_INTERVAL)\n      } else {\n        reject(new Error(`Server not ready after ${timeout}ms`))\n      }\n    }\n\n    check()\n  })\n}\n\n/**\n * 检查 OpenCode 是否已安装\n * @returns 是否已安装\n */\nexport async function checkOpenCodeInstalled(): Promise<boolean> {\n  return new Promise((resolve) => {\n    const proc = spawn('opencode', ['--version'], { stdio: 'ignore' })\n    proc.on('close', (code) => resolve(code === 0))\n    proc.on('error', () => resolve(false))\n  })\n}\n\n/**\n * 检查端口是否可用\n * @param port - 端口号\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @returns 端口是否可用\n */\nexport async function isPortAvailable(port: number, hostname = DEFAULT_HOSTNAME): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = net.createServer()\n    server.once('error', () => resolve(false))\n    server.once('listening', () => {\n      server.close()\n      resolve(true)\n    })\n    server.listen(port, hostname)\n  })\n}\n\n/**\n * 查找可用端口\n * @param startPort - 起始端口\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @param maxTries - 最大尝试次数，默认 10\n * @returns 可用的端口号\n * @throws 找不到可用端口时抛出错误\n */\nexport async function findAvailablePort(\n  startPort: number,\n  hostname = DEFAULT_HOSTNAME,\n  maxTries = MAX_PORT_TRIES\n): Promise<number> {\n  for (let port = startPort; port < startPort + maxTries; port++) {\n    if (await isPortAvailable(port, hostname)) {\n      return port\n    }\n  }\n  throw new Error(`No available port found after ${maxTries} tries starting from ${startPort}`)\n}\n\n/**\n * 终止占用指定端口的进程\n * @param port - 端口号\n * @param hostname - 主机名，默认 '127.0.0.1'\n * @returns 是否成功终止进程\n */\nexport async function killProcessOnPort(port: number, hostname = DEFAULT_HOSTNAME): Promise<boolean> {\n  return new Promise((resolve) => {\n    if (process.platform === 'win32') {\n      killProcessOnWindows(port, resolve)\n    } else {\n      killProcessOnUnix(port, resolve)\n    }\n  })\n}\n\n/**\n * 在 Windows 上终止占用端口的进程\n */\nfunction killProcessOnWindows(port: number, resolve: (value: boolean) => void): void {\n  const proc = spawn('cmd', ['/c', `netstat -ano | findstr :${port}`], { stdio: 'pipe' })\n  let output = ''\n\n  proc.stdout?.on('data', (data) => {\n    output += data.toString()\n  })\n\n  proc.on('close', () => {\n    const match = output.match(/LISTENING\\s+(\\d+)/)\n    if (match) {\n      spawn('taskkill', ['/F', '/PID', match[1]], { stdio: 'ignore' })\n        .on('close', (code) => resolve(code === 0))\n    } else {\n      resolve(false)\n    }\n  })\n}\n\n/**\n * 在 Unix 系统上终止占用端口的进程\n */\nfunction killProcessOnUnix(port: number, resolve: (value: boolean) => void): void {\n  const proc = spawn('lsof', ['-ti', `tcp:${port}`, '-sTCP:LISTEN'], { stdio: 'pipe' })\n  let output = ''\n\n  proc.stdout?.on('data', (data) => {\n    output += data.toString()\n  })\n\n  proc.on('close', () => {\n    const pids = output.trim().split('\\n').filter(Boolean)\n    if (pids.length > 0) {\n      const killProc = spawn('kill', ['-9', ...pids], { stdio: 'ignore' })\n      killProc.on('close', (code) => resolve(code === 0))\n    } else {\n      resolve(false)\n    }\n  })\n}\n\n/**\n * 检查 OpenCode 进程是否在运行\n * @param port - 服务端口\n * @returns 进程是否在运行\n */\nexport async function checkOpenCodeProcess(port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const req = http.get({\n      hostname: DEFAULT_HOSTNAME,\n      port,\n      path: '/health',\n      timeout: HEALTH_CHECK_TIMEOUT,\n    }, (res) => {\n      resolve(res.statusCode === 200)\n    })\n    req.on('error', () => resolve(false))\n    req.end()\n  })\n}\n"]}
package/dist/web.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { ChildProcess } from 'child_process';
2
- import { WebOptions } from './types';
2
+ import { WebOptions } from './types.js';
3
3
  /**
4
4
  * 启动 OpenCode Web 服务
5
5
  * @param options - Web 服务启动选项
package/dist/web.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { spawn } from 'child_process';
2
- import { waitForServer } from './utils';
3
- import { SERVER_START_TIMEOUT, LOG_PREFIX, } from './constants';
2
+ import { waitForServer } from './utils.js';
3
+ import { SERVER_START_TIMEOUT, LOG_PREFIX, } from './constants.js';
4
4
  import path from 'path';
5
5
  import fs from 'fs';
6
6
  /**
@@ -92,4 +92,4 @@ function setupProcessHandlers(proc, port, hostname) {
92
92
  console.error(`\x1b[31m\x1b[1m${LOG_PREFIX}\x1b[0m ❌ Failed to start OpenCode server:`, err.message);
93
93
  });
94
94
  }
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3dlYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFnQixNQUFNLGVBQWUsQ0FBQTtBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sU0FBUyxDQUFBO0FBRXZDLE9BQU8sRUFDTCxvQkFBb0IsRUFDcEIsVUFBVSxHQUNYLE1BQU0sYUFBYSxDQUFBO0FBQ3BCLE9BQU8sSUFBSSxNQUFNLE1BQU0sQ0FBQTtBQUN2QixPQUFPLEVBQUUsTUFBTSxJQUFJLENBQUE7QUFFbkI7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFDSCxNQUFNLENBQUMsS0FBSyxVQUFVLGdCQUFnQixDQUFDLE9BQW1CO0lBQ3hELE1BQU0sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxHQUFHLE9BQU8sQ0FBQTtJQUU5RSxNQUFNLFFBQVEsR0FBRyxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsQ0FBQTtJQUMxQyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLENBQUMsQ0FBQTtJQUNwRSxNQUFNLEdBQUcsR0FBRyxlQUFlLENBQUMsUUFBUSxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUE7SUFFM0UsTUFBTSxJQUFJLEdBQUc7UUFDWCxPQUFPO1FBQ1AsUUFBUSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDdEIsWUFBWSxFQUFFLFFBQVE7S0FDdkIsQ0FBQTtJQUVELElBQUksV0FBVyxJQUFJLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDMUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMzQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQTtRQUM3QixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRTtRQUNuQyxHQUFHO1FBQ0gsS0FBSyxFQUFFLE1BQU07UUFDYixHQUFHO0tBQ0osQ0FBQyxDQUFBO0lBRUYsb0JBQW9CLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQTtJQUUxQyxNQUFNLGFBQWEsQ0FBQyxVQUFVLFFBQVEsSUFBSSxJQUFJLEVBQUUsRUFBRSxvQkFBb0IsQ0FBQyxDQUFBO0lBRXZFLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0JBQW9CLFVBQVUsa0RBQWtELENBQUMsQ0FBQTtJQUU3RixPQUFPLElBQUksQ0FBQTtBQUNiLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBUyxvQkFBb0IsQ0FBQyxHQUFXO0lBQ3ZDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLGNBQWMsRUFBRSxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUE7SUFFckUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQztRQUM3QixFQUFFLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFBO0lBQzdDLENBQUM7SUFFRCxPQUFPLFFBQVEsQ0FBQTtBQUNqQixDQUFDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNILFNBQVMsZUFBZSxDQUFDLFFBQWdCLEVBQUUsU0FBa0IsRUFBRSxhQUFzQixFQUFFLFVBQW1CO0lBQ3hHLE1BQU0sR0FBRyxHQUEyQjtRQUNsQyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQ25CLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLFNBQVMsQ0FBQyxDQUNyQztRQUMzQixjQUFjLEVBQUUsUUFBUTtLQUN6QixDQUFBO0lBRUQsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUNkLEdBQUcsQ0FBQyxtQkFBbUIsR0FBRyxTQUFTLENBQUE7SUFDckMsQ0FBQztJQUVELElBQUksYUFBYSxFQUFFLENBQUM7UUFDbEIsR0FBRyxDQUFDLHdCQUF3QixHQUFHLGFBQWEsQ0FBQTtJQUM5QyxDQUFDO0lBRUQsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNmLEdBQUcsQ0FBQyxnQkFBZ0IsR0FBRyxVQUFVLENBQUE7SUFDbkMsQ0FBQztJQUVELE9BQU8sR0FBRyxDQUFBO0FBQ1osQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQVMsb0JBQW9CLENBQUMsSUFBa0IsRUFBRSxJQUFZLEVBQUUsUUFBZ0I7SUFDOUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtJQUM3QixDQUFDLENBQUMsQ0FBQTtJQUVGLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUU7SUFDN0IsQ0FBQyxDQUFDLENBQUE7SUFFRixJQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO1FBQ3ZCLE9BQU8sQ0FBQyxLQUFLLENBQUMsa0JBQWtCLFVBQVUsNENBQTRDLEVBQUUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ3RHLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNwYXduLCBDaGlsZFByb2Nlc3MgfSBmcm9tICdjaGlsZF9wcm9jZXNzJ1xuaW1wb3J0IHsgd2FpdEZvclNlcnZlciB9IGZyb20gJy4vdXRpbHMnXG5pbXBvcnQgeyBXZWJPcHRpb25zIH0gZnJvbSAnLi90eXBlcydcbmltcG9ydCB7XG4gIFNFUlZFUl9TVEFSVF9USU1FT1VULFxuICBMT0dfUFJFRklYLFxufSBmcm9tICcuL2NvbnN0YW50cydcbmltcG9ydCBwYXRoIGZyb20gJ3BhdGgnXG5pbXBvcnQgZnMgZnJvbSAnZnMnXG5cbi8qKlxuICog5ZCv5YqoIE9wZW5Db2RlIFdlYiDmnI3liqFcbiAqIEBwYXJhbSBvcHRpb25zIC0gV2ViIOacjeWKoeWQr+WKqOmAiemhuVxuICogQHJldHVybnMg5a2Q6L+b56iL5a6e5L6LXG4gKiBAdGhyb3dzIOacjeWKoeWQr+WKqOi2heaXtuaXtuaKm+WHuumUmeivr1xuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBjb25zdCBwcm9jID0gYXdhaXQgc3RhcnRPcGVuQ29kZVdlYih7XG4gKiAgIHBvcnQ6IDQwOTcsXG4gKiAgIGhvc3RuYW1lOiAnMTI3LjAuMC4xJyxcbiAqICAgc2VydmVyVXJsOiAnJyxcbiAqICAgY3dkOiBwcm9jZXNzLmN3ZCgpXG4gKiB9KVxuICogYGBgXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzdGFydE9wZW5Db2RlV2ViKG9wdGlvbnM6IFdlYk9wdGlvbnMpOiBQcm9taXNlPENoaWxkUHJvY2Vzcz4ge1xuICBjb25zdCB7IHBvcnQsIGhvc3RuYW1lLCBjd2QsIGNvbmZpZ0RpciwgY29yc09yaWdpbnMsIGNvbnRleHRBcGlVcmwgfSA9IG9wdGlvbnNcblxuICBjb25zdCBzdGF0ZURpciA9IGNyZWF0ZVN0YXRlRGlyZWN0b3J5KGN3ZClcbiAgY29uc3QgcGx1Z2luUGF0aCA9IHBhdGguam9pbihzdGF0ZURpciwgJ3BsdWdpbnMnLCAncGFnZS1jb250ZXh0LmpzJylcbiAgY29uc3QgZW52ID0gYnVpbGRQcm9jZXNzRW52KHN0YXRlRGlyLCBjb25maWdEaXIsIGNvbnRleHRBcGlVcmwsIHBsdWdpblBhdGgpXG5cbiAgY29uc3QgYXJncyA9IFtcbiAgICAnc2VydmUnLFxuICAgICctLXBvcnQnLCBTdHJpbmcocG9ydCksXG4gICAgJy0taG9zdG5hbWUnLCBob3N0bmFtZSxcbiAgXVxuXG4gIGlmIChjb3JzT3JpZ2lucyAmJiBjb3JzT3JpZ2lucy5sZW5ndGggPiAwKSB7XG4gICAgY29yc09yaWdpbnMuZm9yRWFjaChvcmlnaW4gPT4ge1xuICAgICAgYXJncy5wdXNoKCctLWNvcnMnLCBvcmlnaW4pXG4gICAgfSlcbiAgfVxuXG4gIGNvbnN0IHByb2MgPSBzcGF3bignb3BlbmNvZGUnLCBhcmdzLCB7XG4gICAgY3dkLFxuICAgIHN0ZGlvOiAncGlwZScsXG4gICAgZW52LFxuICB9KVxuXG4gIHNldHVwUHJvY2Vzc0hhbmRsZXJzKHByb2MsIHBvcnQsIGhvc3RuYW1lKVxuXG4gIGF3YWl0IHdhaXRGb3JTZXJ2ZXIoYGh0dHA6Ly8ke2hvc3RuYW1lfToke3BvcnR9YCwgU0VSVkVSX1NUQVJUX1RJTUVPVVQpXG5cbiAgY29uc29sZS5sb2coYFxcblxceDFiWzM2bVxceDFiWzFtJHtMT0dfUFJFRklYfVxceDFiWzBtIOKcqCBPcGVuQ29kZSBzZXJ2ZXIgc3RhcnRlZCBzdWNjZXNzZnVsbHlcXG5gKVxuXG4gIHJldHVybiBwcm9jXG59XG5cbi8qKlxuICog5Yib5bu654q25oCB55uu5b2VXG4gKiBAcGFyYW0gY3dkIC0g5bel5L2c55uu5b2VXG4gKiBAcmV0dXJucyDnirbmgIHnm67lvZXot6/lvoRcbiAqL1xuZnVuY3Rpb24gY3JlYXRlU3RhdGVEaXJlY3RvcnkoY3dkOiBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCBzdGF0ZURpciA9IHBhdGguam9pbihjd2QsICdub2RlX21vZHVsZXMnLCAnLmNhY2hlJywgJ29wZW5jb2RlJylcbiAgXG4gIGlmICghZnMuZXhpc3RzU3luYyhzdGF0ZURpcikpIHtcbiAgICBmcy5ta2RpclN5bmMoc3RhdGVEaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pXG4gIH1cbiAgXG4gIHJldHVybiBzdGF0ZURpclxufVxuXG4vKipcbiAqIOaehOW7uui/m+eoi+eOr+Wig+WPmOmHj1xuICogQHBhcmFtIHN0YXRlRGlyIC0g54q25oCB55uu5b2V6Lev5b6EXG4gKiBAcGFyYW0gY29uZmlnRGlyIC0g6YWN572u55uu5b2V6Lev5b6EXG4gKiBAcGFyYW0gY29udGV4dEFwaVVybCAtIOS4iuS4i+aWhyBBUEkgVVJMXG4gKiBAcGFyYW0gcGx1Z2luUGF0aCAtIOaPkuS7tui3r+W+hFxuICogQHJldHVybnMg546v5aKD5Y+Y6YeP5a+56LGhXG4gKi9cbmZ1bmN0aW9uIGJ1aWxkUHJvY2Vzc0VudihzdGF0ZURpcjogc3RyaW5nLCBjb25maWdEaXI/OiBzdHJpbmcsIGNvbnRleHRBcGlVcmw/OiBzdHJpbmcsIHBsdWdpblBhdGg/OiBzdHJpbmcpOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHtcbiAgY29uc3QgZW52OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+ID0ge1xuICAgIC4uLk9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIE9iamVjdC5lbnRyaWVzKHByb2Nlc3MuZW52KS5maWx0ZXIoKFssIHZdKSA9PiB2ICE9PSB1bmRlZmluZWQpXG4gICAgKSBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+LFxuICAgIFhER19TVEFURV9IT01FOiBzdGF0ZURpcixcbiAgfVxuXG4gIGlmIChjb25maWdEaXIpIHtcbiAgICBlbnYuT1BFTkNPREVfQ09ORklHX0RJUiA9IGNvbmZpZ0RpclxuICB9XG5cbiAgaWYgKGNvbnRleHRBcGlVcmwpIHtcbiAgICBlbnYuT1BFTkNPREVfQ09OVEVYVF9BUElfVVJMID0gY29udGV4dEFwaVVybFxuICB9XG5cbiAgaWYgKHBsdWdpblBhdGgpIHtcbiAgICBlbnYuT1BFTkNPREVfUExVR0lOUyA9IHBsdWdpblBhdGhcbiAgfVxuXG4gIHJldHVybiBlbnZcbn1cblxuLyoqXG4gKiDorr7nva7ov5vnqIvkuovku7blpITnkIblmahcbiAqIEBwYXJhbSBwcm9jIC0g5a2Q6L+b56iL5a6e5L6LXG4gKi9cbmZ1bmN0aW9uIHNldHVwUHJvY2Vzc0hhbmRsZXJzKHByb2M6IENoaWxkUHJvY2VzcywgcG9ydDogbnVtYmVyLCBob3N0bmFtZTogc3RyaW5nKTogdm9pZCB7XG4gIHByb2Muc3Rkb3V0Py5vbignZGF0YScsICgpID0+IHtcbiAgfSlcblxuICBwcm9jLnN0ZGVycj8ub24oJ2RhdGEnLCAoKSA9PiB7XG4gIH0pXG5cbiAgcHJvYy5vbignZXJyb3InLCAoZXJyKSA9PiB7XG4gICAgY29uc29sZS5lcnJvcihgXFx4MWJbMzFtXFx4MWJbMW0ke0xPR19QUkVGSVh9XFx4MWJbMG0g4p2MIEZhaWxlZCB0byBzdGFydCBPcGVuQ29kZSBzZXJ2ZXI6YCwgZXJyLm1lc3NhZ2UpXG4gIH0pXG59XG4iXX0=
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3dlYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFnQixNQUFNLGVBQWUsQ0FBQTtBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBRTFDLE9BQU8sRUFDTCxvQkFBb0IsRUFDcEIsVUFBVSxHQUNYLE1BQU0sZ0JBQWdCLENBQUE7QUFDdkIsT0FBTyxJQUFJLE1BQU0sTUFBTSxDQUFBO0FBQ3ZCLE9BQU8sRUFBRSxNQUFNLElBQUksQ0FBQTtBQUVuQjs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sQ0FBQyxLQUFLLFVBQVUsZ0JBQWdCLENBQUMsT0FBbUI7SUFDeEQsTUFBTSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLEdBQUcsT0FBTyxDQUFBO0lBRTlFLE1BQU0sUUFBUSxHQUFHLG9CQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBQzFDLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFBO0lBQ3BFLE1BQU0sR0FBRyxHQUFHLGVBQWUsQ0FBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQTtJQUUzRSxNQUFNLElBQUksR0FBRztRQUNYLE9BQU87UUFDUCxRQUFRLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQztRQUN0QixZQUFZLEVBQUUsUUFBUTtLQUN2QixDQUFBO0lBRUQsSUFBSSxXQUFXLElBQUksV0FBVyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUMxQyxXQUFXLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFBO1FBQzdCLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVELE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFO1FBQ25DLEdBQUc7UUFDSCxLQUFLLEVBQUUsTUFBTTtRQUNiLEdBQUc7S0FDSixDQUFDLENBQUE7SUFFRixvQkFBb0IsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFBO0lBRTFDLE1BQU0sYUFBYSxDQUFDLFVBQVUsUUFBUSxJQUFJLElBQUksRUFBRSxFQUFFLG9CQUFvQixDQUFDLENBQUE7SUFFdkUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxvQkFBb0IsVUFBVSxrREFBa0QsQ0FBQyxDQUFBO0lBRTdGLE9BQU8sSUFBSSxDQUFBO0FBQ2IsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFTLG9CQUFvQixDQUFDLEdBQVc7SUFDdkMsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQTtJQUVyRSxJQUFJLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBQzdCLEVBQUUsQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUE7SUFDN0MsQ0FBQztJQUVELE9BQU8sUUFBUSxDQUFBO0FBQ2pCLENBQUM7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsU0FBUyxlQUFlLENBQUMsUUFBZ0IsRUFBRSxTQUFrQixFQUFFLGFBQXNCLEVBQUUsVUFBbUI7SUFDeEcsTUFBTSxHQUFHLEdBQTJCO1FBQ2xDLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FDbkIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssU0FBUyxDQUFDLENBQ3JDO1FBQzNCLGNBQWMsRUFBRSxRQUFRO0tBQ3pCLENBQUE7SUFFRCxJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ2QsR0FBRyxDQUFDLG1CQUFtQixHQUFHLFNBQVMsQ0FBQTtJQUNyQyxDQUFDO0lBRUQsSUFBSSxhQUFhLEVBQUUsQ0FBQztRQUNsQixHQUFHLENBQUMsd0JBQXdCLEdBQUcsYUFBYSxDQUFBO0lBQzlDLENBQUM7SUFFRCxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2YsR0FBRyxDQUFDLGdCQUFnQixHQUFHLFVBQVUsQ0FBQTtJQUNuQyxDQUFDO0lBRUQsT0FBTyxHQUFHLENBQUE7QUFDWixDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBUyxvQkFBb0IsQ0FBQyxJQUFrQixFQUFFLElBQVksRUFBRSxRQUFnQjtJQUM5RSxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFO0lBQzdCLENBQUMsQ0FBQyxDQUFBO0lBRUYsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtJQUM3QixDQUFDLENBQUMsQ0FBQTtJQUVGLElBQUksQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUU7UUFDdkIsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsVUFBVSw0Q0FBNEMsRUFBRSxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDdEcsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc3Bhd24sIENoaWxkUHJvY2VzcyB9IGZyb20gJ2NoaWxkX3Byb2Nlc3MnXG5pbXBvcnQgeyB3YWl0Rm9yU2VydmVyIH0gZnJvbSAnLi91dGlscy5qcydcbmltcG9ydCB7IFdlYk9wdGlvbnMgfSBmcm9tICcuL3R5cGVzLmpzJ1xuaW1wb3J0IHtcbiAgU0VSVkVSX1NUQVJUX1RJTUVPVVQsXG4gIExPR19QUkVGSVgsXG59IGZyb20gJy4vY29uc3RhbnRzLmpzJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcbmltcG9ydCBmcyBmcm9tICdmcydcblxuLyoqXG4gKiDlkK/liqggT3BlbkNvZGUgV2ViIOacjeWKoVxuICogQHBhcmFtIG9wdGlvbnMgLSBXZWIg5pyN5Yqh5ZCv5Yqo6YCJ6aG5XG4gKiBAcmV0dXJucyDlrZDov5vnqIvlrp7kvotcbiAqIEB0aHJvd3Mg5pyN5Yqh5ZCv5Yqo6LaF5pe25pe25oqb5Ye66ZSZ6K+vXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGNvbnN0IHByb2MgPSBhd2FpdCBzdGFydE9wZW5Db2RlV2ViKHtcbiAqICAgcG9ydDogNDA5NyxcbiAqICAgaG9zdG5hbWU6ICcxMjcuMC4wLjEnLFxuICogICBzZXJ2ZXJVcmw6ICcnLFxuICogICBjd2Q6IHByb2Nlc3MuY3dkKClcbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHN0YXJ0T3BlbkNvZGVXZWIob3B0aW9uczogV2ViT3B0aW9ucyk6IFByb21pc2U8Q2hpbGRQcm9jZXNzPiB7XG4gIGNvbnN0IHsgcG9ydCwgaG9zdG5hbWUsIGN3ZCwgY29uZmlnRGlyLCBjb3JzT3JpZ2lucywgY29udGV4dEFwaVVybCB9ID0gb3B0aW9uc1xuXG4gIGNvbnN0IHN0YXRlRGlyID0gY3JlYXRlU3RhdGVEaXJlY3RvcnkoY3dkKVxuICBjb25zdCBwbHVnaW5QYXRoID0gcGF0aC5qb2luKHN0YXRlRGlyLCAncGx1Z2lucycsICdwYWdlLWNvbnRleHQuanMnKVxuICBjb25zdCBlbnYgPSBidWlsZFByb2Nlc3NFbnYoc3RhdGVEaXIsIGNvbmZpZ0RpciwgY29udGV4dEFwaVVybCwgcGx1Z2luUGF0aClcblxuICBjb25zdCBhcmdzID0gW1xuICAgICdzZXJ2ZScsXG4gICAgJy0tcG9ydCcsIFN0cmluZyhwb3J0KSxcbiAgICAnLS1ob3N0bmFtZScsIGhvc3RuYW1lLFxuICBdXG5cbiAgaWYgKGNvcnNPcmlnaW5zICYmIGNvcnNPcmlnaW5zLmxlbmd0aCA+IDApIHtcbiAgICBjb3JzT3JpZ2lucy5mb3JFYWNoKG9yaWdpbiA9PiB7XG4gICAgICBhcmdzLnB1c2goJy0tY29ycycsIG9yaWdpbilcbiAgICB9KVxuICB9XG5cbiAgY29uc3QgcHJvYyA9IHNwYXduKCdvcGVuY29kZScsIGFyZ3MsIHtcbiAgICBjd2QsXG4gICAgc3RkaW86ICdwaXBlJyxcbiAgICBlbnYsXG4gIH0pXG5cbiAgc2V0dXBQcm9jZXNzSGFuZGxlcnMocHJvYywgcG9ydCwgaG9zdG5hbWUpXG5cbiAgYXdhaXQgd2FpdEZvclNlcnZlcihgaHR0cDovLyR7aG9zdG5hbWV9OiR7cG9ydH1gLCBTRVJWRVJfU1RBUlRfVElNRU9VVClcblxuICBjb25zb2xlLmxvZyhgXFxuXFx4MWJbMzZtXFx4MWJbMW0ke0xPR19QUkVGSVh9XFx4MWJbMG0g4pyoIE9wZW5Db2RlIHNlcnZlciBzdGFydGVkIHN1Y2Nlc3NmdWxseVxcbmApXG5cbiAgcmV0dXJuIHByb2Ncbn1cblxuLyoqXG4gKiDliJvlu7rnirbmgIHnm67lvZVcbiAqIEBwYXJhbSBjd2QgLSDlt6XkvZznm67lvZVcbiAqIEByZXR1cm5zIOeKtuaAgeebruW9lei3r+W+hFxuICovXG5mdW5jdGlvbiBjcmVhdGVTdGF0ZURpcmVjdG9yeShjd2Q6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IHN0YXRlRGlyID0gcGF0aC5qb2luKGN3ZCwgJ25vZGVfbW9kdWxlcycsICcuY2FjaGUnLCAnb3BlbmNvZGUnKVxuICBcbiAgaWYgKCFmcy5leGlzdHNTeW5jKHN0YXRlRGlyKSkge1xuICAgIGZzLm1rZGlyU3luYyhzdGF0ZURpciwgeyByZWN1cnNpdmU6IHRydWUgfSlcbiAgfVxuICBcbiAgcmV0dXJuIHN0YXRlRGlyXG59XG5cbi8qKlxuICog5p6E5bu66L+b56iL546v5aKD5Y+Y6YePXG4gKiBAcGFyYW0gc3RhdGVEaXIgLSDnirbmgIHnm67lvZXot6/lvoRcbiAqIEBwYXJhbSBjb25maWdEaXIgLSDphY3nva7nm67lvZXot6/lvoRcbiAqIEBwYXJhbSBjb250ZXh0QXBpVXJsIC0g5LiK5LiL5paHIEFQSSBVUkxcbiAqIEBwYXJhbSBwbHVnaW5QYXRoIC0g5o+S5Lu26Lev5b6EXG4gKiBAcmV0dXJucyDnjq/looPlj5jph4/lr7nosaFcbiAqL1xuZnVuY3Rpb24gYnVpbGRQcm9jZXNzRW52KHN0YXRlRGlyOiBzdHJpbmcsIGNvbmZpZ0Rpcj86IHN0cmluZywgY29udGV4dEFwaVVybD86IHN0cmluZywgcGx1Z2luUGF0aD86IHN0cmluZyk6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4ge1xuICBjb25zdCBlbnY6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7XG4gICAgLi4uT2JqZWN0LmZyb21FbnRyaWVzKFxuICAgICAgT2JqZWN0LmVudHJpZXMocHJvY2Vzcy5lbnYpLmZpbHRlcigoWywgdl0pID0+IHYgIT09IHVuZGVmaW5lZClcbiAgICApIGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4sXG4gICAgWERHX1NUQVRFX0hPTUU6IHN0YXRlRGlyLFxuICB9XG5cbiAgaWYgKGNvbmZpZ0Rpcikge1xuICAgIGVudi5PUEVOQ09ERV9DT05GSUdfRElSID0gY29uZmlnRGlyXG4gIH1cblxuICBpZiAoY29udGV4dEFwaVVybCkge1xuICAgIGVudi5PUEVOQ09ERV9DT05URVhUX0FQSV9VUkwgPSBjb250ZXh0QXBpVXJsXG4gIH1cblxuICBpZiAocGx1Z2luUGF0aCkge1xuICAgIGVudi5PUEVOQ09ERV9QTFVHSU5TID0gcGx1Z2luUGF0aFxuICB9XG5cbiAgcmV0dXJuIGVudlxufVxuXG4vKipcbiAqIOiuvue9rui/m+eoi+S6i+S7tuWkhOeQhuWZqFxuICogQHBhcmFtIHByb2MgLSDlrZDov5vnqIvlrp7kvotcbiAqL1xuZnVuY3Rpb24gc2V0dXBQcm9jZXNzSGFuZGxlcnMocHJvYzogQ2hpbGRQcm9jZXNzLCBwb3J0OiBudW1iZXIsIGhvc3RuYW1lOiBzdHJpbmcpOiB2b2lkIHtcbiAgcHJvYy5zdGRvdXQ/Lm9uKCdkYXRhJywgKCkgPT4ge1xuICB9KVxuXG4gIHByb2Muc3RkZXJyPy5vbignZGF0YScsICgpID0+IHtcbiAgfSlcblxuICBwcm9jLm9uKCdlcnJvcicsIChlcnIpID0+IHtcbiAgICBjb25zb2xlLmVycm9yKGBcXHgxYlszMW1cXHgxYlsxbSR7TE9HX1BSRUZJWH1cXHgxYlswbSDinYwgRmFpbGVkIHRvIHN0YXJ0IE9wZW5Db2RlIHNlcnZlcjpgLCBlcnIubWVzc2FnZSlcbiAgfSlcbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vite-plugin-opencode-assistant",
3
- "version": "1.0.0",
3
+ "version": "1.0.2",
4
4
  "description": "Embed OpenCode Web UI in your Vite dev server for real-time code modification and preview",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",