2023-01-28 08:39:37 -05:00
|
|
|
import buildDebug from 'debug';
|
|
|
|
import express, { Application } from 'express';
|
|
|
|
import os from 'os';
|
|
|
|
import path from 'path';
|
|
|
|
|
|
|
|
import { errorUtils } from '@verdaccio/core';
|
2023-11-12 11:51:20 -05:00
|
|
|
import { errorReportingMiddleware, final, handleError } from '@verdaccio/middleware';
|
2023-01-28 08:39:37 -05:00
|
|
|
import { generateRandomHexString } from '@verdaccio/utils';
|
|
|
|
|
|
|
|
import Auth from '../../src/lib/auth';
|
|
|
|
import Config from '../../src/lib/config';
|
2023-11-12 11:51:20 -05:00
|
|
|
import { logger } from '../../src/lib/logger';
|
2023-01-28 08:39:37 -05:00
|
|
|
|
|
|
|
const debug = buildDebug('verdaccio:tools:helpers:server');
|
|
|
|
|
|
|
|
export async function initializeServer(
|
|
|
|
configName,
|
|
|
|
routesMiddleware: any[] = [],
|
|
|
|
Storage
|
|
|
|
): Promise<Application> {
|
|
|
|
const app = express();
|
|
|
|
const config = new Config(configName);
|
|
|
|
config.storage = path.join(os.tmpdir(), '/storage', generateRandomHexString());
|
|
|
|
// httpass would get path.basename() for configPath thus we need to create a dummy folder
|
|
|
|
// to avoid conflics
|
|
|
|
// FUTURE: self_path is configPath in v6
|
|
|
|
config.self_path = config.storage;
|
2023-04-22 04:08:59 -05:00
|
|
|
config.configPath = config.storage;
|
2023-01-28 08:39:37 -05:00
|
|
|
debug('storage: %s', config.storage);
|
|
|
|
const storage = new Storage(config);
|
|
|
|
await storage.init(config, []);
|
|
|
|
const auth: Auth = new Auth(config);
|
|
|
|
// FUTURE: in v6 auth.init() is being called
|
|
|
|
// TODO: this might not be need it, used in apiEndpoints
|
2023-02-14 16:20:11 -05:00
|
|
|
app.use(express.json({ strict: false, limit: '100mb' }));
|
2023-01-28 08:39:37 -05:00
|
|
|
// @ts-ignore
|
2023-11-12 11:51:20 -05:00
|
|
|
app.use(errorReportingMiddleware(logger));
|
2023-01-28 08:39:37 -05:00
|
|
|
for (let route of routesMiddleware) {
|
|
|
|
if (route.async) {
|
|
|
|
const middleware = await route.routes(config, auth, storage);
|
|
|
|
app.use(middleware);
|
|
|
|
} else {
|
|
|
|
app.use(route(config, auth, storage));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// catch 404
|
|
|
|
app.get('/*', function (req, res, next) {
|
|
|
|
next(errorUtils.getNotFound('resource not found'));
|
|
|
|
});
|
|
|
|
|
|
|
|
// @ts-ignore
|
2023-11-12 11:51:20 -05:00
|
|
|
app.use(handleError(logger));
|
2023-01-28 08:39:37 -05:00
|
|
|
// @ts-ignore
|
|
|
|
app.use(final);
|
|
|
|
|
|
|
|
app.use(function (request, response) {
|
|
|
|
response.status(590);
|
|
|
|
response.json({ error: 'cannot handle this' });
|
|
|
|
});
|
|
|
|
|
|
|
|
return app;
|
|
|
|
}
|