package eo.service;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import javax.annotation.Resource;
import javax.jws.WebService;
import javax.xml.ws.Holder;
import javax.xml.ws.WebServiceContext;
import com.fujitsu.futurity.bp.controller.ws.BPMController;
import com.fujitsu.futurity.bp.controller.ws.data.RequestData;
import com.fujitsu.futurity.bp.controller.ws.data.ResponseData;
import com.fujitsu.futurity.bp.controller.ws.exception.BPMControllerException;
import com.fujitsu.futurity.bp.controller.ws.exception.BusinessException;
import com.fujitsu.futurity.bp.controller.ws.exception.IllegalReflectionException;
import com.fujitsu.futurity.bp.controller.ws.helper.RequestBuildHelper;
import com.fujitsu.futurity.bp.controller.ws.helper.ResponseBuildHelper;
import com.fujitsu.futurity.bp.controller.ws.util.TimeFormatter;
import eo.service.client.chife527.CHSV008201SCType;
import eo.service.client.chife527.CHIFE527PortType;
import eo.service.client.chife527.FuncCode;
import eo.service.client.chife527.SvcKeiNo;
import eo.service.client.chife527.PayJokyo;
import eo.service.client.chife527.InitType;
import eo.service.client.chife527.InitResponseType;
import eo.service.client.chife527.ServiceIf;



@WebService(targetNamespace = "http://client.service.eo/CHIFE527 /",
		endpointInterface="eo.service.client.chife527.CHIFE527PortType")
public class CHIFE527 implements CHIFE527PortType { 

		 @Resource 
		private WebServiceContext context; 

		 @Override 
		
 public void init(Holder<String> requestIDPart, 
			 Holder<String> serviceIDPart, 
			 Holder<String> channelPart, 
			 Holder<String> viewIDPart, 
			 Holder<String> operatorIDPart, 
			 Holder<String> ipAddressPart,   
			 Holder<String> operateDatetimePart,
			 InitType initRequest,
			 Holder<String> errorLevelPart,
			 Holder<String> returnCodePart,
			 Holder<String> returnMessagePart,
			 Holder<InitResponseType> initResponse) {

		 try {
			 // サービスを呼び出した日時を設定
			 operateDatetimePart.value = TimeFormatter.format(System

				     .currentTimeMillis()); 

			 RequestData requestData = new RequestData();
			 requestData.setRequestID(requestIDPart.value); 
			 requestData.setServiceID(serviceIDPart.value);
			 requestData.setChannel(channelPart.value);
			 requestData.setViewID(viewIDPart.value);
			 requestData.setOperatorID(operatorIDPart.value);
			 requestData.setIpAddress(ipAddressPart.value);
			 requestData.setOperateDatetime(operateDatetimePart.value);

			 // ユーザデータ作成
			LinkedHashMap<Object, Object> userData = this.createUserData(initRequest);
			requestData.getUserData().putAll(userData);

			BPMController controller = new BPMController();;
			ResponseData responseData = controller.run(context, requestData);

			userData = responseData.getUserData();

			ipAddressPart.value = responseData.getIpAddress();
			 // errorLevelの先頭が9の場合、エラーを設定

		if (responseData.getErrorLevel().startsWith("9")) {

			errorLevelPart.value = "988";
			returnCodePart.value = "9000";
			returnMessagePart.value = "システムエラー";
			initResponse.value = null;

		 } else {

			errorLevelPart.value = responseData.getErrorLevel();
			returnCodePart.value = responseData.getReturnCode();
			returnMessagePart.value = responseData.getReturnMessage();
			initResponse.value = this.createResponseBean(userData);

			}

		 } catch (BPMControllerException e) {

			errorLevelPart.value = "988";
			returnCodePart.value = "9000";
			returnMessagePart.value = "システムエラー";
			e.printStackTrace();
			initResponse.value = null;

		 } catch (IllegalReflectionException e) {

			errorLevelPart.value = "988";
			returnCodePart.value = "9000";
			returnMessagePart.value = "システムエラー";
			e.printStackTrace();
			initResponse.value = null;

		 } catch (BusinessException e) {

			errorLevelPart.value = "888";
			returnCodePart.value = "9000";
			returnMessagePart.value = "業務エラー";
			e.printStackTrace();
			initResponse.value = null;

			}
		}



private LinkedHashMap<Object, Object> createUserData(InitType initRequest) 
			 throws BusinessException, IllegalReflectionException { 

			LinkedHashMap<Object, Object> userData = new LinkedHashMap<Object, Object>(); 

			CHSV008201SCType reqchsv008201sc = initRequest.getCHSV008201SC(); 

		if(reqchsv008201sc == null){

			return userData;
		}

			ServiceIf serviceIf = reqchsv008201sc.getServiceIf();

			Map<Object, Object> serviceIfMap = new LinkedHashMap<Object, Object>();

			userData.put("CHSV008201SC", serviceIfMap);

		if(serviceIf == null){

			return userData;
		}
			serviceIfMap.put("func_code", RequestBuildHelper.getValue(serviceIf.getFuncCode()));
			serviceIfMap.put("svc_kei_no", RequestBuildHelper.getValue(serviceIf.getSvcKeiNo()));

			return userData;
		}



@SuppressWarnings("unchecked") 
		private InitResponseType createResponseBean(LinkedHashMap<Object, Object> userData) 

			     throws BusinessException, IllegalReflectionException { 

			InitResponseType initResponse = new InitResponseType(); 
			Object obj = userData.get("CHSV008201SC"); 

		if(obj == null) {

			return initResponse;
		}

			HashMap<Object, Object> chsv008201scMap = (HashMap<Object, Object>) obj;

			CHSV008201SCType resCHSV008201SC = new CHSV008201SCType();
			resCHSV008201SC.setType("service_if");

			ServiceIf serviceIf = new ServiceIf();
			serviceIf.setFuncCode(ResponseBuildHelper.createObject(chsv008201scMap, FuncCode.class, "func_code"));
			serviceIf.setSvcKeiNo(ResponseBuildHelper.createObject(chsv008201scMap, SvcKeiNo.class, "svc_kei_no"));
			serviceIf.setPayJokyo(ResponseBuildHelper.createObject(chsv008201scMap, PayJokyo.class, "pay_jokyo"));
			resCHSV008201SC.setServiceIf(serviceIf);
			initResponse.setCHSV008201SC(resCHSV008201SC);

			return initResponse;
		}
	}