{"version":3,"sources":["/home/mkabumattar/work/withrawi/rawi/dist/chunk-P3AQU4KL.cjs","../src/core/providers/lmstudio.provider.ts"],"names":["lmstudioModelIds","lmstudioModels","name","lmstudioProvider","streamWithLMStudio","credentials","prompt","baseURL","createLMStudio","result","streamText","error"],"mappings":"AAAA;AACA,wDAAwC,4CCDe,wBAEhB,IAmBjCA,CAAAA,CAAmB,CACvB,oCAAA,CACA,mBAAA,CACA,mBAAA,CACA,oBAAA,CACA,oBAAA,CACA,mBAAA,CACA,oBAAA,CACA,oBAAA,CACA,oBAAA,CACA,iBAAA,CACA,gCAAA,CACA,gCAAA,CACA,8BAAA,CACA,+BAAA,CACA,2BAAA,CACA,6BAAA,CACA,oCAAA,CACA,sCAAA,CACA,6BAAA,CACA,wBAAA,CACA,wBAAA,CACA,oBAAA,CACA,iBAAA,CACA,eAAA,CACA,eAAA,CACA,gBAAA,CACA,sBACF,CAAA,CAEaC,CAAAA,aAA8BD,CAAAA,CAAiB,GAAA,CAAKE,CAAAA,EAAAA,CAAU,CACzE,IAAA,CAAAA,CAAAA,CACA,WAAA,CAAaA,CACf,CAAA,CAAE,CAAA,CAEWC,CAAAA,aAAmB,CAC9B,IAAA,CAAM,UAAA,CACN,WAAA,CAAa,2BAAA,CACb,MAAA,CAAQF,CACV,CAAA,CAEaG,CAAAA,aAAqB,KAAA,CAChCC,CAAAA,CACAC,CAAAA,CAAAA,EAC+B,CAC/B,GAAI,CAEF,IAAMC,CAAAA,iBADWF,CAAAA,mBAAY,gBAAA,6BACH,SAAA,EAAW,0BAAA,CAE/BF,CAAAA,CAAmBK,8CAAAA,CACvB,OAAA,CAAAD,CAAAA,CACA,IAAA,CAAM,UACR,CAAC,CAAA,CAEKE,CAAAA,CAASC,4BAAAA,CACb,KAAA,CAAOP,CAAAA,CAAiBE,CAAAA,CAAY,KAAK,CAAA,CACzC,MAAA,CAAAC,CAAAA,CACA,WAAA,CAAaD,CAAAA,CAAY,WAAA,EAAe,EAAA,CACxC,eAAA,CAAiBA,CAAAA,CAAY,SAAA,EAAa,IAC5C,CAAC,CAAA,CAED,MAAO,CACL,UAAA,CAAYI,CAAAA,CAAO,UAAA,CACnB,YAAA,CAAcA,CAAAA,CAAO,IACvB,CACF,CAAA,KAAA,CAASE,CAAAA,CAAO,CACd,MAAM,IAAI,KAAA,CACR,CAAA,uCAAA,EACEA,EAAAA,WAAiB,KAAA,CAAQA,CAAAA,CAAM,OAAA,CAAU,MAAA,CAAOA,CAAK,CACvD,CAAA,CAAA;ADxFoxC","file":"/home/mkabumattar/work/withrawi/rawi/dist/chunk-P3AQU4KL.cjs","sourcesContent":[null,"import {createOpenAICompatible as createLMStudio} from '@ai-sdk/lmstudio';\nimport type {ModelMessage} from 'ai';\nimport {generateText, streamText} from 'ai';\nimport {parseCommandFromResponse} from '../exec/parser.js';\nimport type {\n  LooseToStrict,\n  ModelInfo,\n  RawiCredentials,\n  StreamingResponse,\n} from '../shared/index.js';\nimport type {\n  ChatCredentials,\n  ChatProvider,\n  ChatStreamOptions,\n  ExecGenerationOptions,\n  ExecGenerationResult,\n} from './types.js';\n\ntype LooseLMStudioModelId = string;\nexport type LMStudioModelId = LooseToStrict<LooseLMStudioModelId>;\n\nconst lmstudioModelIds = [\n  'deepseek/deepseek-r1-0528-qwen3-8b',\n  'google/gemma-3-1b',\n  'google/gemma-2-9b',\n  'google/gemma-3-12b',\n  'google/gemma-3-27b',\n  'google/gemma-3-4b',\n  'ibm/granite-3.1-8b',\n  'ibm/granite-3.2-8b',\n  'meta/llama-3.3-70b',\n  'microsoft/phi-4',\n  'microsoft/phi-4-mini-reasoning',\n  'microsoft/phi-4-reasoning-plus',\n  'mistralai/codestral-22b-v0.1',\n  'mistralai/devstral-small-2505',\n  'mistralai/magistral-small',\n  'mistralai/mathstral-7b-v0.1',\n  'mistralai/mistral-7b-instruct-v0.3',\n  'mistralai/mistral-nemo-instruct-2407',\n  'mistralai/mistral-small-3.2',\n  'qwen/qwen2.5-coder-14b',\n  'qwen/qwen2.5-coder-32b',\n  'qwen/qwen2.5-vl-7b',\n  'qwen/qwen3-1.7b',\n  'qwen/qwen3-4b',\n  'qwen/qwen3-8b',\n  'qwen/qwen3-14b',\n  'qwen/qwen3-235b-a22b',\n] as const;\n\nexport const lmstudioModels: ModelInfo[] = lmstudioModelIds.map((name) => ({\n  name,\n  displayName: name,\n}));\n\nexport const lmstudioProvider = {\n  name: 'lmstudio' as const,\n  displayName: '🖥️ LM Studio',\n  models: lmstudioModels,\n};\n\nexport const streamWithLMStudio = async (\n  credentials: RawiCredentials,\n  prompt: string,\n): Promise<StreamingResponse> => {\n  try {\n    const settings = credentials.providerSettings as any;\n    const baseURL = settings?.baseURL || 'http://localhost:1234/v1';\n\n    const lmstudioProvider = createLMStudio({\n      baseURL,\n      name: 'lmstudio',\n    });\n\n    const result = streamText({\n      model: lmstudioProvider(credentials.model),\n      prompt,\n      temperature: credentials.temperature || 0.7,\n      maxOutputTokens: credentials.maxTokens || 2048,\n    });\n\n    return {\n      textStream: result.textStream,\n      fullResponse: result.text,\n    };\n  } catch (error) {\n    throw new Error(\n      `Error calling LM Studio streaming API: ${\n        error instanceof Error ? error.message : String(error)\n      }`,\n    );\n  }\n};\n\nexport const lmstudioChatProvider: ChatProvider = {\n  name: 'lmstudio',\n  displayName: '🖥️ LM Studio',\n\n  async streamChat(\n    credentials: ChatCredentials,\n    messages: ModelMessage[],\n    options: ChatStreamOptions = {},\n  ): Promise<AsyncIterable<string>> {\n    const settings = credentials.providerSettings as any;\n    const baseURL = settings?.baseURL || 'http://localhost:1234/v1';\n\n    const result = streamText({\n      model: createLMStudio({\n        baseURL,\n        name: 'lmstudio',\n      })(credentials.model),\n      messages,\n      temperature: credentials.temperature || options.temperature || 0.7,\n      maxOutputTokens: credentials.maxTokens || options.maxTokens || 2048,\n    });\n\n    return result.textStream;\n  },\n};\n\nexport const generateWithLMStudio = async (\n  options: ExecGenerationOptions,\n): Promise<ExecGenerationResult> => {\n  const startTime = Date.now();\n\n  try {\n    const settings = options.credentials.providerSettings as any;\n    const baseURL = settings?.baseURL || 'http://localhost:1234/v1';\n\n    const lmstudioProvider = createLMStudio({\n      baseURL,\n      name: 'lmstudio',\n    });\n\n    const result = await generateText({\n      model: lmstudioProvider(options.credentials.model),\n      system: options.systemPrompt,\n      prompt: options.userPrompt,\n    });\n\n    const generationTime = Date.now() - startTime;\n\n    const command = parseCommandFromResponse(result.text);\n\n    return {\n      command,\n      generationTime,\n    };\n  } catch (error) {\n    throw new Error(`LM Studio exec generation failed: ${error}`);\n  }\n};\n"]}