repoburg 1.3.43 → 1.3.44
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/backend/.env +6 -7
- package/backend/dist/src/app.module.js +3 -0
- package/backend/dist/src/app.module.js.map +1 -1
- package/backend/dist/src/core-entities/index.d.ts +1 -0
- package/backend/dist/src/core-entities/index.js +1 -0
- package/backend/dist/src/core-entities/index.js.map +1 -1
- package/backend/dist/src/core-entities/llm-call-log.entity.d.ts +14 -0
- package/backend/dist/src/core-entities/llm-call-log.entity.js +68 -0
- package/backend/dist/src/core-entities/llm-call-log.entity.js.map +1 -0
- package/backend/dist/src/llm-call-logs/dto/llm-call-log.dto.d.ts +13 -0
- package/backend/dist/src/llm-call-logs/dto/llm-call-log.dto.js +68 -0
- package/backend/dist/src/llm-call-logs/dto/llm-call-log.dto.js.map +1 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.controller.d.ts +13 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.controller.js +85 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.controller.js.map +1 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.module.d.ts +2 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.module.js +26 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.module.js.map +1 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.service.d.ts +26 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.service.js +104 -0
- package/backend/dist/src/llm-call-logs/llm-call-logs.service.js.map +1 -0
- package/backend/dist/src/llm-provider/llm-provider.module.js +2 -1
- package/backend/dist/src/llm-provider/llm-provider.module.js.map +1 -1
- package/backend/dist/src/llm-provider/openrouter-llm.provider.d.ts +4 -1
- package/backend/dist/src/llm-provider/openrouter-llm.provider.js +123 -10
- package/backend/dist/src/llm-provider/openrouter-llm.provider.js.map +1 -1
- package/backend/dist/src/llm-provider/zai-llm.provider.d.ts +4 -1
- package/backend/dist/src/llm-provider/zai-llm.provider.js +120 -9
- package/backend/dist/src/llm-provider/zai-llm.provider.js.map +1 -1
- package/backend/dist/src/seeding/data/system-prompts/native_tool_agent.d.ts +1 -1
- package/backend/dist/src/seeding/data/system-prompts/native_tool_agent.js +6 -1
- package/backend/dist/src/seeding/data/system-prompts/native_tool_agent.js.map +1 -1
- package/backend/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/backend/dist/migrations/1700000000000-AddEnabledToolsToSystemPrompts.d.ts +0 -6
- package/backend/dist/migrations/1700000000000-AddEnabledToolsToSystemPrompts.js +0 -22
- package/backend/dist/migrations/1700000000000-AddEnabledToolsToSystemPrompts.js.map +0 -1
- package/backend/migrations/1700000000000-AddEnabledToolsToSystemPrompts.ts +0 -21
package/backend/.env
CHANGED
|
@@ -1,10 +1,3 @@
|
|
|
1
|
-
#REPOBURG_PROJECT_PATH='/Users/celalertug/WebstormProjects/hihiho'
|
|
2
|
-
#REPOBURG_PROJECT_PATH='/Users/celalertug/github/webcoder'
|
|
3
|
-
#REPOBURG_PROJECT_PATH='/Users/celalertug/WebstormProjects/appdb'
|
|
4
|
-
#REPOBURG_PROJECT_PATH='/tmp/a/cleanappdev'
|
|
5
|
-
#REPOBURG_PROJECT_PATH='/Users/celalertug/everest/cleanappdev'
|
|
6
|
-
#REPOBURG_PROJECT_PATH='/Users/celalertug/github/vscode'
|
|
7
|
-
|
|
8
1
|
#react project
|
|
9
2
|
#REPOBURG_PROJECT_PATH='/Users/celalertug/WebstormProjects/ttt1234'
|
|
10
3
|
#REPOBURG_PROJECT_PATH=/Users/celalertug/Desktop/tmp/repoburg-preview-boilerplate-main
|
|
@@ -14,3 +7,9 @@
|
|
|
14
7
|
|
|
15
8
|
# handbag
|
|
16
9
|
REPOBURG_PROJECT_PATH=/Users/celalertug/tmp/handbag-main
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# appdev
|
|
15
|
+
#REPOBURG_PROJECT_PATH=/Users/celalertug/everest/tmpappdev
|
|
@@ -38,6 +38,7 @@ const custom_variables_module_1 = require("./custom-variables/custom-variables.m
|
|
|
38
38
|
const tool_hooks_module_1 = require("./tool-hooks/tool-hooks.module");
|
|
39
39
|
const message_bus_module_1 = require("./message-bus/message-bus.module");
|
|
40
40
|
const session_input_subscriber_1 = require("./session-inputs/session-input.subscriber");
|
|
41
|
+
const llm_call_logs_module_1 = require("./llm-call-logs/llm-call-logs.module");
|
|
41
42
|
let dbPath = ':memory:';
|
|
42
43
|
if (process.env.NODE_ENV === 'production') {
|
|
43
44
|
const projectPath = process.env.REPOBURG_PROJECT_PATH || process.cwd();
|
|
@@ -72,6 +73,7 @@ exports.AppModule = AppModule = __decorate([
|
|
|
72
73
|
core_entities_1.McpTool,
|
|
73
74
|
core_entities_1.CustomVariable,
|
|
74
75
|
core_entities_1.ToolHook,
|
|
76
|
+
core_entities_1.LlmCallLog,
|
|
75
77
|
],
|
|
76
78
|
subscribers: [session_input_subscriber_1.SessionInputSubscriber],
|
|
77
79
|
synchronize: true,
|
|
@@ -100,6 +102,7 @@ exports.AppModule = AppModule = __decorate([
|
|
|
100
102
|
custom_variables_module_1.CustomVariablesModule,
|
|
101
103
|
tool_hooks_module_1.ToolHooksModule,
|
|
102
104
|
message_bus_module_1.MessageBusModule,
|
|
105
|
+
llm_call_logs_module_1.LlmCallLogsModule,
|
|
103
106
|
],
|
|
104
107
|
controllers: [app_controller_1.AppController],
|
|
105
108
|
providers: [app_service_1.AppService],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qDAAiD;AACjD,+CAA2C;AAC3C,6CAAgD;AAChD,
|
|
1
|
+
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qDAAiD;AACjD,+CAA2C;AAC3C,6CAAgD;AAChD,mDAgByB;AACzB,gEAA4D;AAC5D,gEAA4D;AAC5D,kFAA6E;AAC7E,sEAAiE;AACjE,kFAA6E;AAC7E,2FAAsF;AACtF,8FAAyF;AACzF,kFAA6E;AAC7E,6DAAyD;AACzD,mEAA+D;AAC/D,qFAAgF;AAChF,6BAA6B;AAC7B,yBAAyB;AACzB,wFAAmF;AACnF,wFAAmF;AACnF,2FAAsF;AACtF,+EAA0E;AAC1E,0DAAsD;AACtD,wFAAmF;AACnF,gEAAuE;AACvE,iDAA6C;AAC7C,+EAA0E;AAC1E,wFAAmF;AACnF,sEAAiE;AACjE,yEAAoE;AACpE,wFAAmF;AACnF,+EAAyE;AAEzE,IAAI,MAAM,GAAG,UAAU,CAAC;AAExB,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;IAC1C,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IACvE,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;IAClD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,EAAE,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,CAAC;IACD,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;IACzC,OAAO,CAAC,GAAG,CAAC,iCAAiC,MAAM,EAAE,CAAC,CAAC;AACzD,CAAC;AAwDM,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IAtDrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,OAAO,CAAC;gBACpB,IAAI,EAAE,QAAQ;gBACd,QAAQ,EAAE,MAAM;gBAChB,QAAQ,EAAE;oBACR,uBAAO;oBACP,uBAAO;oBACP,+BAAe;oBACf,4BAAY;oBACZ,wBAAQ;oBACR,4BAAY;oBACZ,4BAAY;oBACZ,6BAAa;oBACb,gCAAgB;oBAChB,8BAAc;oBACd,yBAAS;oBACT,uBAAO;oBACP,8BAAc;oBACd,wBAAQ;oBACR,0BAAU;iBACX;gBACD,WAAW,EAAE,CAAC,iDAAsB,CAAC;gBACrC,WAAW,EAAE,IAAI;gBACjB,gBAAgB,EAAE,IAAI;aACvB,CAAC;YACF,gCAAc;YACd,gCAAc;YACd,2CAAmB;YACnB,mCAAe;YACf,2CAAmB;YACnB,iDAAsB;YACtB,mDAAuB;YACvB,2CAAmB;YACnB,8BAAa;YACb,kCAAe;YACf,6CAAoB;YACpB,+CAAqB;YACrB,+CAAqB;YACrB,iDAAsB;YACtB,yCAAkB;YAClB,4BAAY;YACZ,+CAAqB;YACrB,mCAAqB;YACrB,sBAAS;YACT,yCAAkB;YAClB,+CAAqB;YACrB,mCAAe;YACf,qCAAgB;YAChB,wCAAiB;SAClB;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,CAAC;KACxB,CAAC;GACW,SAAS,CAAG"}
|
|
@@ -29,4 +29,5 @@ __exportStar(require("./mcp-config.entity"), exports);
|
|
|
29
29
|
__exportStar(require("./mcp-tool.entity"), exports);
|
|
30
30
|
__exportStar(require("./custom-variable.entity"), exports);
|
|
31
31
|
__exportStar(require("./tool-hook.entity"), exports);
|
|
32
|
+
__exportStar(require("./llm-call-log.entity"), exports);
|
|
32
33
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core-entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,mDAAiC;AACjC,mDAAiC;AACjC,4DAA0C;AAC1C,yDAAuC;AACvC,qDAAmC;AACnC,yDAAuC;AACvC,yDAAuC;AACvC,0DAAwC;AACxC,6DAA2C;AAC3C,2DAAyC;AACzC,sDAAoC;AACpC,oDAAkC;AAClC,2DAAyC;AACzC,qDAAmC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core-entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA8B;AAC9B,mDAAiC;AACjC,mDAAiC;AACjC,4DAA0C;AAC1C,yDAAuC;AACvC,qDAAmC;AACnC,yDAAuC;AACvC,yDAAuC;AACvC,0DAAwC;AACxC,6DAA2C;AAC3C,2DAAyC;AACzC,sDAAoC;AACpC,oDAAkC;AAClC,2DAAyC;AACzC,qDAAmC;AACnC,wDAAsC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseEntity } from '../core-entities/base.entity';
|
|
2
|
+
export declare class LlmCallLog extends BaseEntity {
|
|
3
|
+
session_input_id: string | null;
|
|
4
|
+
provider: 'zai' | 'openrouter' | 'gemini';
|
|
5
|
+
model_id: string;
|
|
6
|
+
request_body: string;
|
|
7
|
+
response_body: string | null;
|
|
8
|
+
status_code: number | null;
|
|
9
|
+
latency_ms: number | null;
|
|
10
|
+
input_tokens: number | null;
|
|
11
|
+
output_tokens: number | null;
|
|
12
|
+
cached_tokens: number | null;
|
|
13
|
+
error_message: string | null;
|
|
14
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.LlmCallLog = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const base_entity_1 = require("../core-entities/base.entity");
|
|
15
|
+
let LlmCallLog = class LlmCallLog extends base_entity_1.BaseEntity {
|
|
16
|
+
};
|
|
17
|
+
exports.LlmCallLog = LlmCallLog;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, typeorm_1.Index)(),
|
|
20
|
+
(0, typeorm_1.Column)({ type: 'varchar', nullable: true }),
|
|
21
|
+
__metadata("design:type", String)
|
|
22
|
+
], LlmCallLog.prototype, "session_input_id", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
(0, typeorm_1.Index)(),
|
|
25
|
+
(0, typeorm_1.Column)({ type: 'text' }),
|
|
26
|
+
__metadata("design:type", String)
|
|
27
|
+
], LlmCallLog.prototype, "provider", void 0);
|
|
28
|
+
__decorate([
|
|
29
|
+
(0, typeorm_1.Index)(),
|
|
30
|
+
(0, typeorm_1.Column)({ type: 'text' }),
|
|
31
|
+
__metadata("design:type", String)
|
|
32
|
+
], LlmCallLog.prototype, "model_id", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, typeorm_1.Column)({ type: 'text' }),
|
|
35
|
+
__metadata("design:type", String)
|
|
36
|
+
], LlmCallLog.prototype, "request_body", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
39
|
+
__metadata("design:type", String)
|
|
40
|
+
], LlmCallLog.prototype, "response_body", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.Column)({ type: 'integer', nullable: true }),
|
|
43
|
+
__metadata("design:type", Number)
|
|
44
|
+
], LlmCallLog.prototype, "status_code", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, typeorm_1.Column)({ type: 'integer', nullable: true }),
|
|
47
|
+
__metadata("design:type", Number)
|
|
48
|
+
], LlmCallLog.prototype, "latency_ms", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, typeorm_1.Column)({ type: 'integer', nullable: true }),
|
|
51
|
+
__metadata("design:type", Number)
|
|
52
|
+
], LlmCallLog.prototype, "input_tokens", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, typeorm_1.Column)({ type: 'integer', nullable: true }),
|
|
55
|
+
__metadata("design:type", Number)
|
|
56
|
+
], LlmCallLog.prototype, "output_tokens", void 0);
|
|
57
|
+
__decorate([
|
|
58
|
+
(0, typeorm_1.Column)({ type: 'integer', nullable: true }),
|
|
59
|
+
__metadata("design:type", Number)
|
|
60
|
+
], LlmCallLog.prototype, "cached_tokens", void 0);
|
|
61
|
+
__decorate([
|
|
62
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
63
|
+
__metadata("design:type", String)
|
|
64
|
+
], LlmCallLog.prototype, "error_message", void 0);
|
|
65
|
+
exports.LlmCallLog = LlmCallLog = __decorate([
|
|
66
|
+
(0, typeorm_1.Entity)('llm_call_logs')
|
|
67
|
+
], LlmCallLog);
|
|
68
|
+
//# sourceMappingURL=llm-call-log.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-call-log.entity.js","sourceRoot":"","sources":["../../../src/core-entities/llm-call-log.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAAgD;AAChD,8DAA0D;AAGnD,IAAM,UAAU,GAAhB,MAAM,UAAW,SAAQ,wBAAU;CAoCzC,CAAA;AApCY,gCAAU;AAGrB;IAFC,IAAA,eAAK,GAAE;IACP,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;oDACZ;AAIhC;IAFC,IAAA,eAAK,GAAE;IACP,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;4CACiB;AAI1C;IAFC,IAAA,eAAK,GAAE;IACP,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;4CACR;AAGjB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;gDACJ;AAGrB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACZ;AAG7B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;+CACjB;AAG3B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CAClB;AAG1B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDAChB;AAG5B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACf;AAG7B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACf;AAG7B;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACZ;qBAnClB,UAAU;IADtB,IAAA,gBAAM,EAAC,eAAe,CAAC;GACX,UAAU,CAoCtB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class CreateLlmCallLogDto {
|
|
2
|
+
session_input_id: string;
|
|
3
|
+
provider: 'zai' | 'openrouter' | 'gemini';
|
|
4
|
+
model_id: string;
|
|
5
|
+
request_body: string;
|
|
6
|
+
response_body?: string | null;
|
|
7
|
+
status_code?: number | null;
|
|
8
|
+
latency_ms?: number | null;
|
|
9
|
+
input_tokens?: number | null;
|
|
10
|
+
output_tokens?: number | null;
|
|
11
|
+
cached_tokens?: number | null;
|
|
12
|
+
error_message?: string | null;
|
|
13
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.CreateLlmCallLogDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
class CreateLlmCallLogDto {
|
|
15
|
+
}
|
|
16
|
+
exports.CreateLlmCallLogDto = CreateLlmCallLogDto;
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, class_validator_1.IsString)(),
|
|
19
|
+
__metadata("design:type", String)
|
|
20
|
+
], CreateLlmCallLogDto.prototype, "session_input_id", void 0);
|
|
21
|
+
__decorate([
|
|
22
|
+
(0, class_validator_1.IsEnum)(['zai', 'openrouter', 'gemini']),
|
|
23
|
+
__metadata("design:type", String)
|
|
24
|
+
], CreateLlmCallLogDto.prototype, "provider", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, class_validator_1.IsString)(),
|
|
27
|
+
__metadata("design:type", String)
|
|
28
|
+
], CreateLlmCallLogDto.prototype, "model_id", void 0);
|
|
29
|
+
__decorate([
|
|
30
|
+
(0, class_validator_1.IsString)(),
|
|
31
|
+
__metadata("design:type", String)
|
|
32
|
+
], CreateLlmCallLogDto.prototype, "request_body", void 0);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, class_validator_1.IsOptional)(),
|
|
35
|
+
(0, class_validator_1.IsString)(),
|
|
36
|
+
__metadata("design:type", String)
|
|
37
|
+
], CreateLlmCallLogDto.prototype, "response_body", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, class_validator_1.IsOptional)(),
|
|
40
|
+
(0, class_validator_1.IsNumber)(),
|
|
41
|
+
__metadata("design:type", Number)
|
|
42
|
+
], CreateLlmCallLogDto.prototype, "status_code", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, class_validator_1.IsOptional)(),
|
|
45
|
+
(0, class_validator_1.IsNumber)(),
|
|
46
|
+
__metadata("design:type", Number)
|
|
47
|
+
], CreateLlmCallLogDto.prototype, "latency_ms", void 0);
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, class_validator_1.IsOptional)(),
|
|
50
|
+
(0, class_validator_1.IsNumber)(),
|
|
51
|
+
__metadata("design:type", Number)
|
|
52
|
+
], CreateLlmCallLogDto.prototype, "input_tokens", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, class_validator_1.IsOptional)(),
|
|
55
|
+
(0, class_validator_1.IsNumber)(),
|
|
56
|
+
__metadata("design:type", Number)
|
|
57
|
+
], CreateLlmCallLogDto.prototype, "output_tokens", void 0);
|
|
58
|
+
__decorate([
|
|
59
|
+
(0, class_validator_1.IsOptional)(),
|
|
60
|
+
(0, class_validator_1.IsNumber)(),
|
|
61
|
+
__metadata("design:type", Number)
|
|
62
|
+
], CreateLlmCallLogDto.prototype, "cached_tokens", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
(0, class_validator_1.IsOptional)(),
|
|
65
|
+
(0, class_validator_1.IsString)(),
|
|
66
|
+
__metadata("design:type", String)
|
|
67
|
+
], CreateLlmCallLogDto.prototype, "error_message", void 0);
|
|
68
|
+
//# sourceMappingURL=llm-call-log.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-call-log.dto.js","sourceRoot":"","sources":["../../../../src/llm-call-logs/dto/llm-call-log.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAyE;AAEzE,MAAa,mBAAmB;CAwC/B;AAxCD,kDAwCC;AAtCC;IADC,IAAA,0BAAQ,GAAE;;6DACc;AAGzB;IADC,IAAA,wBAAM,EAAC,CAAC,KAAK,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;;qDACE;AAG1C;IADC,IAAA,0BAAQ,GAAE;;qDACM;AAGjB;IADC,IAAA,0BAAQ,GAAE;;yDACU;AAIrB;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;0DACmB;AAI9B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;wDACiB;AAI5B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;uDACgB;AAI3B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;yDACkB;AAI7B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;0DACmB;AAI9B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;0DACmB;AAI9B;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;0DACmB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { LlmCallLogsService } from './llm-call-logs.service';
|
|
2
|
+
import { LlmCallLog } from '../core-entities/llm-call-log.entity';
|
|
3
|
+
export declare class LlmCallLogsController {
|
|
4
|
+
private readonly llmCallLogsService;
|
|
5
|
+
constructor(llmCallLogsService: LlmCallLogsService);
|
|
6
|
+
findAll(sessionId?: string, sessionInputId?: string, provider?: string, status?: string, limit?: string, offset?: string): Promise<{
|
|
7
|
+
logs: LlmCallLog[];
|
|
8
|
+
total: number;
|
|
9
|
+
}>;
|
|
10
|
+
findBySessionInputId(inputId: string): Promise<LlmCallLog[]>;
|
|
11
|
+
findBySessionId(sessionId: string): Promise<LlmCallLog[]>;
|
|
12
|
+
findById(id: string): Promise<LlmCallLog>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.LlmCallLogsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const llm_call_logs_service_1 = require("./llm-call-logs.service");
|
|
18
|
+
let LlmCallLogsController = class LlmCallLogsController {
|
|
19
|
+
constructor(llmCallLogsService) {
|
|
20
|
+
this.llmCallLogsService = llmCallLogsService;
|
|
21
|
+
}
|
|
22
|
+
async findAll(sessionId, sessionInputId, provider, status, limit, offset) {
|
|
23
|
+
return this.llmCallLogsService.findAll({
|
|
24
|
+
sessionId,
|
|
25
|
+
sessionInputId,
|
|
26
|
+
provider,
|
|
27
|
+
status,
|
|
28
|
+
limit: limit ? parseInt(limit, 10) : undefined,
|
|
29
|
+
offset: offset ? parseInt(offset, 10) : undefined,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
async findBySessionInputId(inputId) {
|
|
33
|
+
return this.llmCallLogsService.findBySessionInputId(inputId);
|
|
34
|
+
}
|
|
35
|
+
async findBySessionId(sessionId) {
|
|
36
|
+
return this.llmCallLogsService.findBySessionId(sessionId);
|
|
37
|
+
}
|
|
38
|
+
async findById(id) {
|
|
39
|
+
try {
|
|
40
|
+
return await this.llmCallLogsService.findById(id);
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
throw new common_1.NotFoundException(error.message || 'LLM call log not found');
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
exports.LlmCallLogsController = LlmCallLogsController;
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, common_1.Get)(),
|
|
50
|
+
__param(0, (0, common_1.Query)('sessionId')),
|
|
51
|
+
__param(1, (0, common_1.Query)('sessionInputId')),
|
|
52
|
+
__param(2, (0, common_1.Query)('provider')),
|
|
53
|
+
__param(3, (0, common_1.Query)('status')),
|
|
54
|
+
__param(4, (0, common_1.Query)('limit')),
|
|
55
|
+
__param(5, (0, common_1.Query)('offset')),
|
|
56
|
+
__metadata("design:type", Function),
|
|
57
|
+
__metadata("design:paramtypes", [String, String, String, String, String, String]),
|
|
58
|
+
__metadata("design:returntype", Promise)
|
|
59
|
+
], LlmCallLogsController.prototype, "findAll", null);
|
|
60
|
+
__decorate([
|
|
61
|
+
(0, common_1.Get)('session-input/:inputId'),
|
|
62
|
+
__param(0, (0, common_1.Param)('inputId')),
|
|
63
|
+
__metadata("design:type", Function),
|
|
64
|
+
__metadata("design:paramtypes", [String]),
|
|
65
|
+
__metadata("design:returntype", Promise)
|
|
66
|
+
], LlmCallLogsController.prototype, "findBySessionInputId", null);
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, common_1.Get)('session/:sessionId'),
|
|
69
|
+
__param(0, (0, common_1.Param)('sessionId')),
|
|
70
|
+
__metadata("design:type", Function),
|
|
71
|
+
__metadata("design:paramtypes", [String]),
|
|
72
|
+
__metadata("design:returntype", Promise)
|
|
73
|
+
], LlmCallLogsController.prototype, "findBySessionId", null);
|
|
74
|
+
__decorate([
|
|
75
|
+
(0, common_1.Get)(':id'),
|
|
76
|
+
__param(0, (0, common_1.Param)('id')),
|
|
77
|
+
__metadata("design:type", Function),
|
|
78
|
+
__metadata("design:paramtypes", [String]),
|
|
79
|
+
__metadata("design:returntype", Promise)
|
|
80
|
+
], LlmCallLogsController.prototype, "findById", null);
|
|
81
|
+
exports.LlmCallLogsController = LlmCallLogsController = __decorate([
|
|
82
|
+
(0, common_1.Controller)('llm-call-logs'),
|
|
83
|
+
__metadata("design:paramtypes", [llm_call_logs_service_1.LlmCallLogsService])
|
|
84
|
+
], LlmCallLogsController);
|
|
85
|
+
//# sourceMappingURL=llm-call-logs.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-call-logs.controller.js","sourceRoot":"","sources":["../../../src/llm-call-logs/llm-call-logs.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAMwB;AACxB,mEAA6D;AAItD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAChC,YAA6B,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;IAAG,CAAC;IAGjE,AAAN,KAAK,CAAC,OAAO,CACS,SAAkB,EACb,cAAuB,EAC7B,QAAiB,EACnB,MAAe,EAChB,KAAc,EACb,MAAe;QAEhC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC;YACrC,SAAS;YACT,cAAc;YACd,QAAQ;YACR,MAAM;YACN,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;YAC9C,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;SAClD,CAAC,CAAC;IACL,CAAC;IAGK,AAAN,KAAK,CAAC,oBAAoB,CACN,OAAe;QAEjC,OAAO,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;IAC/D,CAAC;IAGK,AAAN,KAAK,CAAC,eAAe,CACC,SAAiB;QAErC,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;IAC5D,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ,CAAc,EAAU;QACpC,IAAI,CAAC;YACH,OAAO,MAAM,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,0BAAiB,CAAC,KAAK,CAAC,OAAO,IAAI,wBAAwB,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;CACF,CAAA;AA5CY,sDAAqB;AAI1B;IADL,IAAA,YAAG,GAAE;IAEH,WAAA,IAAA,cAAK,EAAC,WAAW,CAAC,CAAA;IAClB,WAAA,IAAA,cAAK,EAAC,gBAAgB,CAAC,CAAA;IACvB,WAAA,IAAA,cAAK,EAAC,UAAU,CAAC,CAAA;IACjB,WAAA,IAAA,cAAK,EAAC,QAAQ,CAAC,CAAA;IACf,WAAA,IAAA,cAAK,EAAC,OAAO,CAAC,CAAA;IACd,WAAA,IAAA,cAAK,EAAC,QAAQ,CAAC,CAAA;;;;oDAUjB;AAGK;IADL,IAAA,YAAG,EAAC,wBAAwB,CAAC;IAE3B,WAAA,IAAA,cAAK,EAAC,SAAS,CAAC,CAAA;;;;iEAGlB;AAGK;IADL,IAAA,YAAG,EAAC,oBAAoB,CAAC;IAEvB,WAAA,IAAA,cAAK,EAAC,WAAW,CAAC,CAAA;;;;4DAGpB;AAGK;IADL,IAAA,YAAG,EAAC,KAAK,CAAC;IACK,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;;;;qDAM1B;gCA3CU,qBAAqB;IADjC,IAAA,mBAAU,EAAC,eAAe,CAAC;qCAEuB,0CAAkB;GADxD,qBAAqB,CA4CjC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.LlmCallLogsModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
12
|
+
const llm_call_log_entity_1 = require("../core-entities/llm-call-log.entity");
|
|
13
|
+
const llm_call_logs_service_1 = require("./llm-call-logs.service");
|
|
14
|
+
const llm_call_logs_controller_1 = require("./llm-call-logs.controller");
|
|
15
|
+
let LlmCallLogsModule = class LlmCallLogsModule {
|
|
16
|
+
};
|
|
17
|
+
exports.LlmCallLogsModule = LlmCallLogsModule;
|
|
18
|
+
exports.LlmCallLogsModule = LlmCallLogsModule = __decorate([
|
|
19
|
+
(0, common_1.Module)({
|
|
20
|
+
imports: [typeorm_1.TypeOrmModule.forFeature([llm_call_log_entity_1.LlmCallLog])],
|
|
21
|
+
controllers: [llm_call_logs_controller_1.LlmCallLogsController],
|
|
22
|
+
providers: [llm_call_logs_service_1.LlmCallLogsService],
|
|
23
|
+
exports: [llm_call_logs_service_1.LlmCallLogsService],
|
|
24
|
+
})
|
|
25
|
+
], LlmCallLogsModule);
|
|
26
|
+
//# sourceMappingURL=llm-call-logs.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-call-logs.module.js","sourceRoot":"","sources":["../../../src/llm-call-logs/llm-call-logs.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,8EAAkE;AAClE,mEAA6D;AAC7D,yEAAmE;AAQ5D,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IAN7B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,uBAAa,CAAC,UAAU,CAAC,CAAC,gCAAU,CAAC,CAAC,CAAC;QACjD,WAAW,EAAE,CAAC,gDAAqB,CAAC;QACpC,SAAS,EAAE,CAAC,0CAAkB,CAAC;QAC/B,OAAO,EAAE,CAAC,0CAAkB,CAAC;KAC9B,CAAC;GACW,iBAAiB,CAAG"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { LlmCallLog } from '../core-entities/llm-call-log.entity';
|
|
3
|
+
import { CreateLlmCallLogDto } from './dto/llm-call-log.dto';
|
|
4
|
+
interface FindAllParams {
|
|
5
|
+
sessionId?: string;
|
|
6
|
+
sessionInputId?: string;
|
|
7
|
+
provider?: string;
|
|
8
|
+
status?: string;
|
|
9
|
+
limit?: number;
|
|
10
|
+
offset?: number;
|
|
11
|
+
}
|
|
12
|
+
export declare class LlmCallLogsService {
|
|
13
|
+
private llmCallLogsRepository;
|
|
14
|
+
private readonly logger;
|
|
15
|
+
constructor(llmCallLogsRepository: Repository<LlmCallLog>);
|
|
16
|
+
createLog(createLlmCallLogDto: CreateLlmCallLogDto): Promise<LlmCallLog>;
|
|
17
|
+
updateLog(id: string, updates: Partial<CreateLlmCallLogDto>): Promise<LlmCallLog>;
|
|
18
|
+
findAll(params: FindAllParams): Promise<{
|
|
19
|
+
logs: LlmCallLog[];
|
|
20
|
+
total: number;
|
|
21
|
+
}>;
|
|
22
|
+
findBySessionInputId(sessionInputId: string): Promise<LlmCallLog[]>;
|
|
23
|
+
findBySessionId(sessionId: string): Promise<LlmCallLog[]>;
|
|
24
|
+
findById(id: string): Promise<LlmCallLog>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var LlmCallLogsService_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.LlmCallLogsService = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
19
|
+
const typeorm_2 = require("typeorm");
|
|
20
|
+
const llm_call_log_entity_1 = require("../core-entities/llm-call-log.entity");
|
|
21
|
+
let LlmCallLogsService = LlmCallLogsService_1 = class LlmCallLogsService {
|
|
22
|
+
constructor(llmCallLogsRepository) {
|
|
23
|
+
this.llmCallLogsRepository = llmCallLogsRepository;
|
|
24
|
+
this.logger = new common_1.Logger(LlmCallLogsService_1.name);
|
|
25
|
+
}
|
|
26
|
+
async createLog(createLlmCallLogDto) {
|
|
27
|
+
this.logger.log(`Creating LLM call log for session input ${createLlmCallLogDto.session_input_id}`);
|
|
28
|
+
const newLog = this.llmCallLogsRepository.create(createLlmCallLogDto);
|
|
29
|
+
return this.llmCallLogsRepository.save(newLog);
|
|
30
|
+
}
|
|
31
|
+
async updateLog(id, updates) {
|
|
32
|
+
await this.llmCallLogsRepository.update(id, updates);
|
|
33
|
+
const log = await this.llmCallLogsRepository.findOneBy({ id });
|
|
34
|
+
if (!log) {
|
|
35
|
+
throw new Error(`LlmCallLog with ID "${id}" not found`);
|
|
36
|
+
}
|
|
37
|
+
return log;
|
|
38
|
+
}
|
|
39
|
+
async findAll(params) {
|
|
40
|
+
const queryBuilder = this.llmCallLogsRepository.createQueryBuilder('llm_call_log');
|
|
41
|
+
if (params.sessionId) {
|
|
42
|
+
queryBuilder.innerJoin('llm_call_log.sessionInput', 'session_input', 'session_input.session_id = :sessionId', { sessionId: params.sessionId });
|
|
43
|
+
}
|
|
44
|
+
if (params.sessionInputId) {
|
|
45
|
+
queryBuilder.andWhere('llm_call_log.session_input_id = :sessionInputId', {
|
|
46
|
+
sessionInputId: params.sessionInputId,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
if (params.provider) {
|
|
50
|
+
queryBuilder.andWhere('llm_call_log.provider = :provider', {
|
|
51
|
+
provider: params.provider,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
if (params.status === 'success') {
|
|
55
|
+
queryBuilder.andWhere('llm_call_log.status_code >= :minSuccess AND llm_call_log.status_code < :maxSuccess', {
|
|
56
|
+
minSuccess: 200,
|
|
57
|
+
maxSuccess: 300,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
else if (params.status === 'error') {
|
|
61
|
+
queryBuilder.andWhere('(llm_call_log.status_code < :minSuccess OR llm_call_log.status_code >= :maxSuccess OR llm_call_log.status_code IS NULL)', {
|
|
62
|
+
minSuccess: 200,
|
|
63
|
+
maxSuccess: 300,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
const total = await queryBuilder.getCount();
|
|
67
|
+
if (params.offset) {
|
|
68
|
+
queryBuilder.skip(params.offset);
|
|
69
|
+
}
|
|
70
|
+
if (params.limit) {
|
|
71
|
+
queryBuilder.take(params.limit);
|
|
72
|
+
}
|
|
73
|
+
queryBuilder.orderBy('llm_call_log.created_at', 'DESC');
|
|
74
|
+
const logs = await queryBuilder.getMany();
|
|
75
|
+
return { logs, total };
|
|
76
|
+
}
|
|
77
|
+
async findBySessionInputId(sessionInputId) {
|
|
78
|
+
return this.llmCallLogsRepository.find({
|
|
79
|
+
where: { session_input_id: sessionInputId },
|
|
80
|
+
order: { created_at: 'DESC' },
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
async findBySessionId(sessionId) {
|
|
84
|
+
return this.llmCallLogsRepository
|
|
85
|
+
.createQueryBuilder('llm_call_log')
|
|
86
|
+
.innerJoin('llm_call_log.sessionInput', 'session_input', 'session_input.session_id = :sessionId', { sessionId })
|
|
87
|
+
.orderBy('llm_call_log.created_at', 'DESC')
|
|
88
|
+
.getMany();
|
|
89
|
+
}
|
|
90
|
+
async findById(id) {
|
|
91
|
+
const log = await this.llmCallLogsRepository.findOneBy({ id });
|
|
92
|
+
if (!log) {
|
|
93
|
+
throw new Error(`LlmCallLog with ID "${id}" not found`);
|
|
94
|
+
}
|
|
95
|
+
return log;
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
exports.LlmCallLogsService = LlmCallLogsService;
|
|
99
|
+
exports.LlmCallLogsService = LlmCallLogsService = LlmCallLogsService_1 = __decorate([
|
|
100
|
+
(0, common_1.Injectable)(),
|
|
101
|
+
__param(0, (0, typeorm_1.InjectRepository)(llm_call_log_entity_1.LlmCallLog)),
|
|
102
|
+
__metadata("design:paramtypes", [typeorm_2.Repository])
|
|
103
|
+
], LlmCallLogsService);
|
|
104
|
+
//# sourceMappingURL=llm-call-logs.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm-call-logs.service.js","sourceRoot":"","sources":["../../../src/llm-call-logs/llm-call-logs.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -15,12 +15,13 @@ const proxy_llm_provider_1 = require("./proxy-llm.provider");
|
|
|
15
15
|
const application_state_module_1 = require("../application-state/application-state.module");
|
|
16
16
|
const llm_provider_controller_1 = require("./llm-provider.controller");
|
|
17
17
|
const zai_llm_provider_1 = require("./zai-llm.provider");
|
|
18
|
+
const llm_call_logs_module_1 = require("../llm-call-logs/llm-call-logs.module");
|
|
18
19
|
let LlmProviderModule = class LlmProviderModule {
|
|
19
20
|
};
|
|
20
21
|
exports.LlmProviderModule = LlmProviderModule;
|
|
21
22
|
exports.LlmProviderModule = LlmProviderModule = __decorate([
|
|
22
23
|
(0, common_1.Module)({
|
|
23
|
-
imports: [gemini_module_1.GeminiModule, application_state_module_1.ApplicationStateModule],
|
|
24
|
+
imports: [gemini_module_1.GeminiModule, application_state_module_1.ApplicationStateModule, llm_call_logs_module_1.LlmCallLogsModule],
|
|
24
25
|
controllers: [llm_provider_controller_1.LlmProviderController],
|
|
25
26
|
providers: [
|
|
26
27
|
openrouter_llm_provider_1.OpenRouterLlmProvider,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"llm-provider.module.js","sourceRoot":"","sources":["../../../src/llm-provider/llm-provider.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qEAAwD;AACxD,2DAAuD;AACvD,uEAAkE;AAClE,6DAAwD;AACxD,4FAAuF;AACvF,uEAAkE;AAClE,yDAAoD;
|
|
1
|
+
{"version":3,"file":"llm-provider.module.js","sourceRoot":"","sources":["../../../src/llm-provider/llm-provider.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qEAAwD;AACxD,2DAAuD;AACvD,uEAAkE;AAClE,6DAAwD;AACxD,4FAAuF;AACvF,uEAAkE;AAClE,yDAAoD;AACpD,gFAA0E;AAenE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,8CAAiB;4BAAjB,iBAAiB;IAb7B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,4BAAY,EAAE,iDAAsB,EAAE,wCAAiB,CAAC;QAClE,WAAW,EAAE,CAAC,+CAAqB,CAAC;QACpC,SAAS,EAAE;YACT,+CAAqB;YACrB,iCAAc;YACd;gBACE,OAAO,EAAE,qCAAY;gBACrB,QAAQ,EAAE,qCAAgB;aAC3B;SACF;QACD,OAAO,EAAE,CAAC,qCAAY,CAAC;KACxB,CAAC;GACW,iBAAiB,CAAG"}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { LlmProvider, LlmProviderRequest, LlmModel, LlmResponse } from './llm-provider.interface';
|
|
2
2
|
import { ApplicationStateService } from '../application-state/application-state.service';
|
|
3
|
+
import { LlmCallLogsService } from '../llm-call-logs/llm-call-logs.service';
|
|
3
4
|
export declare class OpenRouterLlmProvider implements LlmProvider {
|
|
4
5
|
private readonly applicationStateService;
|
|
6
|
+
private readonly llmCallLogsService;
|
|
5
7
|
private readonly logger;
|
|
6
8
|
private activeStreams;
|
|
7
|
-
constructor(applicationStateService: ApplicationStateService);
|
|
9
|
+
constructor(applicationStateService: ApplicationStateService, llmCallLogsService: LlmCallLogsService);
|
|
8
10
|
private mapHistory;
|
|
9
11
|
private mapTools;
|
|
10
12
|
getModels(): Promise<LlmModel[]>;
|
|
11
13
|
generateContent(request: LlmProviderRequest): Promise<LlmResponse>;
|
|
14
|
+
private tryParseJson;
|
|
12
15
|
abortBySessionId(sessionId: string): boolean;
|
|
13
16
|
}
|