Update utils.js
This commit is contained in:
parent
274d80e0f3
commit
91f9df3afb
18
src/utils.js
18
src/utils.js
|
@ -14,15 +14,19 @@ const utils = {}
|
||||||
const defaultUserAgent =
|
const defaultUserAgent =
|
||||||
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.130 Safari/537.36 Edg/79.0.309.71'
|
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.130 Safari/537.36 Edg/79.0.309.71'
|
||||||
|
|
||||||
utils.loadConfig = function (file) {
|
utils.loadConfig = function (options) {
|
||||||
|
const file = options.config
|
||||||
if (!file) throw new Error('Path to [site].config.js is missing')
|
if (!file) throw new Error('Path to [site].config.js is missing')
|
||||||
console.log(`Loading '${file}'...`)
|
console.log(`Loading '${file}'...`)
|
||||||
|
|
||||||
const configPath = path.resolve(file)
|
const configPath = path.resolve(file)
|
||||||
const config = require(configPath)
|
const config = require(configPath)
|
||||||
|
|
||||||
|
if (options.channels) config.channels = options.channels
|
||||||
|
else if (config.channels) config.channels = path.join(path.dirname(file), config.channels)
|
||||||
|
else throw new Error("The required 'channels' property is missing")
|
||||||
|
|
||||||
if (!config.site) throw new Error("The required 'site' property is missing")
|
if (!config.site) throw new Error("The required 'site' property is missing")
|
||||||
if (!config.channels) throw new Error("The required 'channels' property is missing")
|
|
||||||
if (!config.url) throw new Error("The required 'url' property is missing")
|
if (!config.url) throw new Error("The required 'url' property is missing")
|
||||||
if (typeof config.url !== 'function' && typeof config.url !== 'string')
|
if (typeof config.url !== 'function' && typeof config.url !== 'string')
|
||||||
throw new Error("The 'url' property should return the function or string")
|
throw new Error("The 'url' property should return the function or string")
|
||||||
|
@ -32,13 +36,11 @@ utils.loadConfig = function (file) {
|
||||||
if (config.logo && typeof config.logo !== 'function')
|
if (config.logo && typeof config.logo !== 'function')
|
||||||
throw new Error("The 'logo' property should return the function")
|
throw new Error("The 'logo' property should return the function")
|
||||||
|
|
||||||
config.channels = path.join(path.dirname(file), config.channels)
|
|
||||||
|
|
||||||
const defaultConfig = {
|
const defaultConfig = {
|
||||||
days: 1,
|
days: options.days ? parseInt(options.days) : 1,
|
||||||
lang: 'en',
|
lang: options.lang || 'en',
|
||||||
delay: 3000,
|
delay: options.delay ? parseInt(options.delay) : 3000,
|
||||||
output: 'guide.xml',
|
output: options.output || 'guide.xml',
|
||||||
request: {
|
request: {
|
||||||
method: 'GET',
|
method: 'GET',
|
||||||
maxContentLength: 5 * 1024 * 1024,
|
maxContentLength: 5 * 1024 * 1024,
|
||||||
|
|
Loading…
Reference in New Issue