feat: migrate to claude 4 #1

Merged
naomi merged 2 commits from feat/claude-4 into main 2025-05-22 11:28:26 -07:00
3 changed files with 346 additions and 449 deletions

View File

@ -14,18 +14,18 @@
"author": "Naomi Carrigan",
"license": "See license in LICENSE.md",
"devDependencies": {
"@nhcarrigan/eslint-config": "5.1.0",
"@nhcarrigan/eslint-config": "5.2.0",
"@nhcarrigan/typescript-config": "4.0.0",
"@types/node": "22.13.1",
"@vitest/coverage-istanbul": "3.0.5",
"eslint": "9.20.0",
"typescript": "5.7.3",
"vitest": "3.0.5"
"@types/node": "22.15.21",
"@vitest/coverage-istanbul": "3.1.4",
"eslint": "9.27.0",
"typescript": "5.8.3",
"vitest": "3.1.4"
},
"dependencies": {
"@anthropic-ai/sdk": "0.36.3",
"@anthropic-ai/sdk": "0.52.0",
"@nhcarrigan/logger": "1.0.0",
"discord.js": "14.18.0",
"fastify": "5.2.1"
"discord.js": "14.19.3",
"fastify": "5.3.3"
}
}

769
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@ -11,6 +11,7 @@ import {
import { personality } from "../config/personality.js";
import { ai } from "../utils/ai.js";
import { calculateCost } from "../utils/calculateCost.js";
import { isSubscribedInteraction } from "../utils/isSubscribed.js";
import { logger } from "../utils/logger.js";
import { replyToError } from "../utils/replyToError.js";
@ -24,13 +25,18 @@ export const start = async(
try {
await interaction.deferReply({ flags: [ MessageFlags.Ephemeral ] });
const subbed = await isSubscribedInteraction(interaction);
if (!subbed) {
return;
}
const messages = await ai.messages.create({
// eslint-disable-next-line @typescript-eslint/naming-convention -- Required key format for SDK.
max_tokens: 2000,
messages: [
{ content: "Please start a new story for me.", role: "user" },
],
model: "claude-3-5-sonnet-latest",
model: "claude-sonnet-4-20250514",
system: `${personality} The user has requested to start a new adventure. You should generate the first message for the game. The user's name is ${interaction.user.displayName}`,
});