All files LoggerMiddleware.ts

42.86% Statements 3/7
100% Branches 0/0
0% Functions 0/3
42.86% Lines 3/7

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                              1x     1x     1x                                
// Copyright (C) 2017  Norman Breau
 
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
 
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
 
// You should have received a copy of the GNU General Public License
// along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
import {Middleware} from './Middleware';
import {Request} from './Request';
import {Response} from './Response';
import {getApplicationLogger} from './instance';
import {IRequestResponse} from './IRequestResponse';
 
export class LoggerMiddleware extends Middleware {
    public constructor() {
        super();
    }
 
    public execute(request: Request, response: Response, options?: any): Promise<IRequestResponse> {
        return new Promise<IRequestResponse>((resolve, reject) => {
            // tslint:disable-next-line max-line-length
            getApplicationLogger().info(`${request.getForwardedIP()} (${request.getIP()}) - ${request.getMethod()} ${request.getURL()} - UA(${request.getHeader('user-agent')})`);
            resolve({
                request: request,
                response: response
            });
        });
    }
}