mirror of
https://github.com/zebrajr/express.git
synced 2025-12-06 00:19:48 +01:00
Since v5 relies on node >= 18, this is now possible (since v16, v14.18.0 [^1][^2]). It's functionally irrelevant: 1. It's not required for CJS nor ESM (with a few exceptions [^3]) 2. It has no performance promises However, there are upsides to this approach: 1. It brings clear boundaries to what's a built-in and what's an external dependency 2. It reduces the risk of importing unwanted deps where a built-in is expected 3. It's slightly more interoperable with other JS runtimes that provide node compatibility[^4], albeit only during development. Once imported from npm, built-ins are assumed. [^1]:https://nodejs.org/docs/latest-v22.x/api/modules.html#built-in-modules [^2]:https://github.com/nodejs/node/pull/37246 [^3]:https://nodejs.org/api/modules.html#built-in-modules-with-mandatory-node-prefix [^4]:https://docs.deno.com/runtime/fundamentals/node/#using-node's-built-in-modules
84 lines
2.2 KiB
JavaScript
84 lines
2.2 KiB
JavaScript
'use strict'
|
|
|
|
/**
|
|
* Module dependencies.
|
|
*/
|
|
|
|
var express = require('../../..');
|
|
var fs = require('node:fs');
|
|
var path = require('node:path');
|
|
|
|
module.exports = function(parent, options){
|
|
var dir = path.join(__dirname, '..', 'controllers');
|
|
var verbose = options.verbose;
|
|
fs.readdirSync(dir).forEach(function(name){
|
|
var file = path.join(dir, name)
|
|
if (!fs.statSync(file).isDirectory()) return;
|
|
verbose && console.log('\n %s:', name);
|
|
var obj = require(file);
|
|
var name = obj.name || name;
|
|
var prefix = obj.prefix || '';
|
|
var app = express();
|
|
var handler;
|
|
var method;
|
|
var url;
|
|
|
|
// allow specifying the view engine
|
|
if (obj.engine) app.set('view engine', obj.engine);
|
|
app.set('views', path.join(__dirname, '..', 'controllers', name, 'views'));
|
|
|
|
// generate routes based
|
|
// on the exported methods
|
|
for (var key in obj) {
|
|
// "reserved" exports
|
|
if (~['name', 'prefix', 'engine', 'before'].indexOf(key)) continue;
|
|
// route exports
|
|
switch (key) {
|
|
case 'show':
|
|
method = 'get';
|
|
url = '/' + name + '/:' + name + '_id';
|
|
break;
|
|
case 'list':
|
|
method = 'get';
|
|
url = '/' + name + 's';
|
|
break;
|
|
case 'edit':
|
|
method = 'get';
|
|
url = '/' + name + '/:' + name + '_id/edit';
|
|
break;
|
|
case 'update':
|
|
method = 'put';
|
|
url = '/' + name + '/:' + name + '_id';
|
|
break;
|
|
case 'create':
|
|
method = 'post';
|
|
url = '/' + name;
|
|
break;
|
|
case 'index':
|
|
method = 'get';
|
|
url = '/';
|
|
break;
|
|
default:
|
|
/* istanbul ignore next */
|
|
throw new Error('unrecognized route: ' + name + '.' + key);
|
|
}
|
|
|
|
// setup
|
|
handler = obj[key];
|
|
url = prefix + url;
|
|
|
|
// before middleware support
|
|
if (obj.before) {
|
|
app[method](url, obj.before, handler);
|
|
verbose && console.log(' %s %s -> before -> %s', method.toUpperCase(), url, key);
|
|
} else {
|
|
app[method](url, handler);
|
|
verbose && console.log(' %s %s -> %s', method.toUpperCase(), url, key);
|
|
}
|
|
}
|
|
|
|
// mount the app
|
|
parent.use(app);
|
|
});
|
|
};
|