Java tutorial
/* * 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); } }); } }