org.entcore.common.http.EntAccessLogger.java Source code

Java tutorial

Introduction

Here is the source code for org.entcore.common.http.EntAccessLogger.java

Source

/*
 * Copyright  "Open Digital Education", 2017
 *
 * This program is published by "Open Digital Education".
 * You must indicate the name of the software and the company in any production /contribution
 * using the software and indicate on the home page of the software industry in question,
 * "powered by Open Digital Education" with a reference to the website: https://opendigitaleducation.com/.
 *
 * This program is free software, licensed under the terms of the GNU Affero General Public License
 * as published by the Free Software Foundation, version 3 of the License.
 *
 * You can redistribute this application and/or modify it since you respect the terms of the GNU Affero General Public License.
 * If you modify the source code and then use this modified source code in your creation, you must make available the source code of your modifications.
 *
 * You should have received a copy of the GNU Affero General Public License along with the software.
 * If not, please see : <http://www.gnu.org/licenses/>. Full compliance requires reading the terms of this license and following its directives.
    
 */

package org.entcore.common.http;

import fr.wseduc.webutils.request.AccessLogger;
import org.entcore.common.user.UserUtils;
import io.vertx.core.Handler;
import io.vertx.core.eventbus.EventBus;
import io.vertx.core.http.HttpServerRequest;
import io.vertx.core.json.JsonObject;

public class EntAccessLogger extends AccessLogger {

    private final EventBus eb;

    public EntAccessLogger(EventBus eb) {
        this.eb = eb;
    }

    @Override
    public void log(final HttpServerRequest request, final Handler<Void> handler) {
        request.pause();
        UserUtils.getSession(eb, request, true, new Handler<JsonObject>() {
            @Override
            public void handle(JsonObject session) {
                if (session != null) {
                    log.trace(formatLog(request) + " - " + session.getString("userId"));
                } else {
                    log.trace(formatLog(request));
                }
                request.resume();
                handler.handle(null);
            }
        });
    }

}