0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-20 22:52:46 -05:00
verdaccio/src/api/endpoint/index.js

55 lines
1.8 KiB
JavaScript
Raw Normal View History

2018-03-10 21:09:04 +01:00
// @flow
import type {IAuth, IStorage} from '../../../types';
import type {Config} from '@verdaccio/types';
import express from 'express';
import bodyParser from 'body-parser';
import whoami from './api/whoami';
import ping from './api/ping';
import user from './api/user';
import distTags from './api/dist-tags';
import publish from './api/publish';
import search from './api/search';
import pkg from './api/package';
2018-03-10 23:13:26 +01:00
const {match, validate_name, validatePackage, encodeScopePackage, anti_loop} = require('../web/middleware');
2017-06-22 01:02:52 +08:00
2018-03-10 23:13:26 +01:00
export default function(config: Config, auth: IAuth, storage: IStorage) {
2017-06-22 01:02:52 +08: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 23:13:26 +01:00
app.param('package', validatePackage);
app.param('filename', validate_name);
app.param('tag', validate_name);
app.param('version', validate_name);
app.param('revision', validate_name);
app.param('token', validate_name);
2017-06-22 01:02:52 +08: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(/.*/));
app.use(auth.basic_middleware());
// app.use(auth.bearer_middleware())
app.use(bodyParser.json({strict: false, limit: config.max_body_size || '10mb'}));
2018-03-10 23:13:26 +01:00
app.use(anti_loop(config));
2017-06-22 01:02:52 +08: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);
search(app, auth, storage);
user(app, auth);
distTags(app, auth, storage);
publish(app, auth, storage, config);
ping(app);
return app;
2018-03-10 23:13:26 +01:00
}