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

Java tutorial

Introduction

Here is the source code for com.dungnv.ws.provider.CxfWsClientOutInterceptor.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.dungnv.streetfood.dto.UserDTO;
import com.dungnv.utils.DateTimeUtils;
import com.dungnv.utils.StringUtils;
import com.vaadin.server.VaadinSession;
import com.vaadin.ui.UI;

import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import java.util.logging.Logger;
import org.apache.cxf.interceptor.AbstractLoggingInterceptor;
import org.apache.cxf.interceptor.LoggingMessage;
import org.apache.cxf.message.Message;
import org.apache.cxf.phase.Phase;

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

    static final Logger logger = Logger.getLogger(CxfWsClientInInterceptor.class.getName());

    public CxfWsClientOutInterceptor() {
        super(Phase.PRE_STREAM);
    }

    public static final Map<String, String> mapLogWS = new HashMap();
    public static final Map<String, Date> mapDateWS = new HashMap();
    public static final Map<String, String> mapMethodWS = new HashMap();

    @Override
    public void handleMessage(Message message) {
        try {
            UserDTO user = (UserDTO) VaadinSession.getCurrent().getSession().getAttribute("user");
            String id = (String) message.getExchange().get(LoggingMessage.ID_KEY);
            if (id == null) {
                id = LoggingMessage.nextId();
                message.getExchange().put(LoggingMessage.ID_KEY, id);
                System.out.println("id: " + id);
            }

            try {
                List<String> listRequest = new ArrayList<>();
                listRequest.add(VaadinSession.getCurrent().getCsrfToken() + "_" + id);
                Map<String, List<String>> protocolHeader = (TreeMap) message.get(Message.PROTOCOL_HEADERS);
                if (protocolHeader == null) {
                    protocolHeader = new TreeMap<>();
                }
                protocolHeader.put("RequestId", listRequest);
                message.put(Message.PROTOCOL_HEADERS, protocolHeader);
            } catch (Exception e) {
                //            ex.printStackTrace();
            }

            String log = "start_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() + "|" + getMethod(message) + ".do" + "|"
                    + "" + "|" + getMethod(message) + "|{responeTime}|[RequestId="
                    + VaadinSession.getCurrent().getCsrfToken() + "_" + id
                    //                    + "][Unit=" + user.getUnitCode()
                    + "][VTS-KPIID=null]";

            mapDateWS.put(id, new Date());
            mapMethodWS.put(id, getMethod(message));
            mapLogWS.put(id, log);

        } catch (Exception ex) {
            //            ex.printStackTrace();
        }
    }

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

    private String getMethod(Message message) {
        return StringUtils
                .getStringParttern(message.get("java.lang.reflect.Method").toString(), "com.viettel.[\\w\\.]+\\(")
                .replace("(", "");
    }
}