UNPKG

dtamind-components

Version:

DTAmindai Components

90 lines (79 loc) 3.23 kB
import path from 'path' import { getBaseClasses, getUserHome } from '../../../../src/utils' import { SaverOptions } from '../interface' import { ICommonObject, IDatabaseEntity, INode, INodeData, INodeParams } from '../../../../src/Interface' import { SqliteSaver } from './sqliteSaver' import { DataSource } from 'typeorm' class SQLiteAgentMemory_Memory implements INode { label: string name: string version: number description: string type: string icon: string category: string badge: string baseClasses: string[] inputs: INodeParams[] credential: INodeParams constructor() { this.label = 'SQLite Agent Memory' this.name = 'sqliteAgentMemory' this.version = 1.0 this.type = 'SQLiteAgentMemory' this.icon = 'sqlite.png' this.category = 'Memory' this.description = 'Memory for agentflow to remember the state of the conversation using SQLite database' this.baseClasses = [this.type, ...getBaseClasses(SqliteSaver)] this.inputs = [ /*{ label: 'Database File Path', name: 'databaseFilePath', type: 'string', placeholder: 'C:\\Users\\User\\.flowise\\database.sqlite', description: 'Path to the SQLite database file. Leave empty to use default application database', optional: true },*/ { label: 'Additional Connection Configuration', name: 'additionalConfig', type: 'json', additionalParams: true, optional: true } ] } async init(nodeData: INodeData, _: string, options: ICommonObject): Promise<any> { const additionalConfig = nodeData.inputs?.additionalConfig as string const databaseEntities = options.databaseEntities as IDatabaseEntity const chatflowid = options.chatflowid as string const appDataSource = options.appDataSource as DataSource const orgId = options.orgId as string let additionalConfiguration = {} if (additionalConfig) { try { additionalConfiguration = typeof additionalConfig === 'object' ? additionalConfig : JSON.parse(additionalConfig) } catch (exception) { throw new Error('Invalid JSON in the Additional Configuration: ' + exception) } } const threadId = options.sessionId || options.chatId const database = path.join(process.env.DATABASE_PATH ?? path.join(getUserHome(), '.flowise'), 'database.sqlite') let datasourceOptions: ICommonObject = { database, ...additionalConfiguration, type: 'sqlite' } const args: SaverOptions = { datasourceOptions, threadId, appDataSource, databaseEntities, chatflowid, orgId } const recordManager = new SqliteSaver(args) return recordManager } } module.exports = { nodeClass: SQLiteAgentMemory_Memory }