@sprucelabs/sprucebot-llm 11.0.15 → 11.0.17

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.
@@ -3,6 +3,7 @@ import { LlmAdapter, SendMessageOptions, SprucebotLlmBot } from '../../llm.types
3
3
  export default class OpenAiAdapter implements LlmAdapter {
4
4
  static OpenAI: typeof OpenAI;
5
5
  private api;
6
+ private log;
6
7
  protected constructor(apiKey: string);
7
8
  static Adapter(apiKey: string): OpenAiAdapter;
8
9
  sendMessage(bot: SprucebotLlmBot, options?: SendMessageOptions): Promise<string>;
@@ -5,11 +5,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.MESSAGE_RESPONSE_ERROR_MESSAGE = void 0;
7
7
  const schema_1 = require("@sprucelabs/schema");
8
+ const spruce_skill_utils_1 = require("@sprucelabs/spruce-skill-utils");
8
9
  const openai_1 = __importDefault(require("openai"));
9
10
  const OpenAiMessageBuilder_1 = __importDefault(require("./OpenAiMessageBuilder"));
10
11
  class OpenAiAdapter {
11
- // private log = buildLog('SprucebotLLM::OpenAiAdapter')
12
12
  constructor(apiKey) {
13
+ this.log = (0, spruce_skill_utils_1.buildLog)('SprucebotLLM::OpenAiAdapter');
13
14
  (0, schema_1.assertOptions)({ apiKey }, ['apiKey']);
14
15
  this.api = new OpenAiAdapter.OpenAI({ apiKey });
15
16
  }
@@ -19,17 +20,14 @@ class OpenAiAdapter {
19
20
  async sendMessage(bot, options) {
20
21
  const messageBuilder = OpenAiMessageBuilder_1.default.Builder(bot);
21
22
  const messages = messageBuilder.buildMessages();
22
- // this.log.info(
23
- // 'Sending message to OpenAI',
24
- // JSON.stringify(messages, null, 2)
25
- // )
23
+ this.log.info('Sending message to OpenAI', JSON.stringify(messages, null, 2));
26
24
  const response = await this.api.chat.completions.create({
27
25
  messages,
28
26
  model: options?.model ?? 'gpt-4o',
29
27
  });
30
28
  const message = response.choices?.[0]?.message?.content?.trim() ??
31
29
  exports.MESSAGE_RESPONSE_ERROR_MESSAGE;
32
- // this.log.info('Received response from OpenAI', message)
30
+ this.log.info('Received response from OpenAI', message);
33
31
  return message;
34
32
  }
35
33
  }
@@ -3,6 +3,7 @@ import { LlmAdapter, SendMessageOptions, SprucebotLlmBot } from '../../llm.types
3
3
  export default class OpenAiAdapter implements LlmAdapter {
4
4
  static OpenAI: typeof OpenAI;
5
5
  private api;
6
+ private log;
6
7
  protected constructor(apiKey: string);
7
8
  static Adapter(apiKey: string): OpenAiAdapter;
8
9
  sendMessage(bot: SprucebotLlmBot, options?: SendMessageOptions): Promise<string>;
@@ -8,11 +8,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
8
8
  });
9
9
  };
10
10
  import { assertOptions } from '@sprucelabs/schema';
11
+ import { buildLog } from '@sprucelabs/spruce-skill-utils';
11
12
  import OpenAI from 'openai';
12
13
  import OpenAiMessageBuilder from './OpenAiMessageBuilder.js';
