java110
2021-08-05 bd199ec0fa775f8ec6fbbad0c8ad082394d595db
java110-core/src/main/java/com/java110/core/context/AbstractDataFlowContext.java
old mode 100644 new mode 100755
@@ -5,6 +5,7 @@
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.util.*;
@@ -12,7 +13,7 @@
 * 数据流上下文
 * Created by wuxw on 2018/5/18.
 */
public abstract class AbstractDataFlowContext implements DataFlowContext,Orders{
public abstract class AbstractDataFlowContext extends AbstractTransactionLog implements DataFlowContext, IOrders, TransactionLog {
    private String dataFlowId;
@@ -30,14 +31,20 @@
    private JSONArray resBusiness;
    private JSONArray serviceBusiness;
    private String code;
    private String message;
    private String reqData;
    private JSONObject reqJson;
    private JSONObject resJson;
    private String resData;
    protected List<Business> businesses;
@@ -47,7 +54,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;
@@ -57,12 +67,46 @@
    /**
     * 构建 对象信息
     *
     * @param reqInfo
     * @param headerAll
     * @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;
@@ -148,18 +192,29 @@
        this.endDate = endDate;
    }
    public Map<String, String> getHeaders() {
        return headers;
    public Map<String, String> getRequestHeaders() {
        return requestHeaders;
    }
    public JSONObject getReqJson() {
        return reqJson;
    public Map<String, String> getResponseHeaders() {
        return responseHeaders;
    }
    public void setReqJson(JSONObject reqJson) {
        this.reqJson = reqJson;
    public Map<String, String> getRequestCurrentHeaders() {
        return requestHeaders;
    }
    public Map<String, String> getResponseCurrentHeaders() {
        return responseHeaders;
    }
    public String getReqData() {
        return reqData;
    }
    public void setReqData(String reqData) {
        this.reqData = reqData;
    }
    public JSONObject getResJson() {
        return resJson;
@@ -167,6 +222,7 @@
    public void setResJson(JSONObject resJson) {
        this.resJson = resJson;
        this.setResData(resJson.toJSONString());
    }
    public List<DataFlowLinksCost> getLinksCostDates() {
@@ -174,7 +230,7 @@
    }
    public List<DataFlowLog> getLogDatas(){
    public List<DataFlowLog> getLogDatas() {
        return logDatas;
    }
@@ -196,30 +252,60 @@
    /**
     * 添加各个环节的日志
     *
     * @param dataFlowLog
     */
    public void addLogDatas(DataFlowLog dataFlowLog){
    public void addLogDatas(DataFlowLog dataFlowLog) {
        this.logDatas.add(dataFlowLog);
    }
    /**
     * 添加各个环节的耗时
     *
     * @param dataFlowLinksCost
     */
    public void addLinksCostDates(DataFlowLinksCost dataFlowLinksCost){
    public void addLinksCostDates(DataFlowLinksCost dataFlowLinksCost) {
        this.linksCostDates.add(dataFlowLinksCost);
    }
    public String getAppId(){return null;}
    public String getAppId() {
        return null;
    }
    public String getUserId(){return null;};
    public String getUserId() {
        return null;
    }
    public String getRemark(){return null;};
    ;
    public String getReqSign(){return null;};
    @Override
    public void setAppId(String appId) {
    public JSONArray getAttrs(){return null;};
    }
    @Override
    public void setUserId(String userId) {
    }
    public String getRemark() {
        return null;
    }
    ;
    public String getReqSign() {
        return null;
    }
    ;
    public JSONArray getAttrs() {
        return null;
    }
    ;
    public String getBusinessType() {
        return businessType;
@@ -233,20 +319,94 @@
        return null;
    }
    public void addParamOut(String key,Object value) {
    public String getResData() {
        return resData;
    }
    public void setResData(String resData) {
        this.resData = resData;
    }
    public JSONObject getReqJson() {
        return reqJson;
    }
    public void setReqJson(JSONObject reqJson) {
        this.reqJson = reqJson;
    }
    public void addParamOut(String key, Object value) {
    }
    public String getbId(){
    public void setPort(String port) {
        this.port = port;
    }
    public String getbId() {
        return null;
    }
    public abstract Orders getOrder();
    public String getLogId() {
        return getbId();
    }
    protected AbstractDataFlowContext(Date startDate, String code){
    /**
     * 业务编码 当前需要处理的业务编码,可以写将要请求服务提供方的方法名
     * 主要用于 日志端展示
     *
     * @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 IOrders getOrder();
    protected AbstractDataFlowContext(Date startDate, String code) {
        this.setStartDate(startDate);
        this.setCode(code);
    }
    public void setResponseEntity(ResponseEntity responseEntity) {
    }
    public ResponseEntity getResponseEntity() {
        return null;
    }
    public JSONArray getServiceBusiness() {
        return serviceBusiness;
    }
    public void addServiceBusiness(JSONObject serviceBusiness) {
        if (this.serviceBusiness == null) {
            this.serviceBusiness = new JSONArray();
        }
        this.serviceBusiness.add(serviceBusiness);
    }
    public void setServiceBusiness(JSONArray serviceBusinesses) {
        this.serviceBusiness = serviceBusinesses;
    }
}