50 lines
1.1 KiB
JavaScript
Raw Normal View History

2016-04-21 14:52:00 +02:00
'use strict';
/**
* Module dependencies
*/
// Public node modules.
const _ = require('lodash');
/**
* This `before` function is run before generating targets.
* Validate, configure defaults, get extra dependencies, etc.
*
* @param {Object} scope
* @param {Function} cb
*/
module.exports = (scope, cb) => {
2016-04-21 14:52:00 +02:00
if (!scope.rootPath || !scope.args[0]) {
return cb.invalid('Usage: `$ strapi generate:controller controllerName apiName`');
}
// `scope.args` are the raw command line arguments.
_.defaults(scope, {
id: _.trim(_.deburr(scope.args[0])),
2016-04-21 14:52:00 +02:00
api: scope.args[1]
});
// Determine default values based on the available scope.
_.defaults(scope, {
globalID: _.upperFirst(_.camelCase(scope.id)),
2016-04-21 14:52:00 +02:00
ext: '.js'
});
// Take another pass to take advantage of the defaults absorbed in previous passes.
_.defaults(scope, {
rootPath: scope.rootPath,
filename: scope.globalID + scope.ext
2016-04-21 14:52:00 +02:00
});
// Humanize output.
_.defaults(scope, {
humanizeId: _.camelCase(scope.id).toLowerCase(),
2016-04-21 14:52:00 +02:00
humanizedPath: '`./api/' + scope.api + '/controllers`'
});
// Trigger callback with no error to proceed.
return cb();
};