<?php
/*
 * Copyright(c) 2000-2006 LOCKON CO.,LTD. All Rights Reserved.
 *
 * http://www.lockon.co.jp/
 */

/*----------------------------------------------------------------------
 * [名称] SC_CheckError
 * [概要] エラーチェッククラス
 *----------------------------------------------------------------------
 */
class SC_CheckError {
	var $arrErr;
	var $arrParam;
	
	// チェック対象の値が含まれる配列をセットする。
	function SC_CheckError($array = "") {
		if($array != "") {
			$this->arrParam = $array;
		} else {
			$this->arrParam = $_POST;
		}

	}
	
	function doFunc($value, $arrFunc) {
		foreach ( $arrFunc as $key ) {
			$this->$key($value);
		}
	}
	
	/* HTMLのタグをチェックする */
	// value[0] = 項目名 value[1] = 判定対象 value[2] = 許可するタグが格納された配列
	function HTML_TAG_CHECK($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		
		// 含まれているタグを抽出する
		preg_match_all("/<([\/]?[a-z]+)/", $this->arrParam[$value[1]], $arrTag);

		foreach($arrTag[1] as $val) {
			$find = false;
			
			foreach($value[2] as $tag) {
				if(eregi("^" . $tag . "$", $val)) {
					$find = true;
				} else {
				}
			}
			
			if(!$find) {
				$this->arrErr[$value[1]] = "※ " . $value[0] . "に許可されていないタグ[" . strtoupper($val) . "]が含まれています。<br />";
				return;
			}		
		}		
	}

