com.dungnv.ws.provider.CxfWsClientInInterceptor.java Source code

Java tutorial

Introduction

Here is the source code for com.dungnv.ws.provider.CxfWsClientInInterceptor.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.dungnv.ws.provider;

import com.vaadin.server.VaadinSession;
import com.vaadin.ui.UI;

import java.io.InputStream;
import java.io.Reader;
import java.io.SequenceInputStream;
import java.util.Date;
import java.util.logging.Logger;
import org.apache.cxf.attachment.DelegatingInputStream;
import org.apache.cxf.common.logging.LogUtils;
import org.apache.cxf.endpoint.Endpoint;
import org.apache.cxf.helpers.IOUtils;
import org.apache.cxf.interceptor.AbstractLoggingInterceptor;
import org.apache.cxf.interceptor.Fault;
import org.apache.cxf.interceptor.LoggingMessage;
import org.apache.cxf.io.CachedOutputStream;
import org.apache.cxf.io.CachedWriter;
import org.apache.cxf.message.Message;
import org.apache.cxf.phase.Phase;
import org.apache.cxf.service.model.EndpointInfo;
import org.apache.cxf.service.model.InterfaceInfo;

/**
 *
 * @author dungnv50
 */
public class CxfWsClientInInterceptor extends AbstractLoggingInterceptor {

    static final org.apache.log4j.Logger logger = org.apache.log4j.Logger.getLogger(CxfWsClientInInterceptor.class);
    static Logger LOG = null;

    public CxfWsClientInInterceptor() {
        super(Phase.RECEIVE);
    }

    @Override
    public void handleMessage(Message message) throws Fault {
        //        Logger log = getMessageLogger(message);
        //        if ((this.writer != null) || (log.isLoggable(Level.INFO))) {
        //            logging(log, message);
        //        }
        try {

            String id = (String) message.getExchange().get(LoggingMessage.ID_KEY);
            if (id == null) {
                id = LoggingMessage.nextId();
                message.getExchange().put(LoggingMessage.ID_KEY, id);
            }

            String method = CxfWsClientOutInterceptor.mapMethodWS.get(id);
            String startLog = CxfWsClientOutInterceptor.mapLogWS.get(id);
            Date startDate = CxfWsClientOutInterceptor.mapDateWS.get(id);
            Date endDate = new Date();
            //            System.out.println(startDate);
            //            System.out.println(endDate);
            //            System.out.println(endDate.getTime() - startDate.getTime());
            Long responeTime = (endDate.getTime() - startDate.getTime()) / 1000;

            String endLog = "end_action|GNOC"
                    //                    + "|" + DateTimeUtils.convertDateToString(new Date(), "dd/MM/yyyy HH:mm:ss")
                    //                    + "|" + user.getUserName()
                    + "|" + UI.getCurrent().getPage().getWebBrowser().getAddress() + "|"
                    + UI.getCurrent().getPage().getLocation().getHost() + ":"
                    + UI.getCurrent().getPage().getLocation().getPort() + "|" + method + ".do" + "|" + "" + "|"
                    + method + "|" + responeTime + "|[RequestId=" + VaadinSession.getCurrent().getCsrfToken() + "_"
                    + id
                    //                    + "][Unit=" + user.getUnitCode()
                    + "][VTS-KPIID=null]";
            logger.info(startLog.replace("{responeTime}", responeTime.toString()));
            logger.info(endLog);
            CxfWsClientOutInterceptor.mapLogWS.remove(id);
            CxfWsClientOutInterceptor.mapDateWS.remove(id);
            CxfWsClientOutInterceptor.mapMethodWS.remove(id);
        } catch (Exception e) {
            //            e.printStackTrace();
        }
    }

