Pierre Noël d64af252bf fix generate:model --plugin path + little refacto of code
Signed-off-by: Pierre Noël <pierre.noel@strapi.io>
2020-03-19 18:29:30 +01:00

53 lines
1.2 KiB
JavaScript

'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
*/
/* eslint-disable prefer-template */
module.exports = (scope, cb) => {
if (!scope.rootPath || !scope.id) {
return cb.invalid(
'Usage: `$ strapi generate:policy policyName --api apiName --plugin pluginName`'
);
}
// Format `id`.
const name = scope.name || _.trim(_.camelCase(scope.id));
let filePath;
if (scope.args.api) {
filePath = `./api/${scope.args.api}/config/policies`;
} else if (scope.args.plugin) {
filePath = `./plugins/${scope.args.plugin}/config/policies`;
} else {
filePath = './config/policies';
}
// Determine default values based on the available scope.
_.defaults(scope, {
ext: '.js',
});
// Take another pass to take advantage of the defaults absorbed in previous passes.
_.defaults(scope, {
name,
filePath,
filename: name + scope.ext,
});
// Trigger callback with no error to proceed.
return cb();
};