wuxw7
2018-11-25 c8665e4368f2e81a54a8117adf8aa77c05add0b1
java110-core/src/main/java/com/java110/core/context/AbstractDataFlowContext.java
@@ -2,17 +2,23 @@
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.java110.common.factory.ApplicationContextFactory;
import com.java110.common.log.LoggerEngine;
import com.java110.common.util.DateUtil;
import com.java110.entity.center.Business;
import com.java110.entity.center.DataFlowLinksCost;
import com.java110.entity.center.DataFlowLog;
import org.springframework.http.ResponseEntity;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.*;
/**
 * 数据流上下文
 * Created by wuxw on 2018/5/18.
 */
public abstract class AbstractDataFlowContext implements DataFlowContext,Orders{
public abstract class AbstractDataFlowContext extends AbstractTransactionLog implements DataFlowContext,Orders,TransactionLog{
    private String dataFlowId;
@@ -51,7 +57,10 @@
    private List<DataFlowLog> logDatas = new ArrayList<DataFlowLog>();
    protected Map<String,String> headers = new HashMap<String,String>();
    protected Map<String,String> requestHeaders = new HashMap<String,String>();
    protected Map<String,String> requestCurrentHeaders = new HashMap<String,String>();
    protected Map<String,String> responseHeaders = new HashMap<String,String>();
    protected Map<String,String> responseCurrentHeaders = new HashMap<String,String>();
    //请求开始时间
    private Date startDate;
@@ -66,7 +75,38 @@
     * @return
     * @throws Exception
     */
    public abstract DataFlowContext builder(String reqInfo, Map<String,String> headerAll) throws Exception;
    public  <T> T builder(String reqInfo, Map<String,String> headerAll) throws Exception{
        //预处理
        preBuilder(reqInfo, headerAll);
        //调用builder
        T dataFlowContext = (T)doBuilder(reqInfo, headerAll);
        //后处理
        afterBuilder((DataFlowContext) dataFlowContext);
        return dataFlowContext;
    }
    /**
     * 预处理
     * @param reqInfo
     * @param headerAll
     */
    protected void preBuilder(String reqInfo, Map<String,String> headerAll) {
        super.preBuilder(reqInfo,headerAll);
    }
    /**
     * 构建对象
     * @param reqInfo
     * @param headerAll
     * @return
     * @throws Exception
     */
    public abstract DataFlowContext doBuilder(String reqInfo, Map<String,String> headerAll) throws Exception;
    protected void afterBuilder(DataFlowContext dataFlowContext){
    }
    public void setTransactionId(String transactionId) {
        this.transactionId = transactionId;
@@ -152,8 +192,20 @@
        this.endDate = endDate;
    }
    public Map<String, String> getHeaders() {
        return headers;
    public Map<String, String> getRequestHeaders() {
        return requestHeaders;
    }
    public Map<String, String> getResponseHeaders() {
        return responseHeaders;
    }
    public Map<String, String> getRequestCurrentHeaders() {
        return requestHeaders;
    }
    public Map<String, String> getResponseCurrentHeaders() {
        return responseHeaders;
    }
    public String getReqData() {
@@ -219,6 +271,16 @@
    public String getUserId(){return null;};
    @Override
    public void setAppId(String appId) {
    }
    @Override
    public void setUserId(String userId) {
    }
    public String getRemark(){return null;};
    public String getReqSign(){return null;};
@@ -257,9 +319,43 @@
    }
    public void setPort(String port) {
        this.port = port;
    }
    public String getbId(){
        return null;
    }
    public String getLogId(){
        return getbId();
    }
    /**
     * 业务编码 当前需要处理的业务编码,可以写将要请求服务提供方的方法名
     * 主要用于 日志端展示
     * @return 当前服务编码
     */
    public String getServiceCode(){
        if(this.currentBusiness != null){
            return currentBusiness.getServiceCode();
        }
        return "";
    }
    /**
     * 业务名称 当前需要处理的业务名称,可以当前调用的业务名称 如 商品购买 等
     * 主要用于 日志端展示
     * @return 当前服务名称
     */
    public String getServiceName(){
        if(this.currentBusiness != null){
            return currentBusiness.getServiceName();
        }
        return "";
    }
    public abstract Orders getOrder();
@@ -269,4 +365,12 @@
    }
    public void setResponseEntity(ResponseEntity responseEntity){
    }
    public ResponseEntity getResponseEntity(){
        return null;
    }
}