57 lines
1.4 KiB
JavaScript
Raw Normal View History

2016-04-21 14:52:00 +02:00
'use strict';
/**
* Module dependencies
*/
// Public node modules.
const _ = require('lodash');
2021-04-29 13:51:12 +02:00
const { nameToSlug } = require('@strapi/utils');
2018-05-04 17:43:38 +02:00
/* eslint-disable prefer-template */
2016-04-21 14:52:00 +02:00
/**
* 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) => {
if (!scope.rootPath || !scope.id) {
2019-10-31 14:34:30 +01:00
return cb.invalid(
'Usage: `$ strapi generate:controller controllerName --api apiName --plugin pluginName`'
);
2016-04-21 14:52:00 +02:00
}
// Format `id`.
const name = scope.name || nameToSlug(scope.id);
2016-04-21 14:52:00 +02:00
// `scope.args` are the raw command line arguments.
_.defaults(scope, {
name,
2019-10-31 14:34:30 +01:00
api: scope.id,
2016-04-21 14:52:00 +02:00
});
// Determine the destination path.
let filePath;
if (scope.args.api) {
filePath = `./api/${scope.args.api}/controllers`;
} else if (scope.args.plugin) {
filePath = `./plugins/${scope.args.plugin}/controllers`;
2019-10-31 14:34:30 +01:00
} else if (scope.args.extend) {
filePath = `./extensions/${scope.args.extend}/controllers`;
} else {
filePath = `./api/${name}/controllers`;
}
2016-04-21 14:52:00 +02:00
// Take another pass to take advantage of the defaults absorbed in previous passes.
_.defaults(scope, {
rootPath: scope.rootPath,
filePath,
filename: `${name}.js`,
2016-04-21 14:52:00 +02:00
});
// Trigger callback with no error to proceed.
return cb();
};