/*********************************************************************
* All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*   システム名      ：eo顧客基幹システム
*	モジュール名	：CCSV0008_CCSV0008OPDBMapper
*	ソースファイル名：CCSV0008_CCSV0008OPDBMapper.java
*	作成者			：FJ
*	日付			：2012年04月10日
*＜機能概要＞
*	BP（アクセスログ出力）へのＤ−Ｂマッピングクラスです。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/04/10	FJ		新規作成
*	v24.00.00	2016/02/24	FJ)中原		ANK-2680-00-00_eoアクセスログ収集対応
*
**********************************************************************/
package eo.web.webview.mapping;

import java.util.ArrayList;
import java.util.HashMap;

import com.fujitsu.futurity.common.JCMAccessLogEventCache;
import com.fujitsu.futurity.web.x31.X31CWebConst;
import com.fujitsu.futurity.web.x31.X31SDataBeanAccess;
import com.fujitsu.futurity.web.x31.X31SDataBeanAccessArray;

/**
 * DataBean-BPマッピングをする。
 * 
 */
public class CCSV0008_CCSV0008OPDBMapper {
	
	/**
	 * コンストラクタ
	 */
	public CCSV0008_CCSV0008OPDBMapper(){
	}
	

	/**
	 * 上りマッピングをする
	 * @param bean　[0]：アクセスログ出力
	 * @param outputMap
	 * @param func_code　機能コード
	 */
	@SuppressWarnings("unchecked")
	// 2016/02/24 ANK-2680-00-00 MOD START
	//public HashMap setCCSV000801SC(X31SDataBeanAccess[] bean, HashMap outputMap, String func_code) {
	public HashMap setCCSV000801SC(X31SDataBeanAccess[] bean, HashMap outputMap, String func_code, String fileName, String gamenID) {
	// 2016/02/24 ANK-2680-00-00 MOD END
		
		if(bean == null){
			return null;
		}
		
		if(bean.length != 1){
			return null;
		}


		HashMap<String, Object> parentMap = new HashMap<String, Object>();

		// 共通情報のマッピング
		parentMap.put("func_code", func_code);

		// 操作区分 → アクセスログ出力マップ.操作区分
		// 2016/02/24 ANK-2680-00-00 ADD START
		//parentMap.put("sosa_div", bean[0].sendMessageString("操作区分", X31CWebConst.DATABEAN_GET_VALUE));
		String sosaDiv = null;
		String[] splt1 = null;
		String[] splt2 = null;
		try {
			try {
				sosaDiv = JCMAccessLogEventCache.getValue(gamenID);
				if(null == sosaDiv || 0 == sosaDiv.length())
				{
					return null;
				}
				// sosaDivの設定値を分割して画面名とボタン名と操作区分を取得する
				splt1 = sosaDiv.split(":");
				splt2 = splt1[0].split(";");
				
				// 操作区分を再設定
				sosaDiv = splt1[1];
			}
			catch (Throwable e)
			{
				throw new Exception("プロパティファイル読込み時に例外が発生しました", e);
			}
		}
		catch (Throwable e)
		{
			e.printStackTrace();
			throw new RuntimeException(e);
		}

		parentMap.put("sosa_div", splt2[0] + ";" + fileName + ":" + sosaDiv);
		// 2016/02/24 ANK-2680-00-00 ADD END

		outputMap.put("CCSV000801SC", parentMap);
						
		return outputMap;
	}


	/**
	 * 下りマッピング
	 * @param bean　[0]：アクセスログ出力
	 * @param outputMap
	 */
	@SuppressWarnings("unchecked")
	public X31SDataBeanAccess[] getCCSV000801SC(X31SDataBeanAccess[] bean, HashMap outputMap){

		HashMap parentMap = null;
		if(outputMap.containsKey("CCSV000801SC")){
			parentMap = (HashMap)outputMap.get("CCSV000801SC");
		}

		
		// アクセスログ出力定義エラーフラグ ← アクセスログ出力マップ.アクセスログ出力定義エラーフラグ
		bean[0].sendMessageString("アクセスログ出力定義エラーフラグ", X31CWebConst.DATABEAN_SET_VALUE, (String)parentMap.get("err_teigi"));
		// アクセスログ出力有無 ← アクセスログ出力マップ.アクセスログ出力有無
		bean[0].sendMessageString("アクセスログ出力有無", X31CWebConst.DATABEAN_SET_VALUE, (String)parentMap.get("um_access_log"));
		// ログ出力実行エラーフラグ ← アクセスログ出力マップ.ログ出力実行エラーフラグ
		bean[0].sendMessageString("ログ出力実行エラーフラグ", X31CWebConst.DATABEAN_SET_VALUE, (String)parentMap.get("err_log_output"));

		return bean;
	}


}