13
14
  class OpenAiAdapter {
14
- // private log = buildLog('SprucebotLLM::OpenAiAdapter')
15
15
  constructor(apiKey) {
16
+ this.log = buildLog('SprucebotLLM::OpenAiAdapter');
16
17
  assertOptions({ apiKey }, ['apiKey']);
17
18
  this.api = new OpenAiAdapter.OpenAI({ apiKey });
18
19
  }
@@ -24,16 +25,13 @@ class OpenAiAdapter {
24
25
  var _a, _b, _c, _d, _e, _f;
25
26
  const messageBuilder = OpenAiMessageBuilder.Builder(bot);
26
27
  const messages = messageBuilder.buildMessages();
27
- // this.log.info(
28
- // 'Sending message to OpenAI',
29
- // JSON.stringify(messages, null, 2)
30
- // )
28
+ this.log.info('Sending message to OpenAI', JSON.stringify(messages, null, 2));
31
29
  const response = yield this.api.chat.completions.create({
32
30
  messages,
33
31
  model: (_a = options === null || options === void 0 ? void 0 : options.model) !== null && _a !== void 0 ? _a : 'gpt-4o',
34
32
  });
35
33
  const message = (_f = (_e = (_d = (_c = (_b = response.choices) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.message) === null || _d === void 0 ? void 0 : _d.content) === null || _e === void 0 ? void 0 : _e.trim()) !== null && _f !== void 0 ? _f : MESSAGE_RESPONSE_ERROR_MESSAGE;
36
- // this.log.info('Received response from OpenAI', message)
34
+ this.log.info('Received response from OpenAI', message);
37
35
  return message;
38
36
  });
39
37
  }
package/package.json CHANGED
@@ -5,11 +5,10 @@
5
5
  "namespace": "sprucebot-llm",
6
6
  "upgradeIgnoreList": [
7
7
  "@sprucelabs/spruce-core-schemas",
8
- "@sprucelabs/spruce-skill-utils",
9
8
  "eta"
10
9
  ]
11
10
  },
12
- "version": "11.0.15",
11
+ "version": "11.0.17",
13
12
  "files": [
14
13
  "build"
15
14
  ],
@@ -54,10 +53,11 @@
54
53
  "chat.images": "node ./build/chatWithImages.js"
55
54
  },
56
55
  "dependencies": {
57
- "@sprucelabs/error": "^8.0.4",
58
- "@sprucelabs/mercury-event-emitter": "^45.0.16",
59
- "@sprucelabs/mercury-types": "^49.0.13",
60
- "@sprucelabs/schema": "^33.0.9",
56
+ "@sprucelabs/error": "^8.0.5",
57
+ "@sprucelabs/mercury-event-emitter": "^45.0.19",
58
+ "@sprucelabs/mercury-types": "^49.0.15",
59
+ "@sprucelabs/schema": "^33.0.11",
60
+ "@sprucelabs/spruce-skill-utils": "^33.0.14",
61
61
  "eta": "3.5.0",
62
62
  "openai": "^6.9.1"
63
63
  },
@@ -65,12 +65,12 @@
65
65
  "eta": "3.5.0"
66
66
  },
67
67
  "devDependencies": {
68
- "@sprucelabs/esm-postbuild": "^9.0.4",
69
- "@sprucelabs/jest-json-reporter": "^10.0.6",
70
- "@sprucelabs/resolve-path-aliases": "^4.0.5",
68
+ "@sprucelabs/esm-postbuild": "^9.0.6",
69
+ "@sprucelabs/jest-json-reporter": "^10.0.8",
70
+ "@sprucelabs/resolve-path-aliases": "^4.0.7",
71
71
  "@sprucelabs/semantic-release": "^6.0.0",
72
- "@sprucelabs/test": "^11.0.0",
73
- "@sprucelabs/test-utils": "^7.0.9",
72
+ "@sprucelabs/test": "^11.0.2",
73
+ "@sprucelabs/test-utils": "^7.0.11",
74
74
  "@types/node": "^24.10.1",
75
75
  "chokidar-cli": "^3.0.0",
76
76
  "dotenv": "^17.2.3",
@@ -78,7 +78,7 @@
78
78
  "eslint-config-spruce": "^11.2.26",
79
79
  "jest": "^30.2.0",
80
80
  "jest-circus": "^30.2.0",
81
- "prettier": "^3.6.2",
81
+ "prettier": "^3.7.2",
82
82
  "ts-node": "^10.9.2",
83
83
  "tsc-watch": "^7.2.0",
84
84
  "typescript": "^5.9.3"