58 lines
1.3 KiB
JavaScript
Raw Normal View History

2017-02-14 01:18:07 +01:00
'use strict';
/**
* Module dependencies
*/
// Public node modules.
2017-06-08 17:16:20 +01:00
const path = require('path');
2018-05-04 17:52:04 +02:00
const fs = require('fs-extra');
const _ = require('lodash');
2017-02-14 01:18:07 +01: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) {
return cb.invalid('Usage: `$ strapi generate:plugin pluginName`');
}
// Format `id`.
const name = scope.name || _.trim(_.camelCase(scope.id));
2017-02-14 01:18:07 +01:00
// Determine default values based on the available scope.
_.defaults(scope, {
globalID: _.upperFirst(name),
ext: '.js',
2017-02-14 01:18:07 +01:00
});
2017-06-08 17:16:20 +01:00
// Plugin info.
_.defaults(scope, {
name,
2017-06-08 17:16:20 +01:00
author: scope.author || 'A Strapi developer',
email: scope.email || '',
year: new Date().getFullYear(),
license: 'MIT',
2017-06-08 17:16:20 +01:00
});
2017-02-14 01:18:07 +01:00
// Take another pass to take advantage of the defaults absorbed in previous passes.
_.defaults(scope, {
filename: `${scope.globalID}${scope.ext}`,
filePath: './plugins',
2017-02-14 01:18:07 +01:00
});
const pluginDir = path.resolve(scope.rootPath, 'plugins');
fs.ensureDirSync(pluginDir);
// Copy the admin files.
fs.copySync(path.resolve(__dirname, '..', 'files'), path.resolve(pluginDir, name));
2017-02-14 01:18:07 +01:00
// Trigger callback with no error to proceed.
return cb.success();
};