diff --git a/AF-Demo/src/af/control/StateManager.java b/AF-Demo/src/af/control/StateManager.java index 95ffc2d..a9163f7 100644 --- a/AF-Demo/src/af/control/StateManager.java +++ b/AF-Demo/src/af/control/StateManager.java @@ -4,6 +4,7 @@ import af.interfaces.AFState; import af.state.StateIdle; import af.state.StateWaitE01; import af.state.StateWaitA; +import af.state.StateWaitB; import ec02.af.abstracts.AbstractAFStateManager; public class StateManager extends AbstractAFStateManager { @@ -18,5 +19,9 @@ public class StateManager extends AbstractAFStateManager { else if (state.equals(AFState.W_ARes)) { this.afState = new StateWaitA(); } + + else if (state.equals(AFState.W_BRes)) { + this.afState = new StateWaitB(); + } } } diff --git a/AF-Demo/src/af/interfaces/AFState.java b/AF-Demo/src/af/interfaces/AFState.java index 63f5cca..1124916 100644 --- a/AF-Demo/src/af/interfaces/AFState.java +++ b/AF-Demo/src/af/interfaces/AFState.java @@ -2,6 +2,8 @@ package af.interfaces; public interface AFState { public String IDLE = "IDLE"; + public String END = "END"; public String W_E01Res = "W_DBRes"; public String W_ARes = "W_ARes"; + public String W_BRes = "W_BRes"; } diff --git a/AF-Demo/src/af/state/StateIdle.java b/AF-Demo/src/af/state/StateIdle.java index cc0ac4e..2baa590 100644 --- a/AF-Demo/src/af/state/StateIdle.java +++ b/AF-Demo/src/af/state/StateIdle.java @@ -4,6 +4,7 @@ import java.util.ArrayList; import af.instatnce.E01Instance; import af.instatnce.EC02Instance; +import af.instatnce.EQXRawInstance; import af.interfaces.AFEvent; import af.interfaces.AFState; import af.interfaces.EQXMsg; @@ -30,7 +31,7 @@ public class StateIdle implements IAFState { ec02Ins.getAFInstance().setInvoke(eqxRawData.getInvoke()); ec02Ins.getAFInstance().setOrig(eqxRawData.getRawDataAttribute(EQXMsg.ORIG)); - if(eqxRawData.getRawEventType().equals(AFEvent.Incoming_HTTP_Request)){ + /*if(eqxRawData.getRawEventType().equals(AFEvent.Incoming_HTTP_Request)){ E01Instance e01Ins = new E01Instance(); ArrayList keys = new ArrayList(); keys.add(eqxRawData.getRawDataMessage()); @@ -49,8 +50,21 @@ public class StateIdle implements IAFState { abstractAF.getUtils().incrementStats("my_stat"); abstractAF.getUtils().incrementStats("raise_by_stat"); abstractAF.getUtils().raiseAlarm("my_alarm", parameter, AlarmSeverity.WARNING, AlarmCategory.APPLICATION, AlarmType.Normal); - this.eqxState = AFState.W_E01Res; - } + this.eqxState = AFState.W_E01Res;*/ + + ArrayList eqxRawList = new ArrayList(); + EQXRawInstance eqxRaw = new EQXRawInstance(); + eqxRaw.setMessage("B Req."); + eqxRaw.setTo(abstractAF.getUtils().getHmWarmConfig().get("Resource-Name-B").get(0)); + eqxRaw.setCtype(EQXMsg.TEXTXML); + eqxRawList.add(eqxRaw); + ArrayList rawList = this.ec02Builder.getHTTPRequest(eqxRawList); + for (int i = 0; i < rawList.size(); i++) { + this.eqxRawDataList.add(rawList.get(i)); + } + this.eqxState = AFState.W_ARes; + + /*}*/ } ec02Ins.setEqxRawDataList(this.eqxRawDataList); return this.eqxState; diff --git a/AF-Demo/src/af/state/StateWaitA.java b/AF-Demo/src/af/state/StateWaitA.java index 2a069e8..e4bd51f 100644 --- a/AF-Demo/src/af/state/StateWaitA.java +++ b/AF-Demo/src/af/state/StateWaitA.java @@ -25,7 +25,7 @@ public class StateWaitA implements IAFState { for(EquinoxRawData eqxRawData : eqxRawDataList) { this.ec02Builder.setEquinoxRawData(eqxRawData, abstractAF, ec02Ins); - if(eqxRawData.getRawEventType().equals(AFEvent.Incoming_A_Response)){ + /*if(eqxRawData.getRawEventType().equals(AFEvent.Incoming_A_Response)){ StringExtract str = new StringExtract(); HashMap map = str.getAll(str.setMessage(eqxRawData.getRawDataMessage().trim())); String message = map.get("MSG[0].value"); @@ -40,7 +40,20 @@ public class StateWaitA implements IAFState { else { } - } + }*/ + + ArrayList eqxRawList = new ArrayList(); + EQXRawInstance eqxRaw = new EQXRawInstance(); + eqxRaw.setMessage("B Req."); + eqxRaw.setTo(abstractAF.getUtils().getHmWarmConfig().get("Resource-Name-B").get(0)); + eqxRaw.setCtype(EQXMsg.TEXTXML); + eqxRawList.add(eqxRaw); + ArrayList rawList = this.ec02Builder.getHTTPRequest(eqxRawList); + for (int i = 0; i < rawList.size(); i++) { + this.eqxRawDataList.add(rawList.get(i)); + } + this.eqxState = AFState.W_BRes; + } ec02Ins.setEqxRawDataList(this.eqxRawDataList); return this.eqxState; diff --git a/AF-Demo/src/af/state/StateWaitB.java b/AF-Demo/src/af/state/StateWaitB.java new file mode 100644 index 0000000..921f85e --- /dev/null +++ b/AF-Demo/src/af/state/StateWaitB.java @@ -0,0 +1,56 @@ +package af.state; + +import java.util.ArrayList; +import java.util.HashMap; + +import th.co.ais.equinox.utils.StringExtract; +import af.instatnce.EC02Instance; +import af.instatnce.EQXRawInstance; +import af.interfaces.AFEvent; +import af.interfaces.AFState; +import af.interfaces.EQXMsg; +import af.message.EC02Builder; +import ec02.af.abstracts.AbstractAF; +import ec02.af.data.EquinoxRawData; +import ec02.af.interfaces.IAFState; + +public class StateWaitB implements IAFState { + private String eqxState = null; + private EC02Builder ec02Builder = new EC02Builder(); + private ArrayList eqxRawDataList = new ArrayList(); + + @Override + public String doAction(AbstractAF abstractAF, Object instance, ArrayList eqxRawDataList) { + EC02Instance ec02Ins = (EC02Instance)instance; + + for(EquinoxRawData eqxRawData : eqxRawDataList) { + this.ec02Builder.setEquinoxRawData(eqxRawData, abstractAF, ec02Ins); + /*if(eqxRawData.getRawEventType().equals(AFEvent.Incoming_A_Response)){ + StringExtract str = new StringExtract(); + HashMap map = str.getAll(str.setMessage(eqxRawData.getRawDataMessage().trim())); + String message = map.get("MSG[0].value"); + if (message.trim().equals("SUCCESS")) { + EQXRawInstance eqxRaw = new EQXRawInstance(); + eqxRaw.setMessage(message.trim()); + eqxRaw.setTo(ec02Ins.getAFInstance().getOrig()); + eqxRaw.setCtype(EQXMsg.TEXTPLAIN); + this.eqxRawDataList.add(this.ec02Builder.getHTTPResponse(eqxRaw)); + this.eqxState = AFState.IDLE; + } + else { + + } + }*/ + + EQXRawInstance eqxRaw = new EQXRawInstance(); + eqxRaw.setMessage("A Res."); + eqxRaw.setTo(ec02Ins.getAFInstance().getOrig()); + eqxRaw.setCtype(EQXMsg.TEXTPLAIN); + this.eqxRawDataList.add(this.ec02Builder.getHTTPResponse(eqxRaw)); + this.eqxState = AFState.END; + + } + ec02Ins.setEqxRawDataList(this.eqxRawDataList); + return this.eqxState; + } +} -- libgit2 0.21.2