From d735e60ad0a17a807ebbba2a273ec466dc188035 Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 12:46:12 +0700 Subject: [PATCH 1/7] change engine syntax --- .../commanders/engines.command.ts | 32 +++++++++++++++++-- .../engines/engines-init.command.ts | 5 ++- 2 files changed, 31 insertions(+), 6 deletions(-) diff --git a/cortex-js/src/infrastructure/commanders/engines.command.ts b/cortex-js/src/infrastructure/commanders/engines.command.ts index 0209d309a..ffea6fe64 100644 --- a/cortex-js/src/infrastructure/commanders/engines.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines.command.ts @@ -4,19 +4,45 @@ import { ContextService } from '@/infrastructure/services/context/context.servic import { EnginesListCommand } from './engines/engines-list.command'; import { EnginesGetCommand } from './engines/engines-get.command'; import { EnginesInitCommand } from './engines/engines-init.command'; +import { ModuleRef } from '@nestjs/core'; @SubCommand({ name: 'engines', subCommands: [EnginesListCommand, EnginesGetCommand, EnginesInitCommand], description: 'Get cortex engines', + arguments: ' [subcommand]', }) @SetCommandContext() export class EnginesCommand extends CommandRunner { - constructor(readonly contextService: ContextService) { + constructor( + readonly contextService: ContextService, + private readonly moduleRef: ModuleRef, + ) { super(); } - async run(): Promise { - this.command?.help(); + async run(passedParam: string[]): Promise { + console.log('Engines command'); + const [parameter, command] = passedParam; + if (command === 'init' && !parameter) { + console.error('Parameter is required for the init command.'); + return; + } + + // Handle the commands accordingly + if (command === 'init') { + await this.runCommand(EnginesInitCommand, [parameter]); + } else { + this.command?.help(); + } + } + + private async runCommand(commandClass: any, params: string[] = []) { + const commandInstance = this.moduleRef.get(commandClass, { strict: false }); + if (commandInstance) { + await commandInstance.run(params); + } else { + console.error('Command not found.'); + } } } diff --git a/cortex-js/src/infrastructure/commanders/engines/engines-init.command.ts b/cortex-js/src/infrastructure/commanders/engines/engines-init.command.ts index 2bbfe0a9f..7ed136c9e 100644 --- a/cortex-js/src/infrastructure/commanders/engines/engines-init.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines/engines-init.command.ts @@ -7,9 +7,8 @@ import { CortexUsecases } from '@/usecases/cortex/cortex.usecases'; import { FileManagerService } from '@/infrastructure/services/file-manager/file-manager.service'; @SubCommand({ - name: 'init', + name: ' init', description: 'Setup engine', - arguments: '', argsDescription: { name: 'Engine name to setup', }, @@ -49,7 +48,7 @@ export class EnginesInitCommand extends CommandRunner { params, engine.includes('@') ? engine.split('@')[1] : 'latest', engine, - true + true, ) .then(() => console.log('Engine installed successfully!')) .catch((e) => From 044f38f537e209f32e857bedbcbe33e5a5e19c24 Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 12:48:25 +0700 Subject: [PATCH 2/7] remove log --- cortex-js/src/infrastructure/commanders/engines.command.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/cortex-js/src/infrastructure/commanders/engines.command.ts b/cortex-js/src/infrastructure/commanders/engines.command.ts index ffea6fe64..b5f64c177 100644 --- a/cortex-js/src/infrastructure/commanders/engines.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines.command.ts @@ -22,7 +22,6 @@ export class EnginesCommand extends CommandRunner { } async run(passedParam: string[]): Promise { - console.log('Engines command'); const [parameter, command] = passedParam; if (command === 'init' && !parameter) { console.error('Parameter is required for the init command.'); From 62687ba4e03fa86b7f2e9dbeabc9c00eadd9d353 Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 14:24:59 +0700 Subject: [PATCH 3/7] shorten engine name, change get engine syntax --- .../commanders/engines.command.ts | 21 +++++++++++++------ .../commanders/engines/engines-get.command.ts | 3 +-- .../engines/engines-list.command.ts | 9 +++++++- .../commanders/types/engine.interface.ts | 10 +++++++++ .../dtos/engines/engines.dto.ts | 3 +-- .../infrastructure/dtos/models/model.dto.ts | 5 +++-- 6 files changed, 38 insertions(+), 13 deletions(-) diff --git a/cortex-js/src/infrastructure/commanders/engines.command.ts b/cortex-js/src/infrastructure/commanders/engines.command.ts index b5f64c177..1775be7aa 100644 --- a/cortex-js/src/infrastructure/commanders/engines.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines.command.ts @@ -5,6 +5,8 @@ import { EnginesListCommand } from './engines/engines-list.command'; import { EnginesGetCommand } from './engines/engines-get.command'; import { EnginesInitCommand } from './engines/engines-init.command'; import { ModuleRef } from '@nestjs/core'; +import { EngineNamesMap } from './types/engine.interface'; +import _ from 'lodash'; @SubCommand({ name: 'engines', @@ -14,26 +16,33 @@ import { ModuleRef } from '@nestjs/core'; }) @SetCommandContext() export class EnginesCommand extends CommandRunner { + commandMap: { [key: string]: any } = { + list: EnginesListCommand, + get: EnginesGetCommand, + init: EnginesInitCommand, + }; + constructor( readonly contextService: ContextService, private readonly moduleRef: ModuleRef, ) { super(); } - async run(passedParam: string[]): Promise { const [parameter, command] = passedParam; - if (command === 'init' && !parameter) { - console.error('Parameter is required for the init command.'); + if (command !== 'list' && !parameter) { + console.error('Engine name is required.'); return; } // Handle the commands accordingly - if (command === 'init') { - await this.runCommand(EnginesInitCommand, [parameter]); - } else { + const commandClass = this.commandMap[command as string]; + if (!commandClass) { this.command?.help(); + return; } + const engine = _.invert(EngineNamesMap)[parameter] || parameter; + await this.runCommand(commandClass, [engine]); } private async runCommand(commandClass: any, params: string[] = []) { diff --git a/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts b/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts index 8eefc6f44..b085f2e61 100644 --- a/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts @@ -4,9 +4,8 @@ import { ContextService } from '@/infrastructure/services/context/context.servic import { EnginesUsecases } from '@/usecases/engines/engines.usecase'; @SubCommand({ - name: 'get', + name: ' get', description: 'Get an engine', - arguments: '', argsDescription: { name: 'Engine name to get', }, diff --git a/cortex-js/src/infrastructure/commanders/engines/engines-list.command.ts b/cortex-js/src/infrastructure/commanders/engines/engines-list.command.ts index 4e931bfb7..fa49aa302 100644 --- a/cortex-js/src/infrastructure/commanders/engines/engines-list.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines/engines-list.command.ts @@ -2,6 +2,7 @@ import { CommandRunner, SubCommand } from 'nest-commander'; import { SetCommandContext } from '../decorators/CommandContext'; import { ContextService } from '@/infrastructure/services/context/context.service'; import { EnginesUsecases } from '@/usecases/engines/engines.usecase'; +import { EngineNamesMap, Engines } from '../types/engine.interface'; @SubCommand({ name: 'list', @@ -17,6 +18,12 @@ export class EnginesListCommand extends CommandRunner { } async run(): Promise { - return this.enginesUsecases.getEngines().then(console.table); + return this.enginesUsecases.getEngines().then((engines) => { + const enginesTable = engines.map((engine) => ({ + ...engine, + name: EngineNamesMap[engine.name as Engines], + })); + console.table(enginesTable); + }); } } diff --git a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts index 93101ad11..49e970c6a 100644 --- a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts +++ b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts @@ -9,3 +9,13 @@ export enum Engines { openai = 'openai', anthropic = 'anthropic', } + +export const EngineNamesMap = { + [Engines.llamaCPP]: 'llamacpp', + [Engines.onnx]: 'onnx', + [Engines.tensorrtLLM]: 'tensorrtLLM', + [Engines.groq]: 'groq', + [Engines.mistral]: 'mistral', + [Engines.openai]: 'openai', + [Engines.anthropic]: 'anthropic', +}; diff --git a/cortex-js/src/infrastructure/dtos/engines/engines.dto.ts b/cortex-js/src/infrastructure/dtos/engines/engines.dto.ts index a86c2e309..b043b6c98 100644 --- a/cortex-js/src/infrastructure/dtos/engines/engines.dto.ts +++ b/cortex-js/src/infrastructure/dtos/engines/engines.dto.ts @@ -6,8 +6,7 @@ export class EngineDto implements Partial { @ApiProperty({ type: String, example: 'cortex.llamacpp', - description: - 'The name of the engine that you want to retrieve.', + description: 'The name of the engine that you want to retrieve.', }) @IsString() name: string; diff --git a/cortex-js/src/infrastructure/dtos/models/model.dto.ts b/cortex-js/src/infrastructure/dtos/models/model.dto.ts index 163ac8527..4054a8b14 100644 --- a/cortex-js/src/infrastructure/dtos/models/model.dto.ts +++ b/cortex-js/src/infrastructure/dtos/models/model.dto.ts @@ -28,7 +28,7 @@ export class ModelDto implements Partial { @ApiProperty({ type: [String], - example: ["End"], + example: ['End'], description: 'Defines specific tokens or phrases that signal the model to stop producing further output.', }) @@ -116,7 +116,8 @@ export class ModelDto implements Partial { @ApiProperty({ description: 'The prompt to use for internal configuration', - example: "You are an assistant with expert knowledge in {subject}. Please provide a detailed and accurate response to the following query: {query}. Ensure that your response is clear, concise, and informative." + example: + 'You are an assistant with expert knowledge in {subject}. Please provide a detailed and accurate response to the following query: {query}. Ensure that your response is clear, concise, and informative.', }) @IsOptional() @IsString() From 817ce217e0b4ef415b4bcb3283612f6adac3f41e Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 14:53:20 +0700 Subject: [PATCH 4/7] change lodash import --- cortex-js/src/infrastructure/commanders/engines.command.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/cortex-js/src/infrastructure/commanders/engines.command.ts b/cortex-js/src/infrastructure/commanders/engines.command.ts index 1775be7aa..9b0744562 100644 --- a/cortex-js/src/infrastructure/commanders/engines.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines.command.ts @@ -1,3 +1,4 @@ +import { invert } from 'lodash'; import { CommandRunner, SubCommand } from 'nest-commander'; import { SetCommandContext } from './decorators/CommandContext'; import { ContextService } from '@/infrastructure/services/context/context.service'; @@ -6,7 +7,6 @@ import { EnginesGetCommand } from './engines/engines-get.command'; import { EnginesInitCommand } from './engines/engines-init.command'; import { ModuleRef } from '@nestjs/core'; import { EngineNamesMap } from './types/engine.interface'; -import _ from 'lodash'; @SubCommand({ name: 'engines', @@ -41,7 +41,7 @@ export class EnginesCommand extends CommandRunner { this.command?.help(); return; } - const engine = _.invert(EngineNamesMap)[parameter] || parameter; + const engine = invert(EngineNamesMap)[parameter] || parameter; await this.runCommand(commandClass, [engine]); } From 8b5e3d19a04cd37fe25865b3a9516fd6a6a2f07e Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 15:10:59 +0700 Subject: [PATCH 5/7] shorten engine name in get --- .../commanders/engines/engines-get.command.ts | 12 +++++++++++- .../commanders/types/engine.interface.ts | 2 +- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts b/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts index b085f2e61..d72766dbe 100644 --- a/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts +++ b/cortex-js/src/infrastructure/commanders/engines/engines-get.command.ts @@ -2,6 +2,7 @@ import { CommandRunner, SubCommand } from 'nest-commander'; import { SetCommandContext } from '../decorators/CommandContext'; import { ContextService } from '@/infrastructure/services/context/context.service'; import { EnginesUsecases } from '@/usecases/engines/engines.usecase'; +import { EngineNamesMap, Engines } from '../types/engine.interface'; @SubCommand({ name: ' get', @@ -20,6 +21,15 @@ export class EnginesGetCommand extends CommandRunner { } async run(passedParams: string[]): Promise { - return this.engineUsecases.getEngine(passedParams[0]).then(console.table); + return this.engineUsecases.getEngine(passedParams[0]).then((engine) => { + if (!engine) { + console.error('Engine not found.'); + } else { + console.table({ + ...engine, + name: EngineNamesMap[engine.name as Engines], + }); + } + }); } } diff --git a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts index 49e970c6a..1970793da 100644 --- a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts +++ b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts @@ -13,7 +13,7 @@ export enum Engines { export const EngineNamesMap = { [Engines.llamaCPP]: 'llamacpp', [Engines.onnx]: 'onnx', - [Engines.tensorrtLLM]: 'tensorrtLLM', + [Engines.tensorrtLLM]: 'tensorrt-llm', [Engines.groq]: 'groq', [Engines.mistral]: 'mistral', [Engines.openai]: 'openai', From 8cc2e9bddcfe36dd278b1d9e8fe6a8320a37ac91 Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 15:13:14 +0700 Subject: [PATCH 6/7] remove remote engine mapping --- .../src/infrastructure/commanders/types/engine.interface.ts | 4 ---- 1 file changed, 4 deletions(-) diff --git a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts index 1970793da..7cff444f3 100644 --- a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts +++ b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts @@ -14,8 +14,4 @@ export const EngineNamesMap = { [Engines.llamaCPP]: 'llamacpp', [Engines.onnx]: 'onnx', [Engines.tensorrtLLM]: 'tensorrt-llm', - [Engines.groq]: 'groq', - [Engines.mistral]: 'mistral', - [Engines.openai]: 'openai', - [Engines.anthropic]: 'anthropic', }; From f78142f9ea767bd68eea6fdf8970c54963305b7f Mon Sep 17 00:00:00 2001 From: marknguyen1302 Date: Wed, 17 Jul 2024 15:14:46 +0700 Subject: [PATCH 7/7] fix build --- .../src/infrastructure/commanders/types/engine.interface.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts index 7cff444f3..c66753523 100644 --- a/cortex-js/src/infrastructure/commanders/types/engine.interface.ts +++ b/cortex-js/src/infrastructure/commanders/types/engine.interface.ts @@ -10,7 +10,9 @@ export enum Engines { anthropic = 'anthropic', } -export const EngineNamesMap = { +export const EngineNamesMap: { + [key in string]: string; +} = { [Engines.llamaCPP]: 'llamacpp', [Engines.onnx]: 'onnx', [Engines.tensorrtLLM]: 'tensorrt-llm',