From d55bbad2b9f6cf4e19e14df7eab2a0549f4e4443 Mon Sep 17 00:00:00 2001 From: Michael Tsang Date: Fri, 13 Sep 2024 14:49:16 +0100 Subject: [PATCH] use unique temp directory (#99) Co-authored-by: Michael Tsang --- src/cli/Container.ts | 11 +++++++---- src/cli/ImportFeedCommand.ts | 2 +- src/cli/OutputGTFSCommand.ts | 10 +++++----- src/cli/OutputGTFSZipCommand.ts | 10 ++++------ 4 files changed, 17 insertions(+), 16 deletions(-) diff --git a/src/cli/Container.ts b/src/cli/Container.ts index 13c5f050..ab4d97a0 100644 --- a/src/cli/Container.ts +++ b/src/cli/Container.ts @@ -1,4 +1,7 @@ import * as memoize from "memoized-class-decorator"; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import * as path from 'node:path'; import {CLICommand} from "./CLICommand"; import {ImportFeedCommand} from "./ImportFeedCommand"; import {DatabaseConfiguration, DatabaseConnection} from "../database/DatabaseConnection"; @@ -45,22 +48,22 @@ export class Container { @memoize public async getFaresImportCommand(): Promise { - return new ImportFeedCommand(await this.getDatabaseConnection(), config.fares, "/tmp/dtd/fares/"); + return new ImportFeedCommand(await this.getDatabaseConnection(), config.fares, fs.mkdtempSync(path.join(os.tmpdir(), "dtd"))); } @memoize public async getRouteingImportCommand(): Promise { - return new ImportFeedCommand(await this.getDatabaseConnection(), config.routeing, "/tmp/dtd/routeing/"); + return new ImportFeedCommand(await this.getDatabaseConnection(), config.routeing, fs.mkdtempSync(path.join(os.tmpdir(), "dtd"))); } @memoize public async getTimetableImportCommand(): Promise { - return new ImportFeedCommand(await this.getDatabaseConnection(), config.timetable, "/tmp/dtd/timetable/"); + return new ImportFeedCommand(await this.getDatabaseConnection(), config.timetable, fs.mkdtempSync(path.join(os.tmpdir(), "dtd"))); } @memoize public async getNFM64ImportCommand(): Promise { - return new ImportFeedCommand(await this.getDatabaseConnection(), config.nfm64, "/tmp/dtd/nfm64/"); + return new ImportFeedCommand(await this.getDatabaseConnection(), config.nfm64, fs.mkdtempSync(path.join(os.tmpdir(), "dtd"))); } diff --git a/src/cli/ImportFeedCommand.ts b/src/cli/ImportFeedCommand.ts index 015e0e7d..7acffbc3 100644 --- a/src/cli/ImportFeedCommand.ts +++ b/src/cli/ImportFeedCommand.ts @@ -127,7 +127,7 @@ export class ImportFeedCommand implements CLICommand { const file = this.getFeedFile(filename); const tables = await this.tables(file); const tableStream = new MySQLStream(filename, file, tables); - const stream = readFile(this.tmpFolder + filename).pipe(tableStream); + const stream = readFile(`${this.tmpFolder}/${filename}`).pipe(tableStream); try { await streamToPromise(stream); diff --git a/src/cli/OutputGTFSCommand.ts b/src/cli/OutputGTFSCommand.ts index 3df1c978..140f036b 100644 --- a/src/cli/OutputGTFSCommand.ts +++ b/src/cli/OutputGTFSCommand.ts @@ -25,7 +25,7 @@ export class OutputGTFSCommand implements CLICommand { * Turn the timetable feed into GTFS files */ public async run(argv: string[]): Promise { - this.baseDir = argv[3] || "./"; + this.baseDir = argv[3] || "."; if (!fs.existsSync(this.baseDir)) { throw new Error(`Output path ${this.baseDir} does not exist.`); @@ -68,7 +68,7 @@ export class OutputGTFSCommand implements CLICommand { */ private async copy(results: object[] | Promise, filename: string): Promise { const rows = await results; - const output = this.output.open(this.baseDir + filename); + const output = this.output.open(`${this.baseDir}/filename`); console.log("Writing " + filename); rows.forEach(row => output.write(row)); @@ -82,9 +82,9 @@ export class OutputGTFSCommand implements CLICommand { */ private copyTrips(schedules: Schedule[], serviceIds: ServiceIdIndex): Promise { console.log("Writing trips.txt, stop_times.txt and routes.txt"); - const trips = this.output.open(this.baseDir + "trips.txt"); - const stopTimes = this.output.open(this.baseDir + "stop_times.txt"); - const routeFile = this.output.open(this.baseDir + "routes.txt"); + const trips = this.output.open(`${this.baseDir}/trips.txt`); + const stopTimes = this.output.open(`${this.baseDir}/stop_times.txt`); + const routeFile = this.output.open(`${this.baseDir}/routes.txt`); const routes = {}; for (const schedule of schedules) { diff --git a/src/cli/OutputGTFSZipCommand.ts b/src/cli/OutputGTFSZipCommand.ts index c604ba63..b1acd20a 100644 --- a/src/cli/OutputGTFSZipCommand.ts +++ b/src/cli/OutputGTFSZipCommand.ts @@ -1,4 +1,6 @@ +import * as os from 'node:os'; +import * as path from 'node:path'; import {CLICommand} from "./CLICommand"; import {OutputGTFSCommand} from "./OutputGTFSCommand"; import * as fs from "fs"; @@ -19,12 +21,8 @@ export class OutputGTFSZipCommand implements CLICommand { if (fs.existsSync(filename)) { fs.unlinkSync(filename); } - - argv[3] = "/tmp/gtfs/"; - - if (!fs.existsSync(argv[3])) { - fs.mkdirSync(argv[3]); - } + + argv[3] = fs.mkdtempSync(path.join(os.tmpdir(), "gtfs")); await this.command.run(argv);