Compare commits

..

2 Commits

Author SHA1 Message Date
a82122561a
feat: migrate to claude 4
All checks were successful
Node.js CI / Lint and Test (pull_request) Successful in 40s
Also resolves the issue where commands were used without an active sub
2025-05-22 11:24:54 -07:00
dcb61d9c5b
chore: update deps 2025-05-22 11:22:43 -07:00
3 changed files with 346 additions and 449 deletions

View File

@ -14,18 +14,18 @@
"author": "Naomi Carrigan", "author": "Naomi Carrigan",
"license": "See license in LICENSE.md", "license": "See license in LICENSE.md",
"devDependencies": { "devDependencies": {
"@nhcarrigan/eslint-config": "5.1.0", "@nhcarrigan/eslint-config": "5.2.0",
"@nhcarrigan/typescript-config": "4.0.0", "@nhcarrigan/typescript-config": "4.0.0",
"@types/node": "22.13.1", "@types/node": "22.15.21",
"@vitest/coverage-istanbul": "3.0.5", "@vitest/coverage-istanbul": "3.1.4",
"eslint": "9.20.0", "eslint": "9.27.0",
"typescript": "5.7.3", "typescript": "5.8.3",
"vitest": "3.0.5" "vitest": "3.1.4"
}, },
"dependencies": { "dependencies": {
"@anthropic-ai/sdk": "0.36.3", "@anthropic-ai/sdk": "0.52.0",
"@nhcarrigan/logger": "1.0.0", "@nhcarrigan/logger": "1.0.0",
"discord.js": "14.18.0", "discord.js": "14.19.3",
"fastify": "5.2.1" "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 { personality } from "../config/personality.js";
import { ai } from "../utils/ai.js"; import { ai } from "../utils/ai.js";
import { calculateCost } from "../utils/calculateCost.js"; import { calculateCost } from "../utils/calculateCost.js";
import { isSubscribedInteraction } from "../utils/isSubscribed.js";
import { logger } from "../utils/logger.js"; import { logger } from "../utils/logger.js";
import { replyToError } from "../utils/replyToError.js"; import { replyToError } from "../utils/replyToError.js";
@ -24,13 +25,18 @@ export const start = async(
try { try {
await interaction.deferReply({ flags: [ MessageFlags.Ephemeral ] }); await interaction.deferReply({ flags: [ MessageFlags.Ephemeral ] });
const subbed = await isSubscribedInteraction(interaction);
if (!subbed) {
return;
}
const messages = await ai.messages.create({ const messages = await ai.messages.create({
// eslint-disable-next-line @typescript-eslint/naming-convention -- Required key format for SDK. // eslint-disable-next-line @typescript-eslint/naming-convention -- Required key format for SDK.
max_tokens: 2000, max_tokens: 2000,
messages: [ messages: [
{ content: "Please start a new story for me.", role: "user" }, { 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}`, 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}`,
}); });