From 4adb9274637fd1a8b17812c156d5e0e45d0e9ea7 Mon Sep 17 00:00:00 2001 From: Sergey Dubovyk Date: Sat, 12 Oct 2019 12:30:41 +0300 Subject: [PATCH] feat: added support for file paths as --options cli argument (#1049) --- cli/index.ts | 34 ++++++++++++++++++++++------------ 1 file changed, 22 insertions(+), 12 deletions(-) diff --git a/cli/index.ts b/cli/index.ts index 7bb27bb2a1..e5f90733ac 100644 --- a/cli/index.ts +++ b/cli/index.ts @@ -14,7 +14,7 @@ import * as zlib from 'zlib'; import { createStore, loadAndBundleSpec, Redoc } from 'redoc'; import { watch } from 'chokidar'; -import { createReadStream, existsSync, readFileSync, ReadStream, writeFileSync } from 'fs'; +import { createReadStream, existsSync, readFileSync, ReadStream, writeFileSync, lstatSync } from 'fs'; import * as mkdirp from 'mkdirp'; import * as YargsParser from 'yargs'; @@ -283,13 +283,13 @@ async function getPageHTML( ssr ? 'hydrate(__redoc_state, container);' : `init("spec.json", ${JSON.stringify(redocOptions)}, container)` - }; + }; `, redocHead: ssr ? (cdn - ? '' - : ``) + css + ? '' + : ``) + css : '', title, disableGoogleFont, @@ -357,13 +357,23 @@ function handleError(error: Error) { } function getObjectOrJSON(options) { - try { - return options && typeof options === 'string' - ? JSON.parse(options) : options - ? options - : {}; - } catch (e) { - console.log(`Encountered error:\n${options}\nis not a valid JSON.`); - handleError(e); + switch (typeof options) { + case 'object': + return options; + case 'string': + try { + if (existsSync(options) && lstatSync(options).isFile()) { + return JSON.parse(readFileSync(options, 'utf-8')); + } else { + return JSON.parse(options); + } + } catch (e) { + console.log( + `Encountered error:\n\n${options}\n\nis neither a file with a valid JSON object neither a stringified JSON object.` + ); + handleError(e); + } + default: + return {}; } }