145 lines
3.8 KiB
JavaScript
Raw Normal View History

2016-03-18 11:12:50 +01:00
'use strict';
/**
* Module dependencies
*/
// Public node modules.
const _ = require('lodash');
const pluralize = require('pluralize');
const { nameToSlug } = require('strapi-utils');
2016-03-18 11:12:50 +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) {
2016-03-25 22:22:34 +01:00
return cb.invalid('Usage: `$ strapi generate:api apiName`');
2016-03-18 11:12:50 +01:00
}
2017-03-09 14:26:47 +01:00
// Format `id`.
const name = scope.name || nameToSlug(scope.id);
2017-03-09 14:26:47 +01:00
scope.contentTypeKind = scope.args.kind || 'collectionType';
2016-03-18 11:12:50 +01:00
// `scope.args` are the raw command line arguments.
_.defaults(scope, {
2019-10-31 14:34:30 +01:00
name,
route:
scope.contentTypeKind === 'singleType'
? _.kebabCase(scope.id)
: _.kebabCase(pluralize(scope.id)),
2016-03-18 11:12:50 +01:00
});
2019-10-31 14:34:30 +01:00
let filePath;
if (scope.args.api) {
filePath = `./api/${scope.args.api}`;
} else if (scope.args.plugin) {
filePath = `./plugins/${scope.args.plugin}`;
} else if (scope.args.extend) {
filePath = `./extensions/${scope.args.extend}`;
} else {
filePath = `./api/${name}`;
}
2016-03-18 11:12:50 +01:00
// Take another pass to take advantage of the defaults absorbed in previous passes.
_.defaults(scope, {
filename: `${name}.js`,
filenameSettings: `${name}.settings.json`,
2019-10-31 14:34:30 +01:00
filePath,
2016-03-18 11:12:50 +01:00
});
// Validate optional attribute arguments.
const invalidAttributes = [];
if (_.isPlainObject(scope.args.attributes)) {
scope.attributes = scope.args.attributes;
} else {
// Map attributes and split them for CLI.
scope.attributes = scope.args.attributes.map(attribute => {
if (_.isString(attribute)) {
const parts = attribute.split(':');
parts[1] = parts[1] || 'string';
// Handle invalid attributes.
if (!parts[1] || !parts[0]) {
invalidAttributes.push('Error: Invalid attribute notation `' + attribute + '`.');
return;
}
return {
name: _.trim(_.deburr(parts[0].toLowerCase())),
params: {
type: _.trim(_.deburr(parts[1].toLowerCase())),
},
};
} else {
return _.has(attribute, 'params.type') ? attribute : undefined;
2017-08-04 18:22:18 +02:00
}
});
2017-08-04 18:22:18 +02:00
scope.attributes = _.compact(scope.attributes);
2018-05-04 17:39:37 +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.reduce((acc, attribute) => {
acc[attribute.name] = attribute.params;
return acc;
}, {});
}
2017-08-11 18:23:19 +02:00
// Set collectionName
2019-07-09 23:51:21 +02:00
scope.collectionName = _.has(scope.args, 'collectionName')
? scope.args.collectionName
2019-10-31 14:34:30 +01:00
: _.snakeCase(pluralize(name));
2017-08-11 18:23:19 +02:00
// Set description
scope.description = _.has(scope.args, 'description') ? scope.args.description : '';
Fix/#3184/fix server crashs on database change (#5703) * Don't set connection field on create/edit operation on content-types & components Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Make sure that every component has a valid connection attribute Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove connection check on components load Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove default connections from core & webhook stores but make sure it's defined in the application lifecycle Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Fix component's associations that can be undefined instead of empty in populateBareAssociations Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove "default" connection from plugins' models Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove connection attribute from generated models (cli) Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Mutate each component instead of reassign Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Build core_store and webhook model based on the current config Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Add connection to templates conditionally (based on args) Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Set default value for description to undefined instead of empty string Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove unnecessary complexity Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Update getStarted models Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Fix attributes parsing for generate:model Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Removed tpl option from generate:model/api Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu> * Remove tpl option from cli Signed-off-by: Convly <jean-sebastien.herbaux@epitech.eu>
2020-04-07 16:31:44 +02:00
// Set connection
scope.connection = _.get(scope.args, 'connection', undefined);
2016-03-18 11:12:50 +01:00
scope.schema = JSON.stringify(
{
connection: scope.connection,
collectionName: scope.collectionName,
info: {
2019-10-31 14:34:30 +01:00
name: scope.args.displayName || scope.id,
description: scope.description,
},
options: {
draftAndPublish: scope.args.draftAndPublish === 'true',
increments: true,
timestamps: true,
comment: '',
},
attributes: scope.attributes,
},
null,
2
);
2016-03-18 11:12:50 +01:00
// Trigger callback with no error to proceed.
return cb.success();
};