From 8fc90f019dc4811f859b184873902b156d85f0dd Mon Sep 17 00:00:00 2001 From: Michael O'Brien Date: Mon, 30 Jul 2018 10:42:42 -0400 Subject: decouple aop lib wrapper from war Change-Id: I8e34ca4c32fdd70646a99f66c880879bcd142224 Issue-ID: LOG-137 Signed-off-by: Michael O'Brien --- .../org/onap/logging/library/LoggingAspect.java | 55 ++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 reference/logging-library/src/main/java/org/onap/logging/library/LoggingAspect.java (limited to 'reference/logging-library/src/main/java/org/onap/logging') diff --git a/reference/logging-library/src/main/java/org/onap/logging/library/LoggingAspect.java b/reference/logging-library/src/main/java/org/onap/logging/library/LoggingAspect.java new file mode 100644 index 0000000..46b1fa7 --- /dev/null +++ b/reference/logging-library/src/main/java/org/onap/logging/library/LoggingAspect.java @@ -0,0 +1,55 @@ +/** + * ============LICENSE_START======================================================= + * org.onap.logging + * ================================================================================ + * Copyright © 2018 Amdocs + * All rights reserved. + * ================================================================================ + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ============LICENSE_END========================================================= + */ +package org.onap.logging.library; + +import javax.servlet.http.HttpServletRequest; + +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.annotation.After; +import org.aspectj.lang.annotation.Aspect; +import org.aspectj.lang.annotation.Before; +import org.onap.logging.ref.slf4j.ONAPLogAdapter; +import org.slf4j.LoggerFactory; + +@Aspect +public class LoggingAspect { + + @Before("execution(* org.onap.demo.logging.*.*(..))") + public void logBefore(JoinPoint joinPoint) { + Object[] args = joinPoint.getArgs(); + Object servletRequest = args[0]; + ONAPLogAdapter.HttpServletRequestAdapter requestAdapter = + new ONAPLogAdapter.HttpServletRequestAdapter((HttpServletRequest)servletRequest); + final ONAPLogAdapter adapter = new ONAPLogAdapter( + LoggerFactory.getLogger(joinPoint.getTarget().getClass())); + try { + adapter.entering(requestAdapter); + } finally { + } + } + + @After("execution(* org.onap.demo.logging.*.*(..))") + public void logAfter(JoinPoint joinPoint) { + final ONAPLogAdapter adapter = new ONAPLogAdapter( + LoggerFactory.getLogger(joinPoint.getTarget().getClass())); + adapter.exiting(); + } +} -- cgit 1.2.3-korg