mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-06 22:40:26 -05:00
fix: using correctly logging levels (#2153)
* fix: using correctly logging levels * chore: update deps
This commit is contained in:
parent
99e10f57cf
commit
5b6be2aa09
13 changed files with 48 additions and 46 deletions
4
.github/workflows/ci-e2e.yml
vendored
4
.github/workflows/ci-e2e.yml
vendored
|
@ -20,10 +20,8 @@ jobs:
|
|||
with:
|
||||
node-version: ${{ matrix.node_version }}
|
||||
- name: Install
|
||||
run: yarn install --immutable
|
||||
run: yarn install
|
||||
- name: Build
|
||||
run: yarn code:build
|
||||
- name: Test CLI
|
||||
run: yarn test:e2e:cli
|
||||
env:
|
||||
NODE_ENV: production
|
||||
|
|
|
@ -41,8 +41,10 @@
|
|||
"jsonwebtoken": "8.5.1",
|
||||
"kleur": "4.1.4",
|
||||
"lodash": "4.17.21",
|
||||
"lru-cache": "6.0.0",
|
||||
"lunr-mutable-indexes": "2.3.2",
|
||||
"marked": "2.0.1",
|
||||
"memoizee": "0.4.15",
|
||||
"mime": "2.5.2",
|
||||
"minimatch": "3.0.4",
|
||||
"mkdirp": "1.0.4",
|
||||
|
@ -126,7 +128,6 @@
|
|||
"jest-junit": "9.0.0",
|
||||
"lint-staged": "8.2.1",
|
||||
"lockfile-lint": "4.3.7",
|
||||
"lru-cache": "6.0.0",
|
||||
"nock": "12.0.3",
|
||||
"node-mocks-http": "^1.10.1",
|
||||
"prettier": "2.2.1",
|
||||
|
@ -171,6 +172,7 @@
|
|||
"lint:ts": "eslint \"**/*.{js,jsx,ts,tsx}\"",
|
||||
"lint:lockfile": "lockfile-lint --path yarn.lock --type yarn --validate-https --allowed-hosts verdaccio npm yarn",
|
||||
"start": "yarn babel-node --extensions \".ts,.tsx\" src/lib/cli",
|
||||
"start:debug": "yarn node debug/bootstrap.js",
|
||||
"code:build": "yarn babel src/ --out-dir build/ --copy-files --extensions \".ts,.tsx\" --source-maps inline",
|
||||
"code:docker-build": "yarn babel src/ --out-dir build/ --copy-files --extensions \".ts,.tsx\"",
|
||||
"docker": "docker build -t verdaccio/verdaccio:pr-2122 . --no-cache",
|
||||
|
|
|
@ -227,9 +227,6 @@ export const LOG_VERDACCIO_BYTES = `${LOG_STATUS_MESSAGE}, bytes: @{bytes.in}/@{
|
|||
|
||||
export function log(config: Config) {
|
||||
return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {
|
||||
// logger
|
||||
req.log = logger.child({ sub: 'in' });
|
||||
|
||||
const _auth = req.headers.authorization;
|
||||
if (_.isNil(_auth) === false) {
|
||||
req.headers.authorization = '<Classified>';
|
||||
|
@ -243,7 +240,7 @@ export function log(config: Config) {
|
|||
req.url = req.originalUrl;
|
||||
// avoid log noise data from static content
|
||||
if (req.originalUrl.match(/static/) === null) {
|
||||
req.log.info({ req: req, ip: req.ip }, "@{ip} requested '@{req.method} @{req.url}'");
|
||||
logger.http({ req: req, ip: req.ip }, "@{ip} requested '@{req.method} @{req.url}'");
|
||||
}
|
||||
req.originalUrl = req.url;
|
||||
|
||||
|
@ -293,13 +290,12 @@ export function log(config: Config) {
|
|||
req.url = req.originalUrl;
|
||||
// avoid log noise data from static content
|
||||
if (req.url.match(/static/) === null) {
|
||||
req.log.warn(
|
||||
logger.http(
|
||||
{
|
||||
request: {
|
||||
method: req.method,
|
||||
url: req.url,
|
||||
},
|
||||
level: 35, // http
|
||||
user: (req.remote_user && req.remote_user.name) || null,
|
||||
remoteIP,
|
||||
status: res.statusCode,
|
||||
|
|
|
@ -18,6 +18,7 @@ import loadPlugin from '../lib/plugin-loader';
|
|||
import { $RequestExtend, $ResponseExtend, IAuth, AESPayload } from '../../types';
|
||||
import { API_ERROR, SUPPORT_ERRORS, TOKEN_BASIC, TOKEN_BEARER } from './constants';
|
||||
import { aesEncrypt, signPayload } from './crypto-utils';
|
||||
import { logger } from './logger';
|
||||
import {
|
||||
getDefaultPlugins,
|
||||
getMiddlewareCredentials,
|
||||
|
@ -33,9 +34,6 @@ import {
|
|||
import { convertPayloadToBase64, ErrorCode } from './utils';
|
||||
import { getMatchedPackagesSpec } from './config-utils';
|
||||
|
||||
/* eslint-disable @typescript-eslint/no-var-requires */
|
||||
const LoggerApi = require('./logger');
|
||||
|
||||
class Auth implements IAuth {
|
||||
public config: Config;
|
||||
public logger: Logger;
|
||||
|
@ -44,7 +42,7 @@ class Auth implements IAuth {
|
|||
|
||||
public constructor(config: Config) {
|
||||
this.config = config;
|
||||
this.logger = LoggerApi.logger.child({ sub: 'auth' });
|
||||
this.logger = logger;
|
||||
this.secret = config.secret;
|
||||
this.plugins = this._loadPlugin(config);
|
||||
this._applyDefaultPlugins();
|
||||
|
|
|
@ -48,7 +48,7 @@ class LocalStorage implements IStorage {
|
|||
public logger: Logger;
|
||||
|
||||
public constructor(config: Config, logger: Logger) {
|
||||
this.logger = logger.child({ sub: 'fs' });
|
||||
this.logger = logger;
|
||||
this.config = config;
|
||||
this.storagePlugin = this._loadStorage(config, logger);
|
||||
}
|
||||
|
|
|
@ -6,18 +6,20 @@ export type LevelCode = number;
|
|||
|
||||
export function calculateLevel(levelCode: LevelCode): LogLevel {
|
||||
switch (true) {
|
||||
case levelCode < 15:
|
||||
case levelCode === 10:
|
||||
return 'trace';
|
||||
case levelCode < 25:
|
||||
case levelCode === 20:
|
||||
return 'debug';
|
||||
case levelCode < 35:
|
||||
return 'info';
|
||||
case levelCode == 35:
|
||||
case levelCode === 25:
|
||||
return 'http';
|
||||
case levelCode < 45:
|
||||
case levelCode === 30:
|
||||
return 'info';
|
||||
case levelCode === 40:
|
||||
return 'warn';
|
||||
case levelCode < 55:
|
||||
case levelCode === 50:
|
||||
return 'error';
|
||||
case levelCode === 60:
|
||||
return 'fatal';
|
||||
default:
|
||||
return 'fatal';
|
||||
}
|
||||
|
|
|
@ -21,7 +21,7 @@ export type LogType = 'file' | 'stdout';
|
|||
export type LogFormat = 'json' | 'pretty-timestamped' | 'pretty';
|
||||
|
||||
export function createLogger(
|
||||
options = {},
|
||||
options = {level: 'http'},
|
||||
destination = pino.destination(1),
|
||||
format: LogFormat = DEFAULT_LOG_FORMAT,
|
||||
prettyPrintOptions = {
|
||||
|
@ -35,10 +35,11 @@ export function createLogger(
|
|||
}
|
||||
|
||||
let pinoConfig = {
|
||||
...options,
|
||||
customLevels: {
|
||||
http: 35,
|
||||
http: 25,
|
||||
},
|
||||
...options,
|
||||
level: options.level,
|
||||
serializers: {
|
||||
err: pino.stdSerializers.err,
|
||||
req: pino.stdSerializers.req,
|
||||
|
@ -60,13 +61,20 @@ export function createLogger(
|
|||
prettifier: require('./formatter'),
|
||||
});
|
||||
}
|
||||
const logger = pino(pinoConfig, destination);
|
||||
|
||||
return pino(pinoConfig, destination);
|
||||
if(process.env.DEBUG) {
|
||||
logger.on('level-change', (lvl, val, prevLvl, prevVal) => {
|
||||
debug('%s (%d) was changed to %s (%d)', lvl, val, prevLvl, prevVal);
|
||||
})
|
||||
}
|
||||
|
||||
return logger;
|
||||
}
|
||||
|
||||
export function getLogger() {
|
||||
if (_.isNil(logger)) {
|
||||
console.warn('logger is not defined');
|
||||
process.emitWarning('logger is not defined');
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -94,8 +102,7 @@ export function setup(options: LoggerConfig | LoggerConfigItem = [DEFAULT_LOGGER
|
|||
const isLegacyConf = Array.isArray(options);
|
||||
if (isLegacyConf) {
|
||||
const deprecateMessage = 'deprecate: multiple logger configuration is deprecated, please check the migration guide.';
|
||||
// eslint-disable-next-line no-console
|
||||
console.log(yellow(padLeft(deprecateMessage)));
|
||||
process.emitWarning(deprecateMessage);
|
||||
}
|
||||
|
||||
// verdaccio 5 does not allow multiple logger configuration
|
||||
|
@ -103,20 +110,16 @@ export function setup(options: LoggerConfig | LoggerConfigItem = [DEFAULT_LOGGER
|
|||
// next major will thrown an error
|
||||
let loggerConfig = isLegacyConf ? options[0] : options;
|
||||
if (!loggerConfig?.level) {
|
||||
loggerConfig = Object.assign({}, loggerConfig, {
|
||||
loggerConfig = Object.assign({}, {
|
||||
level: 'http',
|
||||
});
|
||||
}, loggerConfig);
|
||||
}
|
||||
|
||||
const pinoConfig = { level: loggerConfig.level };
|
||||
if (loggerConfig.type === 'file') {
|
||||
debug('logging file enabled');
|
||||
logger = createLogger(pinoConfig, pino.destination(loggerConfig.path), loggerConfig.format);
|
||||
} else if (loggerConfig.type === 'rotating-file') {
|
||||
// eslint-disable-next-line no-console
|
||||
console.log(yellow(padLeft('rotating-file type is not longer supported, consider use [logrotate] instead')));
|
||||
// eslint-disable-next-line no-console
|
||||
console.log(yellow(padLeft('fallback to stdout configuration triggered')));
|
||||
process.emitWarning('rotating-file type is not longer supported, consider use [logrotate] instead');
|
||||
debug('logging stdout enabled');
|
||||
logger = createLogger(pinoConfig, pino.destination(1), loggerConfig.format);
|
||||
} else {
|
||||
|
|
|
@ -55,7 +55,7 @@ class Storage implements IStorageHandler {
|
|||
public constructor(config: Config) {
|
||||
this.config = config;
|
||||
this.uplinks = setupUpLinks(config);
|
||||
this.logger = logger.child({module: 'storage'});
|
||||
this.logger = logger;
|
||||
this.filters = [];
|
||||
// @ts-ignore
|
||||
this.localStorage = null;
|
||||
|
|
|
@ -8,6 +8,7 @@ import { ReadTarball } from '@verdaccio/streams';
|
|||
import { Config, Callback, Headers, Logger, Package } from '@verdaccio/types';
|
||||
import { IProxy, UpLinkConfLocal } from '../../types';
|
||||
import { parseInterval, isObject, ErrorCode, buildToken } from './utils';
|
||||
import { logger} from './logger';
|
||||
import {
|
||||
ERROR_CODE,
|
||||
TOKEN_BASIC,
|
||||
|
@ -18,7 +19,6 @@ import {
|
|||
HEADER_TYPE,
|
||||
CHARACTER_ENCODING
|
||||
} from './constants';
|
||||
const LoggerApi = require('./logger');
|
||||
|
||||
const encode = function (thing): string {
|
||||
return encodeURIComponent(thing).replace(/^%40/, '@');
|
||||
|
@ -71,7 +71,7 @@ class ProxyStorage implements IProxy {
|
|||
this.failed_requests = 0;
|
||||
this.userAgent = mainConfig.user_agent;
|
||||
this.ca = config.ca;
|
||||
this.logger = LoggerApi.logger.child({ sub: 'out' });
|
||||
this.logger = logger;
|
||||
this.server_id = mainConfig.server_id;
|
||||
|
||||
this.url = URL.parse(this.config.url);
|
||||
|
@ -194,11 +194,10 @@ class ProxyStorage implements IProxy {
|
|||
function logActivity(): void {
|
||||
let message = "@{!status}, req: '@{request.method} @{request.url}'";
|
||||
message += error ? ', error: @{!error}' : ', bytes: @{bytes.in}/@{bytes.out}';
|
||||
self.logger.warn(
|
||||
self.logger.http(
|
||||
{
|
||||
err: err || undefined, // if error is null/false change this to undefined so it wont log
|
||||
request: { method: method, url: uri },
|
||||
level: 35, // http
|
||||
status: res != null ? res.statusCode : 'ERR',
|
||||
error: error,
|
||||
bytes: {
|
||||
|
@ -245,13 +244,12 @@ class ProxyStorage implements IProxy {
|
|||
if (_.isNil(requestCallback) === false) {
|
||||
(function do_log(): void {
|
||||
const message = "@{!status}, req: '@{request.method} @{request.url}' (streaming)";
|
||||
self.logger.warn(
|
||||
self.logger.http(
|
||||
{
|
||||
request: {
|
||||
method: method,
|
||||
url: uri
|
||||
},
|
||||
level: 35, // http
|
||||
status: _.isNull(res) === false ? res.statusCode : 'ERR'
|
||||
},
|
||||
message
|
||||
|
|
|
@ -6,6 +6,7 @@ import buildDebug from 'debug';
|
|||
import semver from 'semver';
|
||||
import YAML from 'js-yaml';
|
||||
import validator from 'validator';
|
||||
import memoizee from 'memoizee';
|
||||
import sanitizyReadme from '@verdaccio/readme';
|
||||
|
||||
import { Package, Version, Author } from '@verdaccio/types';
|
||||
|
@ -143,6 +144,8 @@ export function convertDistRemoteToLocalTarballUrls(pkg: Package, req: Request,
|
|||
return pkg;
|
||||
}
|
||||
|
||||
const memoizedgetPublicUrl = memoizee(getPublicUrl);
|
||||
|
||||
/**
|
||||
* Filter a tarball url.
|
||||
* @param {*} uri
|
||||
|
@ -155,7 +158,7 @@ export function getLocalRegistryTarballUri(uri: string, pkgName: string, req: Re
|
|||
return uri;
|
||||
}
|
||||
const tarballName = extractTarballFromUrl(uri);
|
||||
const domainRegistry = getPublicUrl(urlPrefix || '', req);
|
||||
const domainRegistry = memoizedgetPublicUrl(urlPrefix || '', req);
|
||||
|
||||
return `${domainRegistry}${encodeScopedUri(pkgName)}/-/${tarballName}`;
|
||||
}
|
||||
|
@ -368,8 +371,10 @@ export function parseConfigFile(configPath: string): any {
|
|||
if (/\.ya?ml$/i.test(configPath)) {
|
||||
return YAML.load(fs.readFileSync(configPath, CHARACTER_ENCODING.UTF8));
|
||||
}
|
||||
debug('yaml parsed');
|
||||
return require(configPath);
|
||||
} catch (e) {
|
||||
debug('yaml parse failed');
|
||||
if (e.code !== 'MODULE_NOT_FOUND') {
|
||||
e.message = APP_ERROR.CONFIG_NOT_VALID;
|
||||
}
|
||||
|
|
|
@ -13,7 +13,7 @@ uplinks:
|
|||
npmjs:
|
||||
url: https://registry.verdaccio.org/
|
||||
|
||||
logs: { type: stdout, format: json, level: trace }
|
||||
logs: { type: stdout, format: json, level: http }
|
||||
|
||||
packages:
|
||||
'@*/*':
|
||||
|
|
|
@ -17,7 +17,7 @@ uplinks:
|
|||
local:
|
||||
url: http://localhost:4873
|
||||
|
||||
logs: { type: stdout, format: json, level: warn }
|
||||
logs: { type: stdout, format: json, level: http }
|
||||
|
||||
packages:
|
||||
'@*/*':
|
||||
|
|
BIN
yarn.lock
BIN
yarn.lock
Binary file not shown.
Loading…
Reference in a new issue