2019-09-07 17:46:50 -05:00
|
|
|
import _ from 'lodash';
|
2020-08-13 16:27:00 -05:00
|
|
|
import express, { Express } from 'express';
|
2020-03-03 17:59:19 -05:00
|
|
|
|
2020-09-16 23:48:16 -05:00
|
|
|
import {
|
|
|
|
match,
|
|
|
|
validateName,
|
|
|
|
validatePackage,
|
|
|
|
encodeScopePackage,
|
|
|
|
antiLoop,
|
|
|
|
} from '@verdaccio/middleware';
|
|
|
|
import { IAuth } from '@verdaccio/auth';
|
|
|
|
import { IStorageHandler } from '@verdaccio/store';
|
2020-03-03 17:59:19 -05:00
|
|
|
import { Config } from '@verdaccio/types';
|
2020-07-16 14:59:21 -05:00
|
|
|
import bodyParser from 'body-parser';
|
2018-03-10 15:09:04 -05:00
|
|
|
|
2020-03-03 17:59:19 -05:00
|
|
|
import whoami from './whoami';
|
|
|
|
import ping from './ping';
|
|
|
|
import user from './user';
|
|
|
|
import distTags from './dist-tags';
|
|
|
|
import publish from './publish';
|
|
|
|
import search from './search';
|
|
|
|
import pkg from './package';
|
|
|
|
import stars from './stars';
|
|
|
|
import profile from './v1/profile';
|
|
|
|
import token from './v1/token';
|
2020-08-13 16:27:00 -05:00
|
|
|
import v1Search from './v1/search';
|
2017-06-21 12:02:52 -05:00
|
|
|
|
2020-09-16 23:48:16 -05:00
|
|
|
export default function (
|
|
|
|
config: Config,
|
|
|
|
auth: IAuth,
|
|
|
|
storage: IStorageHandler
|
|
|
|
): Express.Application {
|
2017-06-21 12:02:52 -05:00
|
|
|
/* eslint new-cap:off */
|
|
|
|
const app = express.Router();
|
|
|
|
/* eslint new-cap:off */
|
|
|
|
|
|
|
|
// validate all of these params as a package name
|
|
|
|
// this might be too harsh, so ask if it causes trouble
|
2018-03-10 17:13:26 -05:00
|
|
|
app.param('package', validatePackage);
|
2018-04-30 08:41:04 -05:00
|
|
|
app.param('filename', validateName);
|
|
|
|
app.param('tag', validateName);
|
|
|
|
app.param('version', validateName);
|
|
|
|
app.param('revision', validateName);
|
|
|
|
app.param('token', validateName);
|
2017-06-21 12:02:52 -05:00
|
|
|
|
|
|
|
// these can't be safely put into express url for some reason
|
|
|
|
// TODO: For some reason? what reason?
|
|
|
|
app.param('_rev', match(/^-rev$/));
|
|
|
|
app.param('org_couchdb_user', match(/^org\.couchdb\.user:/));
|
|
|
|
app.param('anything', match(/.*/));
|
2018-04-30 08:13:54 -05:00
|
|
|
app.use(auth.apiJWTmiddleware());
|
2020-07-16 14:59:21 -05:00
|
|
|
app.use(bodyParser.json({ strict: false, limit: config.max_body_size || '10mb' }));
|
2020-03-03 17:59:19 -05:00
|
|
|
// @ts-ignore
|
2018-10-06 17:32:17 -05:00
|
|
|
app.use(antiLoop(config));
|
2017-06-21 12:02:52 -05:00
|
|
|
// encode / in a scoped package name to be matched as a single parameter in routes
|
|
|
|
app.use(encodeScopePackage);
|
|
|
|
// for "npm whoami"
|
|
|
|
whoami(app);
|
|
|
|
pkg(app, auth, storage, config);
|
2018-10-12 04:07:55 -05:00
|
|
|
profile(app, auth);
|
2017-06-21 12:02:52 -05:00
|
|
|
search(app, auth, storage);
|
2018-08-21 01:05:34 -05:00
|
|
|
user(app, auth, config);
|
2017-06-21 12:02:52 -05:00
|
|
|
distTags(app, auth, storage);
|
|
|
|
publish(app, auth, storage, config);
|
|
|
|
ping(app);
|
2019-03-11 10:37:17 -05:00
|
|
|
stars(app, storage);
|
2020-03-06 02:19:06 -05:00
|
|
|
|
2021-01-02 02:11:32 -05:00
|
|
|
if (config?.flags?.search === true) {
|
2020-08-13 16:27:00 -05:00
|
|
|
v1Search(app, auth, storage);
|
2020-06-22 06:33:43 -05:00
|
|
|
}
|
2020-03-06 02:19:06 -05:00
|
|
|
|
2021-01-02 02:11:32 -05:00
|
|
|
if (config?.flags?.token === true) {
|
2019-09-07 17:46:50 -05:00
|
|
|
token(app, auth, storage, config);
|
|
|
|
}
|
2017-06-21 12:02:52 -05:00
|
|
|
return app;
|
2018-03-10 17:13:26 -05:00
|
|
|
}
|