hoomanjs 1.3.0 → 1.4.0

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/README.md CHANGED
@@ -26,7 +26,7 @@ It gives you:
26
26
 
27
27
  ## Features
28
28
 
29
- - Multiple LLM providers: `ollama`, `openai`, `anthropic`, `google`, `bedrock`
29
+ - Multiple LLM providers: `ollama`, `openai`, `anthropic`, `google`, `bedrock`, `xai`
30
30
  - Local configuration under `~/.hooman`
31
31
  - MCP server support via `stdio`, `streamable-http`, and `sse`
32
32
  - MCP server `instructions` support: server-provided instructions are appended to the agent system prompt
@@ -262,6 +262,7 @@ Supported `llm.provider` values:
262
262
  - `anthropic`
263
263
  - `google`
264
264
  - `bedrock`
265
+ - `xai`
265
266
 
266
267
  ## Provider Notes
267
268
 
@@ -328,6 +329,21 @@ Uses Strands `GoogleModel` on top of `@google/genai`. Top-level options like `ap
328
329
 
329
330
  Supports `region`, `clientConfig`, and optional `apiKey`, with all other values forwarded as Bedrock model options.
330
331
 
332
+ ### xAI
333
+
334
+ Uses the Vercel AI SDK xAI provider (`@ai-sdk/xai`) on top of Strands `VercelModel`. Provider-specific settings `apiKey`, `baseURL`, and `headers` are picked up; other values are forwarded into the model config (`temperature`, `maxTokens`, etc.). Defaults to `XAI_API_KEY` from the environment when no `apiKey` is supplied.
335
+
336
+ ```json
337
+ {
338
+ "provider": "xai",
339
+ "model": "grok-4.20-non-reasoning",
340
+ "params": {
341
+ "apiKey": "...",
342
+ "temperature": 0.7
343
+ }
344
+ }
345
+ ```
346
+
331
347
  ## MCP Configuration
332
348
 
333
349
  `mcp.json` is stored as:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hoomanjs",
3
- "version": "1.3.0",
3
+ "version": "1.4.0",
4
4
  "description": "Bun-powered local AI agent CLI with chat, exec, ACP, MCP, and skills support.",
5
5
  "author": {
6
6
  "name": "Vaibhav Pandey",
@@ -51,6 +51,7 @@
51
51
  "dependencies": {
52
52
  "@agentclientprotocol/sdk": "^0.18.2",
53
53
  "@ai-sdk/anthropic": "^3.0.69",
54
+ "@ai-sdk/xai": "^3.0.83",
54
55
  "@aws-sdk/client-bedrock-runtime": "^3.1028.0",
55
56
  "@google/genai": "^1.40.0",
56
57
  "@huggingface/transformers": "^4.0.1",
@@ -8,6 +8,7 @@ export enum LlmProvider {
8
8
  OpenAI = "openai",
9
9
  Ollama = "ollama",
10
10
  Bedrock = "bedrock",
11
+ Xai = "xai",
11
12
  }
12
13
 
13
14
  const LlmSchema = z.object({
@@ -13,4 +13,5 @@ export const modelProviders: Record<string, () => Promise<ModelProvider>> = {
13
13
  google: () => import("./google.ts"),
14
14
  ollama: () => import("./ollama/index.ts"),
15
15
  openai: () => import("./openai.ts"),
16
+ xai: () => import("./xai.ts"),
16
17
  };
@@ -0,0 +1,47 @@
1
+ import { createXai, xai } from "@ai-sdk/xai";
2
+ import { VercelModel } from "@strands-agents/sdk/models/vercel";
3
+ import type { XaiProviderSettings } from "@ai-sdk/xai";
4
+ import type { VercelModelConfig } from "@strands-agents/sdk/models/vercel";
5
+ import { omit, pick } from "lodash";
6
+
7
+ const PROVIDER_SETTINGS_KEYS = ["apiKey", "baseURL", "headers"] as const;
8
+
9
+ function pickProviderSettings(
10
+ params: Record<string, unknown>,
11
+ ): XaiProviderSettings {
12
+ const picked = pick(params, [...PROVIDER_SETTINGS_KEYS]) as Record<
13
+ string,
14
+ unknown
15
+ >;
16
+ const unset = Object.keys(picked).filter((k) => picked[k] === undefined);
17
+ return omit(picked, unset) as XaiProviderSettings;
18
+ }
19
+
20
+ function pickVercelModelConfig(
21
+ params: Record<string, unknown>,
22
+ ): Partial<VercelModelConfig> {
23
+ return omit(params, [
24
+ ...PROVIDER_SETTINGS_KEYS,
25
+ ]) as Partial<VercelModelConfig>;
26
+ }
27
+
28
+ /**
29
+ * xAI (Grok) via AI SDK + Strands {@link VercelModel}.
30
+ *
31
+ * - **`config.llm.model`**: model id passed to `xai(...)` (e.g. `grok-4.20-non-reasoning`).
32
+ * - **`params`**: {@link XaiProviderSettings} (`apiKey`, `baseURL`, `headers`).
33
+ * If none are set, the default provider is used (`XAI_API_KEY` from env).
34
+ * - Any other `params` keys are forwarded as {@link VercelModelConfig} (e.g. `temperature`, `maxTokens`).
35
+ */
36
+ export function create(
37
+ model: string,
38
+ params: Record<string, unknown> = {},
39
+ ): VercelModel {
40
+ const settings = pickProviderSettings(params);
41
+ const provider = Object.keys(settings).length > 0 ? createXai(settings) : xai;
42
+ const config = pickVercelModelConfig(params);
43
+ return new VercelModel({
44
+ provider: provider(model),
45
+ ...config,
46
+ });
47
+ }