Merge pull request #160 from yanyao2333/fix-code-block-format

将AI返回内容中的markdown代码块转换为普通json
This commit is contained in:
Del 2024-07-24 15:18:59 +08:00 committed by GitHub
commit 5d455e2ffe
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 45 additions and 24 deletions

View File

@ -1,5 +1,6 @@
import { Memory, Message, Room, User } from "@prisma/client"; import { Memory, Message, Room, User } from "@prisma/client";
import { firstOf, lastOf } from "../../../utils/base"; import { firstOf, lastOf } from "../../../utils/base";
import { Logger } from "../../../utils/log";
import { MemoryCRUD } from "../../db/memory"; import { MemoryCRUD } from "../../db/memory";
import { LongTermMemoryCRUD } from "../../db/memory-long-term"; import { LongTermMemoryCRUD } from "../../db/memory-long-term";
import { ShortTermMemoryCRUD } from "../../db/memory-short-term"; import { ShortTermMemoryCRUD } from "../../db/memory-short-term";
@ -15,6 +16,7 @@ export class MemoryManager {
* owner * owner
*/ */
private owner?: User; private owner?: User;
private _logger = Logger.create({ tag: "Memory" });
constructor(room: Room, owner?: User) { constructor(room: Room, owner?: User) {
this.room = room; this.room = room;
@ -118,6 +120,7 @@ export class MemoryManager {
lastMemory, lastMemory,
}); });
if (!newMemory) { if (!newMemory) {
this._logger.error("💀 生成短期记忆失败");
return false; return false;
} }
const res = await ShortTermMemoryCRUD.addOrUpdate({ const res = await ShortTermMemoryCRUD.addOrUpdate({
@ -151,6 +154,7 @@ export class MemoryManager {
lastMemory, lastMemory,
}); });
if (!newMemory) { if (!newMemory) {
this._logger.error("💀 生成长期记忆失败");
return false; return false;
} }
const res = await LongTermMemoryCRUD.addOrUpdate({ const res = await LongTermMemoryCRUD.addOrUpdate({

View File

@ -1,6 +1,7 @@
import { LongTermMemory, ShortTermMemory } from "@prisma/client"; import { LongTermMemory, ShortTermMemory } from "@prisma/client";
import { jsonDecode, lastOf } from "../../../utils/base"; import { lastOf } from "../../../utils/base";
import { buildPrompt } from "../../../utils/string"; import { buildPrompt } from "../../../utils/string";
import { cleanJsonAndDecode } from "../../../utils/parse";
import { openai } from "../../openai"; import { openai } from "../../openai";
import { MessageContext } from "../conversation"; import { MessageContext } from "../conversation";
@ -67,6 +68,6 @@ export class LongTermMemoryAgent {
shortTermMemory: lastOf(newMemories)!.text, shortTermMemory: lastOf(newMemories)!.text,
}), }),
}); });
return jsonDecode(res?.content)?.longTermMemories?.toString(); return cleanJsonAndDecode(res?.content)?.longTermMemories?.toString();
} }
} }

View File

@ -1,5 +1,5 @@
import { Memory, Message, ShortTermMemory, User } from "@prisma/client"; import { Memory, Message, ShortTermMemory, User } from "@prisma/client";
import { jsonDecode } from "../../../utils/base"; import { cleanJsonAndDecode } from "../../../utils/parse";
import { buildPrompt, formatMsg } from "../../../utils/string"; import { buildPrompt, formatMsg } from "../../../utils/string";
import { openai } from "../../openai"; import { openai } from "../../openai";
import { MessageContext } from "../conversation"; import { MessageContext } from "../conversation";
@ -78,6 +78,6 @@ export class ShortTermMemoryAgent {
.join("\n"), .join("\n"),
}), }),
}); });
return jsonDecode(res?.content)?.shortTermMemories?.toString(); return cleanJsonAndDecode(res?.content)?.shortTermMemories?.toString();
} }
} }

View File

@ -5,7 +5,8 @@ import {
getMiIOT, getMiIOT,
getMiNA, getMiNA,
} from "mi-service-lite"; } from "mi-service-lite";
import { clamp, jsonEncode, sleep } from "../../utils/base"; import { clamp, sleep } from "../../utils/base";
import { jsonEncode } from "../../utils/parse";
import { Logger } from "../../utils/log"; import { Logger } from "../../utils/log";
import { StreamResponse } from "./stream"; import { StreamResponse } from "./stream";
import { kAreYouOK } from "../../utils/string"; import { kAreYouOK } from "../../utils/string";

View File

@ -1,4 +1,5 @@
import { isEmpty } from "./is"; import { isEmpty } from "./is";
import { jsonEncode } from "./parse"
export function timestamp() { export function timestamp() {
return new Date().getTime(); return new Date().getTime();
@ -87,24 +88,6 @@ export function toSet<T = any>(datas: T[], byKey?: (e: T) => any) {
return Array.from(new Set(datas)); return Array.from(new Set(datas));
} }
export function jsonEncode(obj: any, options?: { prettier?: boolean }) {
const { prettier } = options ?? {};
try {
return prettier ? JSON.stringify(obj, undefined, 4) : JSON.stringify(obj);
} catch (error) {
return undefined;
}
}
export function jsonDecode(json: string | null | undefined) {
if (json == undefined) return undefined;
try {
return JSON.parse(json!);
} catch (error) {
return undefined;
}
}
export function withDefault<T = any>(e: any, defaultValue: T): T { export function withDefault<T = any>(e: any, defaultValue: T): T {
return isEmpty(e) ? defaultValue : e; return isEmpty(e) ? defaultValue : e;
} }

View File

@ -1,7 +1,7 @@
import fs from "fs-extra"; import fs from "fs-extra";
import path from "path"; import path from "path";
import { jsonDecode, jsonEncode } from "./base"; import { jsonDecode, jsonEncode } from "./parse";
export const kRoot = process.cwd(); export const kRoot = process.cwd();

32
src/utils/parse.ts Normal file
View File

@ -0,0 +1,32 @@
/**
* json字符串前后的其他字符,
*/
export function cleanJsonAndDecode(input: string | undefined | null) {
if (input == undefined) return undefined;
const pattern = /(\{[\s\S]*?"\s*:\s*[\s\S]*?})/;
const match = input.match(pattern);
if (!match) {
return undefined;
}
return jsonDecode(match[0]);
}
export function jsonEncode(obj: any, options?: { prettier?: boolean }) {
const { prettier } = options ?? {};
try {
return prettier ? JSON.stringify(obj, undefined, 4) : JSON.stringify(obj);
} catch (error) {
return undefined;
}
}
export function jsonDecode(json: string | null | undefined) {
if (json == undefined) return undefined;
try {
return JSON.parse(json!);
} catch (error) {
return undefined;
}
}