mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
refactor: get rid off require('../lib/logger');
(#1040)
refactored `require('../lib/logger');` in `src/api/index.js`, `src/api/middleware.js` and `src/api/storage.js` and `require ('./midderlware')` from `src/api/index.js`
This commit is contained in:
parent
06706c857c
commit
385a791237
3 changed files with 15 additions and 18 deletions
|
@ -21,9 +21,8 @@ import web from './web';
|
||||||
import type { $Application } from 'express';
|
import type { $Application } from 'express';
|
||||||
import type { $ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler, IAuth } from '../../types';
|
import type { $ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler, IAuth } from '../../types';
|
||||||
import type { Config as IConfig, IPluginMiddleware } from '@verdaccio/types';
|
import type { Config as IConfig, IPluginMiddleware } from '@verdaccio/types';
|
||||||
|
import { setup, logger } from '../lib/logger';
|
||||||
const LoggerApp = require('../lib/logger');
|
import { log, final, errorReportingMiddleware } from './middleware';
|
||||||
const Middleware = require('./middleware');
|
|
||||||
|
|
||||||
const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
||||||
const auth: IAuth = new Auth(config);
|
const auth: IAuth = new Auth(config);
|
||||||
|
@ -34,8 +33,8 @@ const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
||||||
app.use(cors());
|
app.use(cors());
|
||||||
|
|
||||||
// Router setup
|
// Router setup
|
||||||
app.use(Middleware.log);
|
app.use(log);
|
||||||
app.use(Middleware.errorReportingMiddleware);
|
app.use(errorReportingMiddleware);
|
||||||
app.use(function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {
|
app.use(function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {
|
||||||
res.setHeader('X-Powered-By', config.user_agent);
|
res.setHeader('X-Powered-By', config.user_agent);
|
||||||
next();
|
next();
|
||||||
|
@ -56,7 +55,7 @@ const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
||||||
// register middleware plugins
|
// register middleware plugins
|
||||||
const plugin_params = {
|
const plugin_params = {
|
||||||
config: config,
|
config: config,
|
||||||
logger: LoggerApp.logger,
|
logger: logger,
|
||||||
};
|
};
|
||||||
const plugins = loadPlugin(config, config.middlewares, plugin_params, function(plugin: IPluginMiddleware) {
|
const plugins = loadPlugin(config, config.middlewares, plugin_params, function(plugin: IPluginMiddleware) {
|
||||||
return plugin.register_middlewares;
|
return plugin.register_middlewares;
|
||||||
|
@ -91,7 +90,7 @@ const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
||||||
if (_.isFunction(res.report_error) === false) {
|
if (_.isFunction(res.report_error) === false) {
|
||||||
// in case of very early error this middleware may not be loaded before error is generated
|
// in case of very early error this middleware may not be loaded before error is generated
|
||||||
// fixing that
|
// fixing that
|
||||||
Middleware.errorReportingMiddleware(req, res, _.noop);
|
errorReportingMiddleware(req, res, _.noop);
|
||||||
}
|
}
|
||||||
res.report_error(err);
|
res.report_error(err);
|
||||||
} else {
|
} else {
|
||||||
|
@ -100,13 +99,13 @@ const defineAPI = function(config: IConfig, storage: IStorageHandler) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
app.use(Middleware.final);
|
app.use(final);
|
||||||
|
|
||||||
return app;
|
return app;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default (async function(configHash: any) {
|
export default (async function(configHash: any) {
|
||||||
LoggerApp.setup(configHash.logs);
|
setup(configHash.logs);
|
||||||
const config: IConfig = new AppConfig(configHash);
|
const config: IConfig = new AppConfig(configHash);
|
||||||
const storage: IStorageHandler = new Storage(config);
|
const storage: IStorageHandler = new Storage(config);
|
||||||
// waits until init calls have been intialized
|
// waits until init calls have been intialized
|
||||||
|
|
|
@ -10,8 +10,7 @@ import { API_ERROR, HEADER_TYPE, HEADERS, HTTP_STATUS, TOKEN_BASIC, TOKEN_BEARER
|
||||||
import { stringToMD5 } from '../lib/crypto-utils';
|
import { stringToMD5 } from '../lib/crypto-utils';
|
||||||
import type { $ResponseExtend, $RequestExtend, $NextFunctionVer, IAuth } from '../../types';
|
import type { $ResponseExtend, $RequestExtend, $NextFunctionVer, IAuth } from '../../types';
|
||||||
import type { Config } from '@verdaccio/types';
|
import type { Config } from '@verdaccio/types';
|
||||||
|
import { logger } from '../lib/logger';
|
||||||
const Logger = require('../lib/logger');
|
|
||||||
|
|
||||||
export function match(regexp: RegExp) {
|
export function match(regexp: RegExp) {
|
||||||
return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string) {
|
return function(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string) {
|
||||||
|
@ -166,7 +165,7 @@ export function final(body: any, req: $RequestExtend, res: $ResponseExtend, next
|
||||||
|
|
||||||
export function log(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {
|
export function log(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {
|
||||||
// logger
|
// logger
|
||||||
req.log = Logger.logger.child({ sub: 'in' });
|
req.log = logger.child({ sub: 'in' });
|
||||||
|
|
||||||
let _auth = req.headers.authorization;
|
let _auth = req.headers.authorization;
|
||||||
if (_.isNil(_auth) === false) {
|
if (_.isNil(_auth) === false) {
|
||||||
|
@ -263,9 +262,9 @@ export function errorReportingMiddleware(req: $RequestExtend, res: $ResponseExte
|
||||||
next({ error: err.message || API_ERROR.UNKNOWN_ERROR });
|
next({ error: err.message || API_ERROR.UNKNOWN_ERROR });
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Logger.logger.error({ err: err }, 'unexpected error: @{!err.message}\n@{err.stack}');
|
logger.error({ err: err }, 'unexpected error: @{!err.message}\n@{err.stack}');
|
||||||
if (!res.status || !res.send) {
|
if (!res.status || !res.send) {
|
||||||
Logger.logger.error('this is an error in express.js, please report this');
|
logger.error('this is an error in express.js, please report this');
|
||||||
res.destroy();
|
res.destroy();
|
||||||
} else if (!res.headersSent) {
|
} else if (!res.headersSent) {
|
||||||
res.status(HTTP_STATUS.INTERNAL_ERROR);
|
res.status(HTTP_STATUS.INTERNAL_ERROR);
|
||||||
|
|
|
@ -20,8 +20,7 @@ import type { IStorage, IProxy, IStorageHandler, ProxyList, StringValue } from '
|
||||||
import type { Versions, Package, Config, MergeTags, Version, DistFile, Callback, Logger } from '@verdaccio/types';
|
import type { Versions, Package, Config, MergeTags, Version, DistFile, Callback, Logger } from '@verdaccio/types';
|
||||||
import type { IReadTarball, IUploadTarball } from '@verdaccio/streams';
|
import type { IReadTarball, IUploadTarball } from '@verdaccio/streams';
|
||||||
import { hasProxyTo } from './config-utils';
|
import { hasProxyTo } from './config-utils';
|
||||||
|
import { logger } from '../lib/logger';
|
||||||
const LoggerApi = require('../lib/logger');
|
|
||||||
|
|
||||||
class Storage implements IStorageHandler {
|
class Storage implements IStorageHandler {
|
||||||
localStorage: IStorage;
|
localStorage: IStorage;
|
||||||
|
@ -32,11 +31,11 @@ class Storage implements IStorageHandler {
|
||||||
constructor(config: Config) {
|
constructor(config: Config) {
|
||||||
this.config = config;
|
this.config = config;
|
||||||
this.uplinks = setupUpLinks(config);
|
this.uplinks = setupUpLinks(config);
|
||||||
this.logger = LoggerApi.logger.child();
|
this.logger = logger.child();
|
||||||
}
|
}
|
||||||
|
|
||||||
init(config: Config) {
|
init(config: Config) {
|
||||||
this.localStorage = new LocalStorage(this.config, LoggerApi.logger);
|
this.localStorage = new LocalStorage(this.config, logger);
|
||||||
|
|
||||||
return this.localStorage.getSecret(config);
|
return this.localStorage.getSecret(config);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue