143 lines
3.6 KiB
JavaScript
Raw Normal View History

2016-04-21 14:59:00 +02:00
'use strict';
/**
* Module dependencies
*/
// Node.js core.
const fs = require('fs');
const path = require('path');
// Public node modules.
const _ = require('lodash');
const pluralize = require('pluralize');
const { nameToSlug } = require('strapi-utils');
// Fetch stub attribute template on initial load.
const attributeTemplate = fs.readFileSync(
path.resolve(__dirname, '..', 'templates', 'attribute.template'),
'utf8'
);
2018-05-04 17:44:42 +02:00
/* eslint-disable prefer-template */
2016-04-21 14:59: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) {
return cb.invalid(
'Usage: `$ strapi generate:model modelName --api apiName --plugin pluginName`'
);
2016-04-21 14:59:00 +02:00
}
// Format `id`.
const name = scope.name || nameToSlug(scope.id);
2016-04-21 14:59:00 +02:00
// `scope.args` are the raw command line arguments.
_.defaults(scope, {
name,
idPluralized: pluralize.plural(_.trim(_.deburr(scope.id))),
environment: process.env.NODE_ENV || 'development',
2016-04-21 14:59:00 +02:00
});
// Determine the destination path.
let filePath;
if (scope.args.api) {
filePath = `./api/${scope.args.api}/models`;
} else if (scope.args.plugin) {
filePath = `./plugins/${scope.args.plugin}/models`;
} else {
filePath = `./api/${name}/models`;
}
2016-04-21 14:59: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`,
filenameSettings: `${name}.settings.json`,
2016-04-21 14:59:00 +02:00
});
// Validate optional attribute arguments.
const invalidAttributes = [];
2016-08-10 11:00:56 +02:00
// Map attributes and split them.
scope.attributes = scope.args.attributes.map(attribute => {
const parts = attribute.split(':');
parts[1] = parts[1] ? parts[1] : 'string';
// Handle invalid attributes.
if (!parts[1] || !parts[0]) {
invalidAttributes.push('Error: Invalid attribute notation `' + attribute + '`.');
return;
2016-08-10 11:00:56 +02:00
}
return {
name: _.trim(_.deburr(_.camelCase(parts[0]).toLowerCase())),
type: _.trim(_.deburr(_.camelCase(parts[1]).toLowerCase())),
};
2016-04-21 14:59:00 +02:00
});
2018-05-14 12:05:09 +02:00
// Set collectionName
scope.collectionName = _.has(scope.args, 'collectionName')
? scope.args.collectionName
: undefined;
2018-05-14 12:05:09 +02:00
// Set description
scope.description = _.has(scope.args, 'description') ? scope.args.description : undefined;
2018-05-14 12:05:09 +02:00
// Handle invalid action arguments.
// Send back invalidActions.
if (invalidAttributes.length) {
return cb.invalid(invalidAttributes);
}
// Make sure there aren't duplicates.
if (
_(scope.attributes.map(attribute => attribute.name))
.uniq()
.valueOf().length !== scope.attributes.length
) {
return cb.invalid('Duplicate attributes not allowed!');
}
// Render some stringified code from the action template
// and make it available in our scope for use later on.
scope.attributes = scope.attributes
.map(attribute => {
const compiled = _.template(attributeTemplate);
return _.trimEnd(
_.unescape(
compiled({
name: attribute.name,
type: attribute.type,
})
)
);
})
.join(',\n');
2016-04-21 14:59:00 +02:00
// Get default connection
try {
scope.connection =
2019-12-03 09:50:43 +01:00
scope.args.connection ||
JSON.parse(
fs.readFileSync(
path.resolve(scope.rootPath, 'config', 'environments', scope.environment, 'database.json')
)
2019-12-03 09:50:43 +01:00
).defaultConnection ||
'';
2016-04-21 14:59:00 +02:00
} catch (err) {
return cb.invalid(err);
}
// Trigger callback with no error to proceed.
return cb();
};