	/*　必須入力の判定　*/
	// value[0] = 項目名 value[1] = 判定対象
	function EXIST_CHECK( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($this->arrParam[$value[1]]) == 0 ){					
			$this->arrErr[$value[1]] = "※ " . $value[0] . "が入力されていません。<br />";
		}
	}
	
	/*　スペース、タブの判定　*/
	// value[0] = 項目名 value[1] = 判定対象
	function SPTAB_CHECK( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) != 0 && ereg("^[ 　\t\r\n]+$", $this->arrParam[$value[1]])){						
			$this->arrErr[$value[1]] = "※ " . $value[0] . "にスペース、タブ、改行のみの入力はできません。<br />";
		}
	}
	
	/*　スペース、タブの判定　*/
	// value[0] = 項目名 value[1] = 判定対象
	function NO_SPTAB( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) != 0 && mb_ereg("[　 \t\r\n]+", $this->arrParam[$value[1]])){						
			$this->arrErr[$value[1]] = "※ " . $value[0] . "にスペース、タブ、改行は含めないで下さい。<br />";
		}
	}
	
	/* ゼロで開始されている数値の判定 */
	function ZERO_START($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) != 0 && ereg("^[0]+[0-9]+$", $this->arrParam[$value[1]])){						
			$this->arrErr[$value[1]] = "※ " . $value[0] . "に0で始まる数値が入力されています。<br />";
		}
	}
	
	/*　必須選択の判定　*/
	// value[0] = 項目名 value[1] = 判定対象 
	function SELECT_CHECK( $value ) {			// プルダウンなどで選択されていない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($this->arrParam[$value[1]]) == 0 ){						
			$this->arrErr[$value[1]] = "※ " . $value[0] . "が選択されていません。<br />";
		}
	}

	/*　同一性の判定　*/
	// value[0] = 項目名1 value[1] = 項目名2 value[2] = 判定対象文字列1  value[3] = 判定対象文字列2
	function EQUAL_CHECK( $value ) {		// 入力が指定文字数以上ならエラーを返す
		if(isset($this->arrErr[$value[2]]) || isset($this->arrErr[$value[3]])) {
			return;
		}
		// 文字数の取得			
		if( $this->arrParam[$value[2]] != $this->arrParam[$value[3]]) {
			$this->arrErr[$value[2]] = "※ " . $value[0] . "と" . $value[1] . "が一致しません。<br />";
		}
	}
	
	/*　値が異なることの判定　*/
	// value[0] = 項目名1 value[1] = 項目名2 value[2] = 判定対象文字列1  value[3] = 判定対象文字列2
	function DIFFERENT_CHECK( $value ) {		// 入力が指定文字数以上ならエラーを返す
		if(isset($this->arrErr[$value[2]]) || isset($this->arrErr[$value[3]])) {
			return;
		}
		// 文字数の取得			
		if( $this->arrParam[$value[2]] == $this->arrParam[$value[3]]) {
			$this->arrErr[$value[2]] = "※ " . $value[0] . "と" . $value[1] . "は、同じ値を使用できません。<br />";
		}
	}
	
	/*　値の大きさを比較する value[2] < value[3]でなければエラー　*/
	// value[0] = 項目名1 value[1] = 項目名2 value[2] = 判定対象文字列1  value[3] = 判定対象文字列2
	function GREATER_CHECK($value) {		// 入力が指定文字数以上ならエラーを返す
		if(isset($this->arrErr[$value[2]]) || isset($this->arrErr[$value[3]])) {
			return;
		}
		// 文字数の取得			
		if($this->arrParam[$value[2]] != "" && $this->arrParam[$value[3]] != "" && ($this->arrParam[$value[2]] > $this->arrParam[$value[3]])) {
			$this->arrErr[$value[2]] = "※ " . $value[0] . "は" . $value[1] . "より大きい値を入力できません。<br />";
		}
	}
	
	
	/*　最大文字数制限の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列  value[2] = 最大文字数(半角も全角も1文字として数える)
	function MAX_LENGTH_CHECK( $value ) {		// 入力が指定文字数以上ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		// 文字数の取得			
		if( mb_strlen($this->arrParam[$value[1]]) > $value[2] ) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は" . $value[2] . "字以下で入力してください。<br />";
		}
	}
	
	/*　最小文字数制限の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 value[2] = 最小文字数(半角も全角も1文字として数える)
	function MIN_LENGTH_CHECK( $value ) {		// 入力が指定文字数未満ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}										
		// 文字数の取得		
		if( mb_strlen($this->arrParam[$value[1]]) < $value[2] ) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は" . $value[2] . "字以上で入力してください。<br />";
		}
	}
	
	/*　最大文字数制限の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列  value[2] = 最大数
	function MAX_CHECK( $value ) {		// 入力が最大数以上ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		// 文字数の取得			
		if($this->arrParam[$value[1]] > $value[2] ) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は" . $value[2] . "以下で入力してください。<br />";
		}
	}
	
		
	/*　数字の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 
	function NUM_CHECK( $value ) {				// 入力文字が数字以外ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($this->arrParam[$value[1]]) > 0 && !EregI("^[[:digit:]]+$", $this->arrParam[$value[1]])) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は数字で入力してください。<br />";	
		}
	}
	
		/*　小数点を含む数字の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 
	function NUM_POINT_CHECK( $value ) {				// 入力文字が数字以外ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($this->arrParam[$value[1]]) > 0 && !EregI("^[[:digit:]]+[\.]?[[:digit:]]+$", $this->arrParam[$value[1]])) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は数字で入力してください。<br />";	
		}
	}
		
	function ALPHA_CHECK($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($this->arrParam[$value[1]]) > 0 && !EregI("^[[:alpha:]]+$", $this->arrParam[$value[1]])) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は半角英字で入力してください。<br />";	
		}
	}
	
	/* 電話番号の判定 （数字チェックと文字数チェックを実施する。)
		value[0] : 項目名
		value[1] : 電番1項目目
		value[2] : 電番2項目目
		value[3] : 電番3項目目
		value[4] : 文字数制限
	*/
	function TEL_CHECK($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		
		$cnt = 0;
		
		for($i = 1; $i <= 3; $i++) {
			if(strlen($this->arrParam[$value[$i]]) > 0) {
				$cnt++;
			}
		}
		
		// すべての項目が満たされていない場合を判定(一部だけ入力されている状態)
		if($cnt > 0 && $cnt < 3) {
			$this->arrErr[$value[1]] .= "※ " . $value[0] . "はすべての項目を入力してください。<br />";
		}
					
		for($i = 1; $i <= 3; $i++) {
			if(strlen($this->arrParam[$value[$i]]) > 0 && strlen($this->arrParam[$value[$i]]) > $value[4]) {
				$this->arrErr[$value[1]] .= "※ " . $value[0] . $i . "は" . $value[4] . "字以内で入力してください。<br />";
			} else if (strlen($this->arrParam[$value[$i]]) > 0 && !EregI("^[[:digit:]]+$", $this->arrParam[$value[$i]])) {
				$this->arrErr[$value[1]] .= "※ " . $value[0] . $i . "は数字で入力してください。<br />";
			}
		}
	}
	
	/* 関連項目が完全に満たされているか判定 
		value[0]		: 項目名
		value[1]		: 判定対象要素名
	*/
	function FULL_EXIST_CHECK($value) {
		$max = count($value);
			
		// 既に該当項目にエラーがある場合は、判定しない。
		for($i = 1; $i < $max; $i++) {
			if(isset($this->arrErr[$value[$i]])) {
				return;
			}
		}
		
		$blank = false;
		
		// すべての項目がブランクでないか、すべての項目が入力されていない場合はエラーとする。
		for($i = 1; $i < $max; $i++) {
			if(strlen($this->arrParam[$value[$i]]) <= 0) {
				$blank = true;
			}
		}
		
		if($blank) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "が入力されていません。<br />";
		}
	}
		
	/* 関連項目がすべて満たされているか判定 
		value[0]		: 項目名
		value[1]		: 判定対象要素名
	*/
	function ALL_EXIST_CHECK($value) {
		$max = count($value);
			
		// 既に該当項目にエラーがある場合は、判定しない。
		for($i = 1; $i < $max; $i++) {
			if(isset($this->arrErr[$value[$i]])) {
				return;
			}
		}
		
		$blank = false;
		$input = false;
		
		// すべての項目がブランクでないか、すべての項目が入力されていない場合はエラーとする。
		for($i = 1; $i < $max; $i++) {
			if(strlen($this->arrParam[$value[$i]]) <= 0) {
				$blank = true;
			} else {
				$input = true;
			}
		}
		
		if($blank && $input) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "はすべての項目を入力して下さい。<br />";
		}
	}
	
		/* 関連項目がどれか一つ満たされているか判定 
		value[0]		: 項目名
		value[1]		: 判定対象要素名
	*/
	function ONE_EXIST_CHECK($value) {
		$max = count($value);
			
		// 既に該当項目にエラーがある場合は、判定しない。
		for($i = 1; $i < $max; $i++) {
			if(isset($this->arrErr[$value[$i]])) {
				return;
			}
		}
		
		$input = false;
		
		// すべての項目がブランクでないか、すべての項目が入力されていない場合はエラーとする。
		for($i = 1; $i < $max; $i++) {
			if(strlen($this->arrParam[$value[$i]]) > 0) {
				$input = true;
			}
		}
		
		if(!$input) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "が入力されていません。<br />";
		}
	}
	
	/* 上位の項目が満たされているか判定
		value[0]		: 項目名
		value[1]		: 判定対象要素名
	*/
	function TOP_EXIST_CHECK($value) {
		$max = count($value);
			
		// 既に該当項目にエラーがある場合は、判定しない。
		for($i = 1; $i < $max; $i++) {
			if(isset($this->arrErr[$value[$i]])) {
				return;
			}
		}
		
		$blank = false;
		$error = false;
				
		// すべての項目がブランクでないか、すべての項目が入力されていない場合はエラーとする。
		for($i = 1; $i < $max; $i++) {
			if(strlen($this->arrParam[$value[$i]]) <= 0) {
				$blank = true;
			} else {
				if($blank) {
					$error = true;
				}
			}
		}
		
		if($error) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は先頭の項目から順番に入力して下さい。<br />";
		}
	}
	
	
	/*　カタカナの判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 
	function KANA_CHECK( $value ) {				// 入力文字がカナ以外ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) > 0 && ! ereg("^(\xA5[\xA1-\xF6]|\xA1\xBC|\xA1\xA6|\xA1\xA1|\x20)+$", $this->arrParam[$value[1]] ) ) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "はカタカナで入力してください。<br />";	
		}
	}

	/*　英数字の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 
	function ALNUM_CHECK( $value ) {				// 入力文字が英数字以外ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}										
		if( strlen($this->arrParam[$value[1]]) > 0 && ! EregI("^[[:alnum:]]+$", $this->arrParam[$value[1]] ) ) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は英数字で入力してください。<br />";	
		}
	}

	/*　必須選択の判定　*/
	// value[0] = 項目名 value[1] = 判定対象
	function ZERO_CHECK( $value ) {				// 入力値で0が許されない場合エラーを返す
		
		if($this->arrParam[$value[1]] == "0" ){						
			$this->arrErr[$value[1]] = "※ " . $value[0] . "は1以上を入力してください。<br />";
		}
	}

	/*　桁数の判定　（最小最大）*/
	// value[0] = 項目名 value[1] = 判定対象文字列 value[2] = 最小桁数 value[3] = 最大桁数
	function NUM_RANGE_CHECK( $value ) {		// 入力文字の桁数判定　→　最小桁数＜入力文字列＜最大桁数
		if(isset($this->arrErr[$value[1]])) {
			return;
		}										 
		// $this->arrParam[$value[0]] = mb_convert_kana($this->arrParam[$value[0]], "n");										
		$count = strlen($this->arrParam[$value[1]]);
		if( ( $count > 0 ) && $value[2] > $count || $value[3] < $count ) {  
			$this->arrErr[$value[1]] =  "※ $value[0]は$value[2]桁〜$value[3]桁で入力して下さい。<br />";
		}
	}

	/*　桁数の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列 value[2] = 桁数 
	function NUM_COUNT_CHECK( $value ) {		// 入力文字の桁数判定　→　入力文字列 = 桁数　以外はNGの場合
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		$count = strlen($this->arrParam[$value[1]]);
		if(($count > 0) && $count != $value[2] ) {  
			$this->arrErr[$value[1]] =  "※ $value[0]は$value[2]桁で入力して下さい。<br />";
		}
	}				
	
	/*　メールアドレス形式の判定　*/
	// value[0] = 項目名 value[1] = 判定対象メールアドレス
	function EMAIL_CHECK( $value ){				//　メールアドレスを正規表現で判定する
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) > 0 && !ereg("^[^@]+@[^.]+\..+", $this->arrParam[$value[1]])) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "の形式が不正です。<br />";
		}
	}		
		
	/*　メールアドレスに使用できる文字の判定　*/
	//  value[0] = 項目名 value[1] = 判定対象メールアドレス
	function EMAIL_CHAR_CHECK( $value ){				//　メールアドレスに使用する文字を正規表現で判定する
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) > 0 && !ereg("^[a-zA-Z0-9_\.@\+\?-]+$",$this->arrParam[$value[1]]) ) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "に使用する文字を正しく入力してください。<br />";
		}
	}		
	
	/*　URL形式の判定　*/
	//  value[0] = 項目名 value[1] = 判定対象URL
	function URL_CHECK( $value ){				//　URLを正規表現で判定する。デフォルトでhttp://があってもOK
	 	if(isset($this->arrErr[$value[1]])) {
			return;
		}										
        if( strlen($this->arrParam[$value[1]]) > 0 && !ereg( "^https?://+($|[a-zA-Z0-9_~=&\?\.\/-])+$", $this->arrParam[$value[1]] ) ) {
            $this->arrErr[$value[1]] = "※ " . $value[0] . "を正しく入力してください。<br />";     
        }
    }
  	    
	/*　拡張子の判定　*/
	// value[0] = 項目名 value[1] = 判定対象 value[2]=array(拡張子)	
	function FILE_EXT_CHECK( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if($_FILES[$value[1]]['name'] != "" ) {										
			$errFlag = 1;
			$array_ext = explode(".", $_FILES[$value[1]]['name']);
			$ext = $array_ext[ count ( $array_ext ) - 1 ];
			$ext = strtolower($ext);
			
			$strExt = "";
			
			foreach ( $value[2] as $checkExt ){
				if ( $ext == $checkExt) {
					$errFlag = 0;
				}
				
				if($strExt == "") {
					$strExt.= $checkExt;
				} else {
					$strExt.= "・$checkExt";
				}
			}
		}
		if ($errFlag == 1) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "で許可されている形式は、" . $strExt . "です。<br />";
		}
	}
	
	/* ファイルが存在するかチェックする */
	// value[0] = 項目名 value[1] = 判定対象  value[2] = 指定ディレクトリ
	function FIND_FILE( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		
		if($value[2] != "") {
			$dir = $value[2];
		} else {
			$dir = IMAGE_SAVE_DIR;
		}
		
		$path = $dir . "/" . $this->arrParam[$value[1]];
		$path = ereg_replace("//", "/", $path);
				
		if($this->arrParam[$value[1]] != "" && !file_exists($path)){
			$this->arrErr[$value[1]] = "※ " . $path . "が見つかりません。<br />";
		}
	}
	
	/*　ファイルが上げられたか確認　*/
	// value[0] = 項目名 value[1] = 判定対象  value[2] = 指定サイズ（KB)
	function FILE_EXIST_CHECK( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}											
		if(!($_FILES[$value[1]]['size'] != "" && $_FILES[$value[1]]['size'] > 0)){
			$this->arrErr[$value[1]] = "※ " . $value[0] . "をアップロードして下さい。<br />";
		}
	}
	
	/*　ファイルサイズの判定　*/
	// value[0] = 項目名 value[1] = 判定対象  value[2] = 指定サイズ（KB)
	function FILE_SIZE_CHECK( $value ) {			// 受け取りがない場合エラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}											
		if( $_FILES[$value[1]]['size'] > $value[2] *  1024 ){
			$byte = "KB";
			if( $value[2] >= 1000 ) {
				$value[2] = $value[2] / 1000; 
				$byte = "MB";
			}
			$this->arrErr[$value[1]] = "※ " . $value[0] . "のファイルサイズは" . $value[2] . $byte . "以下のものを使用してください。<br />";
		}
	}

	/*　ファイル名の判定　*/
	// value[0] = 項目名 value[1] = 判定対象文字列
	function FILE_NAME_CHECK( $value ) {				// 入力文字が英数字,"_","-"以外ならエラーを返す
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if( strlen($_FILES[$value[1]]['name']) > 0 && ! EregI("^[[:alnum:]_\.-]+$", $_FILES[$value[1]]['name']) ) { 
			$this->arrErr[$value[1]] = "※ " . $value[0] . "のファイル名に日本語やスペースは使用しないで下さい。<br />";	
		}
	}
	
	//日付チェック
	// value[0] = 項目名
	// value[1] = YYYY
	// value[2] = MM
	// value[3] = DD
	function CHECK_DATE($value) {						
		if(isset($this->arrErr[$value[1]])) {
			return;
		}										
		// 少なくともどれか一つが入力されている。
		if($this->arrParam[$value[1]] > 0 || $this->arrParam[$value[2]] > 0 || $this->arrParam[$value[3]] > 0) {
			// 年月日のどれかが入力されていない。
			if(!(strlen($this->arrParam[$value[1]]) > 0 && strlen($this->arrParam[$value[2]]) > 0 && strlen($this->arrParam[$value[3]]) > 0)) {
				$this->arrErr[$value[1]] = "※ " . $value[0] . "はすべての項目を入力して下さい。<br />";
			} else if ( ! checkdate($this->arrParam[$value[2]], $this->arrParam[$value[3]], $this->arrParam[$value[1]])) {						
				$this->arrErr[$value[1]] = "※ " . $value[0] . "が正しくありません。<br />";
			}
		}
	}
	
	//日付チェック
	// value[0] = 項目名
	// value[1] = YYYY
	// value[2] = MM
	// value[3] = DD
	// value[4] = HH
	function CHECK_DATE2($value) {						
		if(isset($this->arrErr[$value[1]])) {
			return;
		}										
		// 少なくともどれか一つが入力されている。
		if($this->arrParam[$value[1]] > 0 || $this->arrParam[$value[2]] > 0 || $this->arrParam[$value[3]] > 0 || $this->arrParam[$value[4]] > 0) {
			// 年月日時のどれかが入力されていない。
			if(!(strlen($this->arrParam[$value[1]]) > 0 && strlen($this->arrParam[$value[2]]) > 0 && strlen($this->arrParam[$value[3]]) > 0 && strlen($this->arrParam[$value[4]]) > 0)) {
				$this->arrErr[$value[1]] = "※ " . $value[0] . "はすべての項目を入力して下さい。<br />";
			} else if ( ! checkdate($this->arrParam[$value[2]], $this->arrParam[$value[3]], $this->arrParam[$value[1]])) {						
				$this->arrErr[$value[1]] = "※ " . $value[0] . "が正しくありません。<br />";
			}
		}
	}

	/*-----------------------------------------------------------------*/
	/*	CHECK_SET_TERM
	/*	年月日に別れた2つの期間の妥当性をチェックし、整合性と期間を返す
	/*　引数 (開始年,開始月,開始日,終了年,終了月,終了日)
	/*　戻値 array(１，２，３）
	/*  		１．開始年月日 (YYYYMMDD 000000)
	/*			２．終了年月日 (YYYYMMDD 235959)
	/*			３．エラー ( 0 = OK, 1 = NG )
	/*-----------------------------------------------------------------*/
	// value[0] = 項目名1
	// value[1] = 項目名2
	// value[2] = start_year
	// value[3] = start_month
	// value[4] = start_day
	// value[5] = end_year
	// value[6] = end_month
	// value[7] = end_day
	function CHECK_SET_TERM ($value) {

		// 期間指定
		if(isset($this->arrErr[$value[2]]) || isset($this->arrErr[$value[5]])) {
			return;
		}	
		$error = 0;
		if ( (strlen($this->arrParam[$value[2]]) > 0 || strlen($this->arrParam[$value[3]]) > 0 || strlen($this->arrParam[$value[4]] ) > 0) && ! checkdate($this->arrParam[$value[3]], $this->arrParam[$value[4]], $this->arrParam[$value[2]]) ) {
			$this->arrErr[$value[2]] = "※ " . $value[0] . "を正しく指定してください。<br />";
		}
		if ( (strlen($this->arrParam[$value[5]]) > 0 || strlen($this->arrParam[$value[6]]) > 0 || strlen($this->arrParam[$value[7]] ) > 0) && ! checkdate($this->arrParam[$value[6]], $this->arrParam[$value[7]], $this->arrParam[$value[5]]) ) {
			$this->arrErr[$value[5]] = "※ " . $value[1] . "を正しく指定してください。<br />";
		}
		if ( (strlen($this->arrParam[$value[2]]) > 0 && strlen($this->arrParam[$value[3]]) > 0 && strlen($this->arrParam[$value[4]] ) > 0) &&  (strlen($this->arrParam[$value[5]]) > 0 || strlen($this->arrParam[$value[6]]) > 0 || strlen($this->arrParam[$value[7]] ) > 0) ){

			$date1 = $this->arrParam[$value[2]] .sprintf("%02d", $this->arrParam[$value[3]]) .sprintf("%02d",$this->arrParam[$value[4]]) ."000000";
			$date2 = $this->arrParam[$value[5]] .sprintf("%02d", $this->arrParam[$value[6]]) .sprintf("%02d",$this->arrParam[$value[7]]) ."235959";
			
			if (($this->arrErr[$value[2]] == "" && $this->arrErr[$value[5]] == "") && $date1 > $date2) {
				$this->arrErr[$value[2]] = "※ " .$value[0]. "と" .$value[1]. "の期間指定が不正です。<br />";
			}
		}
	}
	
	/*-----------------------------------------------------------------*/
	/*	CHECK_SET_TERM2
	/*	年月日時に別れた2つの期間の妥当性をチェックし、整合性と期間を返す
	/*　引数 (開始年,開始月,開始日,開始時間,終了年,終了月,終了日,終了時間)
	/*　戻値 array(１，２，３）
	/*  		１．開始年月日 (YYYYMMDDHH 0000)
	/*			２．終了年月日 (YYYYMMDDHH 0059)
	/*			３．エラー ( 0 = OK, 1 = NG )
	/*-----------------------------------------------------------------*/
	// value[0] = 項目名1
	// value[1] = 項目名2
	// value[2] = start_year
	// value[3] = start_month
	// value[4] = start_day
	// value[5] = start_hour
	// value[6] = end_year
	// value[7] = end_month
	// value[8] = end_day
	// value[9] = end_hour
	function CHECK_SET_TERM2 ($value) {

		// 期間指定
		if(isset($this->arrErr[$value[2]]) || isset($this->arrErr[$value[6]])) {
			return;
		}	
		$error = 0;
		if ( (strlen($this->arrParam[$value[2]]) > 0 || strlen($this->arrParam[$value[3]]) > 0 || strlen($this->arrParam[$value[4]] ) > 0 || strlen($this->arrParam[$value[5]]) > 0) && ! checkdate($this->arrParam[$value[3]], $this->arrParam[$value[4]], $this->arrParam[$value[2]]) ) {
			$this->arrErr[$value[2]] = "※ " . $value[0] . "を正しく指定してください。<br />";
		}
		if ( (strlen($this->arrParam[$value[6]]) > 0 || strlen($this->arrParam[$value[7]]) > 0 || strlen($this->arrParam[$value[8]] ) > 0 || strlen($this->arrParam[$value[9]] ) > 0) && ! checkdate($this->arrParam[$value[7]], $this->arrParam[$value[8]], $this->arrParam[$value[6]]) ) {
			$this->arrErr[$value[6]] = "※ " . $value[1] . "を正しく指定してください。<br />";
		}
		if ( (strlen($this->arrParam[$value[2]]) > 0 && strlen($this->arrParam[$value[3]]) > 0 && strlen($this->arrParam[$value[4]] ) > 0 && strlen($this->arrParam[$value[5]] ) > 0) &&  (strlen($this->arrParam[$value[6]]) > 0 || strlen($this->arrParam[$value[7]]) > 0 || strlen($this->arrParam[$value[8]] ) > 0 || strlen($this->arrParam[$value[9]] ) > 0) ){

			$date1 = $this->arrParam[$value[2]] .sprintf("%02d", $this->arrParam[$value[3]]) .sprintf("%02d",$this->arrParam[$value[4]]) .sprintf("%02d",$this->arrParam[$value[5]])."0000";
			$date2 = $this->arrParam[$value[6]] .sprintf("%02d", $this->arrParam[$value[7]]) .sprintf("%02d",$this->arrParam[$value[8]]) .sprintf("%02d",$this->arrParam[$value[9]])."0000";
			
			if (($this->arrErr[$value[2]] == "" && $this->arrErr[$value[6]] == "") && $date1 > $date2) {
				$this->arrErr[$value[2]] = "※ " .$value[0]. "と" .$value[1]. "の期間指定が不正です。<br />";
			}
			if($date1 == $date2) {
				$this->arrErr[$value[2]] = "※ " .$value[0]. "と" .$value[1]. "の期間指定が不正です。<br />";
			}
			
		}
	}	
	//ディレクトリ存在チェック
	function DIR_CHECK ($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(!is_dir($this->arrParam[$value[1]])) {
			$this->arrErr[$value[1]] = "※ 指定した" . $value[0] . "は存在しません。<br />";
		}
	}
	
	//ディレクトリ存在チェック
	function DOMAIN_CHECK ($value) {
		if(isset($this->arrErr[$value[1]])) {
			return;
		}
		if(strlen($this->arrParam[$value[1]]) > 0 && !ereg("^\.[^.]+\..+", $this->arrParam[$value[1]])) {
			$this->arrErr[$value[1]] = "※ " . $value[0] . "の形式が不正です。<br />";
		}
	}	
}
?>