    protected void logging(Logger logger, Message message) throws Fault {
        if (message.containsKey(LoggingMessage.ID_KEY)) {
            return;
        }
        String id = (String) message.getExchange().get(LoggingMessage.ID_KEY);
        if (id == null) {
            id = LoggingMessage.nextId();
            message.getExchange().put(LoggingMessage.ID_KEY, id);
        }
        message.put(LoggingMessage.ID_KEY, id);
        LoggingMessage buffer = new LoggingMessage("Inbound Message\n----------------------------", id);
        if (!Boolean.TRUE.equals(message.get("decoupled.channel.message"))) {
            Integer responseCode = (Integer) message.get(Message.RESPONSE_CODE);
            if (responseCode != null) {
                buffer.getResponseCode().append(responseCode);
            }
        }
        String encoding = (String) message.get(Message.ENCODING);
        if (encoding != null) {
            buffer.getEncoding().append(encoding);
        }
        String httpMethod = (String) message.get("org.apache.cxf.request.method");
        if (httpMethod != null) {
            buffer.getHttpMethod().append(httpMethod);
        }
        String ct = (String) message.get("Content-Type");
        if (ct != null) {
            buffer.getContentType().append(ct);
        }
        Object headers = message.get(Message.PROTOCOL_HEADERS);
        if (headers != null) {
            buffer.getHeader().append(headers);
        }
        String uri = (String) message.get("org.apache.cxf.request.url");
        if (uri == null) {
            String address = (String) message.get(Message.ENDPOINT_ADDRESS);
            uri = (String) message.get("org.apache.cxf.request.uri");
            if ((uri != null) && (uri.startsWith("/"))) {
                if ((address != null) && (!address.startsWith(uri))) {
                    if ((address.endsWith("/")) && (address.length() > 1)) {
                        address = address.substring(0, address.length());
                    }
                    uri = address + uri;
                }
            } else {
                uri = address;
            }
        }
        if (uri != null) {
            buffer.getAddress().append(uri);
            String query = (String) message.get(Message.QUERY_STRING);
            if (query != null) {
                buffer.getAddress().append("?").append(query);
            }
        }
        if ((!isShowBinaryContent()) && (isBinaryContent(ct))) {
            buffer.getMessage().append("--- Binary Content ---").append('\n');
            log(logger, buffer.toString());
            return;
        }
        //        if ((!isShowMultipartContent()) && (isMultipartContent(ct))) {
        //            buffer.getMessage().append("--- Multipart Content ---").append('\n');
        //            log(logger, buffer.toString());
        //            return;
        //        }
        InputStream is = (InputStream) message.getContent(InputStream.class);
        if (is != null) {
            logInputStream(message, is, buffer, encoding, ct);
        } else {
            Reader reader = (Reader) message.getContent(Reader.class);
            if (reader != null) {
                logReader(message, reader, buffer);
            }
        }
        log(logger, formatLoggingMessage(buffer));
    }

    protected void logReader(Message message, Reader reader, LoggingMessage buffer) {
        try {
            CachedWriter writer = new CachedWriter();
            IOUtils.copyAndCloseInput(reader, writer);
            message.setContent(Reader.class, writer.getReader());
            if (writer.getTempFile() != null) {
                buffer.getMessage().append("\nMessage (saved to tmp file):\n");
                buffer.getMessage().append("Filename: " + writer.getTempFile().getAbsolutePath() + "\n");
            }
            if ((writer.size() > this.limit) && (this.limit != -1)) {
                buffer.getMessage().append("(message truncated to " + this.limit + " bytes)\n");
            }
            writer.writeCacheTo(buffer.getPayload(), this.limit);
        } catch (Exception e) {
            throw new Fault(e);
        }
    }

    protected void logInputStream(Message message, InputStream is, LoggingMessage buffer, String encoding,
            String ct) {
        CachedOutputStream bos = new CachedOutputStream();
        if (this.threshold > 0L) {
            bos.setThreshold(this.threshold);
        }
        try {
            InputStream bis = (is instanceof DelegatingInputStream) ? ((DelegatingInputStream) is).getInputStream()
                    : is;

            //            IOUtils.copyAtLeast(bis, bos, this.limit == -1 ? Integer.MAX_VALUE : this.limit);
            IOUtils.copyAtLeast(bis, bos, 1000);
            bos.flush();
            bis = new SequenceInputStream(bos.getInputStream(), bis);
            if ((is instanceof DelegatingInputStream)) {
                ((DelegatingInputStream) is).setInputStream(bis);
            } else {
                message.setContent(InputStream.class, bis);
            }
            if (bos.getTempFile() != null) {
                buffer.getMessage().append("\nMessage (saved to tmp file):\n");
                buffer.getMessage().append("Filename: " + bos.getTempFile().getAbsolutePath() + "\n");
            }
            if ((bos.size() > this.limit) && (this.limit != -1)) {
                buffer.getMessage().append("(message truncated to " + this.limit + " bytes)\n");
            }
            writePayload(buffer.getPayload(), bos, encoding, ct);

            bos.close();
        } catch (Exception e) {
            throw new Fault(e);
        }
    }

    protected String formatLoggingMessage(LoggingMessage loggingMessage) {
        return loggingMessage.toString();
    }

    Logger getMessageLogger(Message message) {
        Endpoint ep = message.getExchange().getEndpoint();
        if ((ep == null) || (ep.getEndpointInfo() == null)) {
            return getLogger();
        }
        EndpointInfo endpoint = ep.getEndpointInfo();
        if (endpoint.getService() == null) {
            return getLogger();
        }
        LOG = (Logger) endpoint.getProperty("MessageLogger", Logger.class);
        if (LOG == null) {
            String serviceName = endpoint.getService().getName().getLocalPart();
            InterfaceInfo iface = endpoint.getService().getInterface();
            String portName = endpoint.getName().getLocalPart();
            String portTypeName = iface.getName().getLocalPart();
            String logName = "org.apache.cxf.services." + serviceName + "." + portName + "." + portTypeName;

            LOG = LogUtils.getL7dLogger(getClass(), null, logName);
            endpoint.setProperty("MessageLogger", logger);
        }
        return LOG;
    }

    @Override
    protected Logger getLogger() {
        return LOG;
    }
}