/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*   モジュール名    ：FUIFE168
*   ソースファイル名：FUIFE168.java
*   作成者          ：富士通
*   日付            ：2019/11/1
*＜機能概要＞
*   外部I/F：「アカウント認証(営業支援)(FUIFE168)」受付処理クラスです。
*＜修正履歴＞
*   バージョン  修正日       修正者      修正内容
*   v46.00.00   2019/11/1   FJ)西川     ANK-3766-00-00_営業チャネルでの既契約者対応
**********************************************************************/
package local.gyomu.api;
import java.util.List;
import java.util.Map;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.Response;

import local.gyomu.ApiServerLocalBase;
import local.gyomu.api.common.ApiBpInterface;

import com.k_opti.api_parts.server.bean.ApiServerPartsBean;
import com.k_opti.api_parts.server.exception.ApiServerExceptionGyomuErr;

/**
 * 外部I/F：「アカウント認証(営業支援)(FUIFE168)」受付処理クラスです。<br>
 */
@Path("FUIFE168")
public class FUIFE168 extends ApiServerLocalBase {

	/**
	 * APIID
	 */
    private static final String APIID = "FUIFE168";

    /**
     * 呼び出す業務サービスID
     */
    private static final String SERVICE_ID = "FUSV0333";
    
    /**
     * 相手先システムID
     */
    private static final String SYSTEM_ID = "ESS1";
    
    /**
     * JOBID
     */
    private static final String JOB_ID = "FUIFE168";
    
    
    /**
     * 公開メソッド
     *
     * @pram pRequest リクエスト
     * @pram pContext コンテキスト
     * @return Response レスポンス
     * @throws Exception
     */
    @POST
    public Response execute(@Context final HttpServletRequest pRequest,
    		@Context final ServletContext pContext) throws Exception {

        /************************************************************
         * ■■■基盤ロジック呼出■■■■■■■■■■■■■■■■■
         ***********************************************************/
        // API共通部品呼出
        Response response = super.exec(APIID, pRequest, pContext);

        return response;
    }

    /**
     * 業務ロジック処理
     *
     * @param reqPartsBean サーバ業務AP連携データ(リクエスト)
     * @return ApiServerPartsBean サーバ業務AP連携データ(レスポンス)
     * @throws Exception
     */
    @Override
    protected ApiServerPartsBean run(ApiServerPartsBean reqPartsBean) throws Exception {
        
        // レスポンスデータ生成
        ApiServerPartsBean resPartsBean
            = this.logicExecute(reqPartsBean);

        /************************************************************
         * ■■■基盤ロジック呼出■■■■■■■■■■■■■■■■■
         ***********************************************************/
        return resPartsBean;
    }

    /**
     * 業務ロジックメイン処理
     * 指定されたサービスを呼び出し、結果をレスポンス情報に設定します。
     *
     * @param reqPartsBean サーバ業務AP連携データ(リクエスト)
     * @return ApiServerPartsBean サーバ業務AP連携データ(レスポンス)
     * @throws Exception
     */
    private ApiServerPartsBean logicExecute(ApiServerPartsBean reqPartsBean) throws Exception {

		// サービス呼び出し
		String serviceId = SERVICE_ID;
		Map<String, Object> outMap = callBpService(serviceId, reqPartsBean, JOB_ID, SYSTEM_ID);

		// サービス処理の結果
		Map<String, Object> resultMap = (Map<String, Object>)outMap.get(serviceId + _01CC);

		// 業務データMapからエラー情報を取得する。
		Object errInfo = resultMap.get(ApiBpInterface.ERROR_INFO);

		if (errInfo != null && errInfo instanceof List<?>)
		{
			List<Object> errList = (List<Object>)errInfo;

			// reqPartsBeanにそのまま設定する
			reqPartsBean.setErrList(errList);

			// 業務データMapからエラー情報を削除する
			resultMap.remove(ApiBpInterface.ERROR_INFO);

			// レスポンス情報をセット
			reqPartsBean.setBody(resultMap);

			throw new ApiServerExceptionGyomuErr(reqPartsBean);
		}

		// レスポンス情報をセット
		ApiServerPartsBean resPartsBean = new ApiServerPartsBean();
		resPartsBean.setBody(resultMap);

		return resPartsBean;
	}

}
