serverless/lib/utils/getServerlessConfigFile.js
Daniel Schep dd4a49d7f5
Merge pull request #4827 from simonbuchan/config-promises
Support returning promises from serverless.js
2018-11-27 11:45:07 -05:00

47 lines
1.4 KiB
JavaScript

'use strict';
const _ = require('lodash');
const BbPromise = require('bluebird');
const path = require('path');
const fileExists = require('./fs/fileExists');
const readFile = require('./fs/readFile');
const getServerlessConfigFile = _.memoize((srvcPath) => {
const servicePath = srvcPath || process.cwd();
const jsonPath = path.join(servicePath, 'serverless.json');
const ymlPath = path.join(servicePath, 'serverless.yml');
const yamlPath = path.join(servicePath, 'serverless.yaml');
const jsPath = path.join(servicePath, 'serverless.js');
return BbPromise.props({
json: fileExists(jsonPath),
yml: fileExists(ymlPath),
yaml: fileExists(yamlPath),
js: fileExists(jsPath),
}).then((exists) => {
if (exists.json) {
return readFile(jsonPath);
} else if (exists.yml) {
return readFile(ymlPath);
} else if (exists.yaml) {
return readFile(yamlPath);
} else if (exists.js) {
return BbPromise.try(() => {
// use require to load serverless.js
// eslint-disable-next-line global-require
const configExport = require(jsPath);
// In case of a promise result, first resolve it.
return configExport;
}).then(config => {
if (_.isPlainObject(config)) {
return config;
}
throw new Error('serverless.js must export plain object');
});
}
return '';
});
});
module.exports = getServerlessConfigFile;