From 3d0a9b477bd6576e431491f04d2c75309ba807f2 Mon Sep 17 00:00:00 2001 From: Jeffrey Morgan Date: Tue, 11 Jul 2023 15:51:59 -0700 Subject: [PATCH] log to console as well as file --- app/src/index.ts | 39 ++++++++++++++++++--------------------- 1 file changed, 18 insertions(+), 21 deletions(-) diff --git a/app/src/index.ts b/app/src/index.ts index 79996c72..eec01a65 100644 --- a/app/src/index.ts +++ b/app/src/index.ts @@ -13,18 +13,16 @@ require('@electron/remote/main').initialize() const store = new Store() let tray: Tray | null = null -const logFile = new winston.transports.File({ - filename: path.join(app.getPath('home'), '.ollama', 'logs', 'server.log'), - maxsize: 1024 * 1024 * 20, - maxFiles: 5, -}); - -const logger = winston.createLogger({ - transports: [logFile], - format: winston.format.combine( - winston.format.timestamp(), - winston.format.printf(info => `${info.timestamp} ${info.level}: ${info.message}`) - ) +const logger = winston.createLogger({ + transports: [ + new winston.transports.Console(), + new winston.transports.File({ + filename: path.join(app.getPath('home'), '.ollama', 'logs', 'server.log'), + maxsize: 1024 * 1024 * 20, + maxFiles: 5, + }), + ], + format: winston.format.printf(info => `${info.message}`), }) const SingleInstanceLock = app.requestSingleInstanceLock() @@ -56,25 +54,25 @@ const ollama = path.join(process.resourcesPath, 'ollama') function server() { const binary = app.isPackaged - ? path.join(process.resourcesPath, 'ollama') - : path.resolve(process.cwd(), '..', 'ollama') + ? path.join(process.resourcesPath, 'ollama') + : path.resolve(process.cwd(), '..', 'ollama') - const proc = spawn(binary, ['serve']) + const proc = spawn(binary, ['serve'], { cwd: path.dirname(binary) }) proc.stdout.on('data', data => { logger.info(`server: ${data.toString()}`) }) proc.stderr.on('data', data => { - logger.error(`server: ${data.toString()}`) + logger.info(`server: ${data.toString()}`) }) proc.on('exit', () => { - logger.info('Restarting the server...'); - server(); + logger.info('Restarting the server...') + server() }) proc.on('disconnect', () => { - logger.info('Server disconnected. Reconnecting...'); - server(); + logger.info('Server disconnected. Reconnecting...') + server() }) process.on('exit', () => { @@ -82,7 +80,6 @@ function server() { }) } - function installCLI() { const symlinkPath = '/usr/local/bin/ollama'