'use strict'; /** * Module dependencies */ // Node.js core. const fs = require('fs'); const path = require('path'); // 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) => { if (!scope.rootPath || !scope.args[0]) { return cb.invalid('Usage: `$ strapi generate:model modelName apiName`'); } // `scope.args` are the raw command line arguments. _.defaults(scope, { id: _.trim(_.deburr(scope.args[0])), attributes: _.takeRight(scope.args, _.size(scope.args) - 1), api: {}, environment: process.NODE_ENV || 'development' }); // Determine default values based on the available scope. _.defaults(scope, { globalID: _.upperFirst(_.camelCase(scope.id)), 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, filenameSettings: scope.globalID + '.settings.json' }); // Humanize output. _.defaults(scope, { humanizeId: _.camelCase(scope.id).toLowerCase(), humanizedPath: '`./api/' + scope.id + '/models`' }); _.forEach(scope.attributes, attribute => { const object = attribute.split(':'); if (_.size(object) === 2) { scope.api[_.trim(_.deburr(_.camelCase(_.first(object)).toLowerCase()))] = { type: _.trim(_.deburr(_.camelCase(_.last(object).toLowerCase()))) }; } }); // Get default connection try { scope.connection = JSON.parse(fs.readFileSync(path.resolve(scope.rootPath, 'config', 'environments', scope.environment, 'databases.json'))).defaultConnection || ''; } catch (err) { return cb.invalid(err); } // Trigger callback with no error to proceed. return cb(); };