0xV3NOMx
Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64



Your IP : 3.145.170.164


Current Path : /var/www/oasis/src/
Upload File :
Current File : /var/www/oasis/src/dynamicmastersdetails_one.php

<?php
$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
$main_src=$main_src_obj[1];
$root_file_name=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/validation_files/validate_".$_SESSION['g_file_id'].".php";

if (file_exists($root_file_name)) {
			require_once($root_file_name);
			}
function getModuleColumnName($aobj_context)
    {
	    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$module_name=$aobj_context->mobj_data["module_name"];
		$qry="  select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where module_name='$module_name'     and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
		$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
		//echo $qry;
		print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_rs,0,"success"));
			        return $lobj_rs;
	}
	function AssignRefModuleLovValues($aobj_context)
    {
		session_start();
		$user_type=$_SESSION['user_type'];
		$user_dept=$_SESSION['user_dept'];
	    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$schema_id=$aobj_context->mobj_data["schema_id"];
		$qry="select su.internal_code,su.ref_module_code,s.module_name,
				ifnull(su.populate_lov,1) as populate_lov from s_user_schema_elements su
				inner join s_user_schema s on s.internal_code=su.ref_module_code
				where su.is_ref_module_code_lov=1 
				and su.ref_s_user_schema_code={$schema_id}
				and su.ref_module_code<>0"; 
		$lobj_rs = $aobj_context->mobj_db->GetAll($qry);
		 
		for($mod=0;$mod<count($lobj_rs);$mod++)
		{
			$ref_module_code=$lobj_rs[$mod][ref_module_code];
			$ele_code=$lobj_rs[$mod][internal_code];
			$module_name=$lobj_rs[$mod][module_name];
			
			$select_meta_data="select  field_id,table_name from module_meta_columns
					where module_id={$ref_module_code}";
			$lobj_select_meta_data = $aobj_context->mobj_db->GetRow($select_meta_data);	
			$field_id=$lobj_select_meta_data[field_id];
			$table_name=$lobj_select_meta_data[table_name];
			$item_type_codes="";
			if($user_type=='User' && $module_name=='Item Type')
			{
				$select_item_codes="select group_concat(ref_item_type_code) as ref_item_type_code
									 from dept_item_type_mapping where
									 ref_dept_code={$user_dept}";
				$lobj_select_item_codes = $aobj_context->mobj_db->GetRow($select_item_codes); 
				$item_type_ic=$lobj_select_item_codes[ref_item_type_code];
				$item_type_codes=" where internal_code in ({$item_type_ic})";				
			}
			if($lobj_rs[$mod]['populate_lov']=='1')
			{
			$select_data="select {$ele_code} as ele_code,internal_code, concat({$field_id}) as  value
						from {$table_name} {$item_type_codes}";
			$lobj_select_data = $aobj_context->mobj_db->GetAll($select_data);
			if(!empty($lobj_select_data))
			$arr[$mod]=	$lobj_select_data;
			}
			else
			{
				$lobj_select_data_lov[0]['ele_code']=$ele_code;
				$lobj_select_data_lov[0]['internal_code']=0;
				$lobj_select_data_lov[0]['value']="";
					$arr[$mod]=	$lobj_select_data_lov;
			}			
			//echo $select_data;
			
		}
		 
		print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"));
	 
	}
	function getsRefDataValuesForDetails($aobj_context)
    {
	    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$internal_code=$aobj_context->mobj_data["internal_code"];
		$schema_id=$aobj_context->mobj_data["schema_id"];
		$text_box_id=$aobj_context->mobj_data["text_box_id"];
		$qry="  select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where s.internal_code='$schema_id'    and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
		$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
		$field_split=explode(",",$lobj_rs[field_name]);
		$get_value="select concat({$field_split[0]},'-',{$field_split[1]}) as value from {$lobj_rs[table_name]}
				where internal_code={$internal_code}";
			$lobj_get_value[val] = $aobj_context->mobj_db->GetRow($get_value);	
			$lobj_get_value[text_box_id]=$text_box_id;
		print_r($aobj_context->mobj_output->ToJSONEnvelope($lobj_get_value,0,"success"));
			        return $lobj_get_value;
	}
	function getRefModuleColumnName($aobj_context)
    {
	    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC); 
		$internal_code=$aobj_context->mobj_data["internal_code"];
		$html_field_id=$aobj_context->mobj_data["html_field_id"];
		$old_qry="  select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where s.internal_code='$internal_code'    and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
		//echo $qry;
				$qry="select concat('module_',schema_id  ) as table_name,
				schema_id as table_id,
				GROUP_CONCAT(name  order by seq SEPARATOR '-ele-' ) as name,
				GROUP_CONCAT(name,'->',field_name) as pop_field_name,
				GROUP_CONCAT(field_name order by seq) as field_name from 
				(select ref_s_user_schema_code  as schema_id,name,db_field as field_name,
				ifnull(sequence,0) as seq
				from s_user_schema_elements 
				where include_in_popup=1 
				and ref_s_user_schema_code={$internal_code} 
				order by ref_s_user_schema_group_code,ifnull(sequence,0),internal_code
				 ) a group by schema_id";
		$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
		// To Get The Filter Consition
		  $get_ref_module_filter="select s.ref_module_code,
				s.ref_module_code_ref_field,s_ref.db_field,
				s.ref_module_code_ref_field_on ,s.ref_module_code_ref_field_const
				from s_user_schema_elements s 
				inner join s_user_schema_elements s_ref on s_ref.internal_code=s.ref_module_code_ref_field
				where s.internal_code={$html_field_id}";
			$lobj_get_ref_module_filter = $aobj_context->mobj_db->GetRow($get_ref_module_filter);
			$pop_up_value_split=explode(",",$lobj_rs['pop_field_name']);	 
			foreach($pop_up_value_split as $k=>$v)
			{
				$comma_split=explode("->",$v);	
				$pop_up_data[$comma_split[1]]=$comma_split[0];
			}
			 
		$arr['pop_up_data']=$pop_up_data;	 
		$arr['ref_data']=$lobj_rs;	 
		$arr['filter_data']=$lobj_get_ref_module_filter;	 
		if(!empty($lobj_rs))
		{
		print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"));
			        return $lobj_rs;
		}
		else
		{
		print_r($aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"success"));
			        return $lobj_rs;
		}
	}
function pupulateLeftNav($aobj_context)
{
		  /* require("login.php");
		   $CMayaContextuser=NEW CMayaContext();
		echo  "gg".$CMayaContextuser->getUser(); */
        $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
		$type=$aobj_context->mobj_data["type"];
		$get_user_right="select ss.internal_code as user_id,user_type,value  from  s_sysdb ss 
		inner join  s_ref_type sr on sr.internal_code=user_type where ss.internal_code=".$_SESSION['user_id'];
		   $lobj_get_user_right = $aobj_context->mobj_db->GetRow($get_user_right);
		if($lobj_get_user_right[value]=='Admin')
		{
				$lstr_qry = "select s.internal_code,module_name,t.value,is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
				,IFNULL(main_menu,'0') as main_menu_id,
				IFNULL(mm.value,concat('z',module_name)) as main_menu_val from s_user_schema s inner join s_ref_type t
				on t.internal_code=module_type
				left join s_ref_type mm on mm.internal_code=main_menu
				where module_name is not null and t.value='{$type}'
				and s.active=1
				group by s.internal_code order by 
				 ifnull(s.sequence,0),main_menu_val,module_name";
		}
		else
		{
        $lstr_qry = "select s.internal_code,module_name,t.value,is_menu_only,if(is_menu_only=1,menu_function,'') as menu_function 
				,IFNULL(main_menu,'0') as main_menu_id,
				IFNULL(mm.value,concat('z',module_name)) as main_menu_val from s_user_schema s inner join s_ref_type t
					on t.internal_code=module_type
					left join s_ref_type mm on mm.internal_code=main_menu
				inner join user_rights ur on ur.module_id=s.internal_code
					where module_name is not null and t.value='{$type}'
					and (is_view=1 or is_add=1 or is_edit=1 or is_del=1)
				and ref_s_sysdb_code=".$_SESSION['user_id']." and s.active=1
				group by s.internal_code
				order by  ifnull(s.sequence,0),main_menu_val,module_name";
		}
		 
        $lobj_rs = $aobj_context->mobj_db->GetAll($lstr_qry);
		//echo $lstr_qry;
		$arr[0]=$type;
		$arr[1]=$lobj_rs;
        if(count($lobj_rs) != 0)
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
        else
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
        return;
}
function AddUserSchemaGeneralDetails($aobj_context)
{
	session_start();
	$user_id=$_SESSION['user_id'];
	include_once("/JSON.php"); 
    $json = new Services_JSON();
    $obj_error_class = $aobj_context->main_src."/custom_src/parseini.php"; 
	
	require_once($aobj_context->main_src."/custom_src/parseini.php");
	$obj_error_class=new parseIni($aobj_context);
	
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
		 
		$data_cols=stripcslashes($aobj_context->mobj_data["data_cols"]);
		$data_cols=  (substr($data_cols,0,strlen($data_cols) - 1));
		$data_values=stripcslashes($aobj_context->mobj_data["data_values"]);
		$data_values=  (substr($data_values,0,strlen($data_values) - 1));
		$schema_id=$aobj_context->mobj_data["ref_s_user_schema_code"];
		$validation=$aobj_context->mobj_data["validation"];
		$login_cnt=$aobj_context->mobj_data["login_counter"];
		$is_update_visible_field=$aobj_context->mobj_data["is_update_visible_field"];
		$validation=  (substr($validation,0,strlen($validation) - 1));
				
 // gets the details information
	$internal_code=$aobj_context->mobj_data["internal_code"];
	$table_name=$aobj_context->mobj_data["table_name"];
	$auto_increment_value=$aobj_context->mobj_data["auto_increment_value"];
	$lstr_param = stripslashes($aobj_context->mobj_data["schemaData"]);
	$mobj_jsondata = $json->decode($lstr_param);
	$larr_schema_data = get_object_vars($mobj_jsondata);
	$schema_module_table="module_".$schema_id;
	 
	$lstr_save_schema_details_arr =  stripcslashes($aobj_context->mobj_data["save_schema_details_arr"]);
	$mobj_jsondata = $json->decode($lstr_save_schema_details_arr);
	$larr_save_data = get_object_vars($mobj_jsondata); 
	if(empty($larr_save_data))
	{
	$lstr_save_schema_details_arr =  ($aobj_context->mobj_data["save_schema_details_arr"]);
	$mobj_jsondata = $json->decode($lstr_save_schema_details_arr);
	$larr_save_data = get_object_vars($mobj_jsondata); 
	}
	
	$lstr_auto_inc_jsn_text = stripslashes($aobj_context->mobj_data["auto_inc_jsn_text"]);
	$mobj_ai_jsondata = $json->decode($lstr_auto_inc_jsn_text);
	$auto_inc_jsn_text = get_object_vars($mobj_ai_jsondata);
	 foreach($auto_inc_jsn_text as $ak=>$av)
	 {
		foreach($av as $akk=>$avv)
		$auto_inc_arr[$akk]=$avv;
	 }
 
	$insert_cols="";
	$insert_col_values="";
	$update_col_values="";
	foreach($larr_save_data as $pk=>$pv)
	{
	$insert_cols.=$pv->field_id.",";
	
	$field_split_arr=explode("_ele_",$pv->field_id);
	$int_code=$field_split_arr[1];
	if(isset($auto_inc_arr) && in_array($int_code,$auto_inc_arr))
	{
	$prefix=$auto_inc_arr[$int_code];
	$ref_module_element_code=$int_code;
	$ref_module_code=$schema_id;
	$aut_inc_val=getSerieslastNoInFile($aobj_context,$prefix,$ref_module_code,$ref_module_element_code);
	$insert_col_values.="'{$aut_inc_val}',";
	}
	else	
	$insert_col_values.="'".addslashes($pv->field_id_val)."',";
	
	$update_cond.=$pv->field_id."='".addslashes($pv->field_id_val)."',";
	}

	$insert_cols=substr($insert_cols,0,strlen($insert_cols)-1);
	$insert_col_values=substr($insert_col_values,0,strlen($insert_col_values)-1);
	$update_cond.=" modified_by={$user_id}, modified_date=now() ";
	$update_qry=" update {$schema_module_table} set {$update_cond} where internal_code={$internal_code}";
	 
		//echo $validation; die(); 
		
		$_SESSION['error_flag']=1;
		 
		 
	 if (function_exists('validate'))
		{
			validate($aobj_context); 
		}
	
 	
	if($internal_code==0 && $_SESSION['error_flag']==1)
	{

		  //inserts bthe values in first Module_ table
		$insert_qry="insert into module_".$schema_id."
								( ref_s_user_schema_code, ".$insert_cols.",created_by,
								created_date,
								modified_by,
								modified_date) values 
								(".$schema_id.",".$insert_col_values.",".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()
								)";	
			 					
		$insert_qry_old="insert into module_".$schema_id."
								( ref_s_user_schema_code, ".$data_cols.",created_by,
								created_date,
								modified_by,
								modified_date) values 
								(".$schema_id.",".$data_values.",".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()
								)";
		//echo $insert_qry;
		// die();
		 $lobj_rs = $aobj_context->mobj_db->Execute($insert_qry); 
		 
		 if(mysql_error()!='')
		 { 
		    $validation_data_cols = explode(",", $data_cols);
		    $validation_data_values = explode(",",str_ireplace('"','',$data_values));
	        
			for($spc = 0 ;$spc < count($validation_data_values) ; $spc++)	
			 {
			     $trim_validation_data_values[$spc] = trim($validation_data_values[$spc]);
			 }
			
			$validation_data_values =  array_flip($trim_validation_data_values);
		  
		    $pos=strpos(mysql_error(),'Duplicate');
							
		 		   
           $dupvalid =  strstr(mysql_error(), "'");
           $dupvalid_array =  explode("' for",$dupvalid);
		   $dupvalid = substr($dupvalid_array[0],1);
		   	   
		   
		   $get_search_id = $validation_data_values[$dupvalid];
		    
		   
		   $get_system_id_array =  explode('ele_',$validation_data_cols[$get_search_id]);
		   $mid = $schema_id;
		   $sysid = $get_system_id_array[1];
		   
		   $getmod_sys_names = "select s.module_name,ss.system_name from s_user_schema s
									inner join s_user_schema_elements ss on ss.ref_s_user_schema_code = s.internal_code
									where s.internal_code = {$mid} and ss.internal_code = {$sysid} ";
		   $lobj_getmod_sys_names = $aobj_context->mobj_db->GetRow($getmod_sys_names);
		   $obj_error_class->valid_module_name =  $lobj_getmod_sys_names[module_name];
		   $obj_error_class->valid_system_name =  $lobj_getmod_sys_names[system_name];
		   $valid_message = $obj_error_class->getErrorMessage();
		   		   		
		   		   	           		  
			if($pos>=0);
			 {
	            if(empty($valid_message))
                {				
				   $rdata['msg']="Check for Unique values".mysql_error();
				}
				else 
				{
				   
                   $rdata['msg']=$valid_message;	
                }
                
				   
				echo $aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure");
				return 	$rdata;
			 }
		 }
		 // to update the transaction_series_prefix table with last number
		  if(!empty($auto_increment_value))
		 {
		 $loop_count=explode("~",$auto_increment_value);
		 for($i=0;$i<count($loop_count)-1;$i++)
		 {
		 $last_no=0;
		 $ref_module_element_code_arr=explode("ele_value",$loop_count[$i]);
		 $ref_module_element_code=$ref_module_element_code_arr[0];
		 $index_val=strripos($ref_module_element_code_arr[1],"-");
		 $last_no=(substr($ref_module_element_code_arr[1],$index_val+1));
		 
		 $update_last_no="update transaction_series_prefix set last_no={$last_no} 
		 where ref_module_element_code={$ref_module_element_code} and ref_module_code={$schema_id}
		 and {$last_no}>last_no";
		 //echo $update_last_no;
		  $update_last_no = $aobj_context->mobj_db->Execute($update_last_no);
		 }
		 }
	             
		$last_inserted_id = $aobj_context->mobj_db->Insert_ID();
  ########################### To Inser tMultiple Group Details ####################################### To Inser tMultiple Group Details
		 $select_distinct_group_names="select internal_code,name,
								concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name,
								concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name
								,ifnull(parent_group_code,0) as parent_group_code
								from s_user_schema_group 
								where ref_s_user_schema_code={$schema_id}
								and multiple=1 and ifnull(parent_group_code,0)=0 
								order by ifnull(sequence,0)";
		 $lobj_select_distinct_group_names = $aobj_context->mobj_db->GetAll($select_distinct_group_names);
 	 
		foreach( $lobj_select_distinct_group_names as $gk=>$gv)
		{
			$group_id=$gv['internal_code'];
			$entry_table_name=$gv['entry_table_name'];
			$group_table_name=$gv['group_table_name'];
			
			$get_child_groups="select internal_code,
							concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as child_entry_table,
							concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as child_group_table_name
							from s_user_schema_group
							where parent_group_code={$group_id}
							and multiple=1";
			 $lobj_get_child_groups =  $aobj_context->mobj_db->GetAll($get_child_groups);
			 
			$desc_table="desc {$entry_table_name}";
			 $lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
			 $elements='';
			 foreach($lobj_desc_table as $d=>$dv)
			 {
			 	if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code' &&  $dv['Field']!='ref_s_ref_data_code'&&  $dv['Field']!='group_int_code')
				{
				 $elements.=$dv['Field'].',';
				}
			 }
			$elements=substr($elements,0,strlen($elements)-1);
			 ########################### to Map the CHILD Group Table  Values STARTS #######################################
		 	if($lobj_get_child_groups)
			{
				$get_limit_cnt="select * from {$entry_table_name}
								where login_cnt={$login_cnt}";
				 $lobj_get_limit_cnt = $aobj_context->mobj_db->getAll($get_limit_cnt);
				for($limit=0;$limit<count($lobj_get_limit_cnt);$limit++)
				{
				$insert_into_group_table="insert into {$group_table_name} 
									(internal_code,ref_s_ref_data_code,{$elements})
									select 0,{$last_inserted_id},{$elements} from {$entry_table_name}
									where login_cnt={$login_cnt}  and
									internal_code={$lobj_get_limit_cnt[$limit][internal_code]}";
					$group_insrt=$aobj_context->mobj_db->Execute($insert_into_group_table);
					 
			 		$last_inserted_parent_group_id = $aobj_context->mobj_db->Insert_ID();
						for($j=0;$j<count($lobj_get_child_groups);$j++)
						{
								$child_entry_table=$lobj_get_child_groups[$j][child_entry_table];
								$child_group_table_name=$lobj_get_child_groups[$j][child_group_table_name];
								$desc_table="desc {$child_entry_table}";
								 $lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
								 $child_elements='';
								 foreach($lobj_desc_table as $d=>$dv)
								 {
									if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code' &&  $dv['Field']!='ref_s_ref_data_code' &&  $dv['Field']!='group_int_code')
									{
									 $child_elements.=$dv['Field'].',';
									}
								 }
							$child_elements=substr($child_elements,0,strlen($child_elements)-1);
								$insert_into_child_group_table="insert into {$child_group_table_name} 
								(internal_code,ref_s_ref_data_code,{$child_elements})
								select 0,{$last_inserted_parent_group_id},{$child_elements} 
								from {$child_entry_table}
								where login_cnt={$login_cnt}
								and ref_s_ref_data_code= {$lobj_get_limit_cnt[$limit][internal_code] }";
						$group_insrt=$aobj_context->mobj_db->Execute($insert_into_child_group_table);
												
					 
						}
				}
				for($d=0;$d<count($lobj_get_child_groups);$d++)
					{
					$del_child_entry_table=$lobj_get_child_groups[$d][child_entry_table];
					$delete_from_child_group_table="delete from {$del_child_entry_table} where login_cnt={$login_cnt}";
					$delete_from_child_group_table =  $aobj_context->mobj_db->Execute($delete_from_child_group_table);
					}
			}	
			
			 ########################### to Map the CHILD Group Table  Values ENDS #######################################
			 
			else
			{
			$insert_into_group_table="insert into {$group_table_name} 
									(internal_code,ref_s_ref_data_code,{$elements})
									select 0,{$last_inserted_id},{$elements} from {$entry_table_name}
									where login_cnt={$login_cnt}";
			$group_insrt=$aobj_context->mobj_db->Execute($insert_into_group_table);
			 
			UpldateGroupImagesFromEntryToGroupTable($aobj_context,$login_cnt,$last_inserted_id,$schema_id,$group_id,$group_table_name,$entry_table_name);
			}
			$delete_from_group_table="delete from {$entry_table_name} where login_cnt={$login_cnt}";
			$lobj_delete_from_group_table =  $aobj_context->mobj_db->Execute($delete_from_group_table);
		}
	 
			
			
	  if (function_exists('postSave'))
		{
			$post_data =  postSave($aobj_context,$last_inserted_id,$internal_code); 
		}
	     //echo $lstr_qry;
	        if(count($lobj_rs) != 0)
			{
			 
			
				for( $i = 0; $i < count($larr_schema_data); $i++ )
				{
				$get_module_code="select ref_module_code from s_user_schema_elements where internal_code=".addslashes($larr_schema_data[$i]->ref_s_user_schema_elements_code);
				$lobj_ele_code = $aobj_context->mobj_db->GetRow($get_module_code);
				 
					$insert_qry="insert into {$table_name} (
			       ref_s_user_schema_code,
			       ref_s_module_code,
			       ref_s_user_schema_group_code,
			       ref_s_user_schema_elements_code,
			       value,ref_ref_s_user_schema_code,
				   created_by,
					created_date,
					modified_by,
					modified_date
				   
			       )
			        values ( '".addslashes($larr_schema_data[$i]->ref_s_user_schema_code)  ."','"
			                   .  $last_inserted_id  ."','"
			                   .   addslashes($larr_schema_data[$i]->ref_s_user_schema_group_code)  ."','"
			                   .   addslashes($larr_schema_data[$i]->ref_s_user_schema_elements_code)  ."','"
			                   .   addslashes($larr_schema_data[$i]->value)  ."',".$lobj_ele_code[ref_module_code].",
								 ".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()  
								)";
						   $lobj_rs = $aobj_context->mobj_db->Execute($insert_qry); 
	 				   //echo 	$insert_qry;
				}
			}
					 
				if($lobj_rs)
				{
				 
		        $rdata['msg'] = (!empty($post_data))?$post_data:"Inserted  Successfully.";
		        $rdata['last_id'] = $last_inserted_id;
			    print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return;
			 }
	 
			 else
			{
		 
				$rdata['msg']="Insertion Failed";
	            echo $aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure");
				return 	$rdata;
			}
	} 
		
    
	else if($internal_code>0 && $_SESSION['error_flag']==1)
	{
	  //inserts bthe values in first Module_ table
	   
	  $table_name="module_{$schema_id}";
	  /* $old_data_arr="";
	  $get_old_data="select * from module_{$schema_id} where internal_code={$internal_code}";
	  $lobj_get_old_data = $aobj_context->mobj_db->GetRow($get_old_data); 
	  foreach( $lobj_get_old_data as $k=>$v)
		$old_data_arr[$k]=$v;
	  
	  $del_qry="delete from  {$table_name} where internal_code={$internal_code}";
	   $lobj_rs = $aobj_context->mobj_db->Execute($del_qry); //deleting same and inserting same id as internal_code
		$insert_qry="insert into {$table_name} (internal_code,ref_s_user_schema_code, ".$data_cols.",
								created_by,
								created_date,
								modified_by,
								modified_date) values (".$internal_code.",".$schema_id.",".$data_values.",".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()
								)";
		
		 
		 $lobj_rs = $aobj_context->mobj_db->Execute($insert_qry) */;
		 $lobj_rs = $aobj_context->mobj_db->Execute($update_qry);
			
		  if(mysql_error()!='')
		 { 
		 
		    $validation_data_cols = explode(",", $data_cols);
		    $validation_data_values = explode(",",str_ireplace('"','',$data_values));
	        
			for($spc = 0 ;$spc < count($validation_data_values) ; $spc++)	
			 {
			     $trim_validation_data_values[$spc] = trim($validation_data_values[$spc]);
			 }
			
			$validation_data_values =  array_flip($trim_validation_data_values);
		  
		    $pos=strpos(mysql_error(),'Duplicate');
							
		 		   
           $dupvalid =  strstr(mysql_error(), "'");
           $dupvalid_array =  explode("' for",$dupvalid);
		   $dupvalid = substr($dupvalid_array[0],1);
		   	   
		   
		   $get_search_id = $validation_data_values[$dupvalid];
		    
		   
		   $get_system_id_array =  explode('ele_',$validation_data_cols[$get_search_id]);
		   $mid = $schema_id;
		   $sysid = $get_system_id_array[1];
		   
		   $getmod_sys_names = "select s.module_name,ss.system_name from s_user_schema s
									inner join s_user_schema_elements ss on ss.ref_s_user_schema_code = s.internal_code
									where s.internal_code = {$mid} and ss.internal_code = {$sysid} ";
		   $lobj_getmod_sys_names = $aobj_context->mobj_db->GetRow($getmod_sys_names);
		   $obj_error_class->valid_module_name =  $lobj_getmod_sys_names[module_name];
		   $obj_error_class->valid_system_name =  $lobj_getmod_sys_names[system_name];
		   
		   $valid_message = $obj_error_class->getErrorMessage();
						
			if($pos>=0);
			 {
				 if(empty($valid_message))
                {				
				   $rdata['msg']="Check for Unique values";
				}
				else 
				{
				   
                   $rdata['msg']=$valid_message;	
                }			
				
				echo $aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure");
				return 	$rdata;
			 }
		 }
		  $last_inserted_id = $internal_code;
		  
		  // Update the Old Value to Table
		/* $update_created_by_values="update {$table_name} set 
						created_by='{$old_data_arr[created_by]}',
						created_date='{$old_data_arr[created_date]}' where internal_code={$internal_code}";
			 $lobj_update = $aobj_context->mobj_db->Execute($update_created_by_values);			 
		 
		 // To update the Non visible field Values
		if($is_update_visible_field)
		{
			$select_db_field="select db_field from s_user_schema_elements where 
				ref_s_user_schema_code={$schema_id}
				  and is_visible=0";
			$lobj_select_db_field = $aobj_context->mobj_db->GetAll($select_db_field); 
			$update_cond="";
			foreach($lobj_select_db_field  as $ku=>$kv)
			{
			$update_cond.="{$kv[db_field]}='{$old_data_arr[$kv[db_field]]}',";
			}
		 $update_cond=substr($update_cond,0,strlen($update_cond)-1);
		 $update_old_val="update module_{$schema_id} set 
					{$update_cond} where internal_code={$internal_code}";
		$lobj_update_old_val = $aobj_context->mobj_db->Execute($update_old_val); 			
		 }*/
		 if(!empty($auto_increment_value))
		 {
		 $loop_count=explode("~",$auto_increment_value);
		 for($i=0;$i<count($loop_count)-1;$i++)
		 {
		 $last_no=0;
		 $ref_module_element_code_arr=explode("ele_value",$loop_count[$i]);
		 $ref_module_element_code=$ref_module_element_code_arr[0];
		 $index_val=strripos($ref_module_element_code_arr[1],"-");
		 $last_no=(substr($ref_module_element_code_arr[1],$index_val+1));
		 
		 $update_last_no="update transaction_series_prefix set last_no={$last_no} 
		 where ref_module_element_code={$ref_module_element_code} and ref_module_code={$schema_id}
		 and {$last_no}>last_no";
		 //echo $update_last_no;
		  $update_last_no = $aobj_context->mobj_db->Execute($update_last_no);
		 }
		 }
	 				
			 if($lobj_rs)
		    {
			$del_qry="delete from $table_name where ref_s_module_code=".$internal_code;
			 $lobj_del = $aobj_context->mobj_db->Execute($del_qry); 
			
			for( $i = 0; $i < count($larr_schema_data); $i++ )
					{
					$get_module_code="select ref_module_code from s_user_schema_elements where
					internal_code=".addslashes($larr_schema_data[$i]->ref_s_user_schema_elements_code);
					$lobj_ele_code = $aobj_context->mobj_db->GetRow($get_module_code);
					 
						$insert_qry="insert into {$table_name} (
				       ref_s_user_schema_code,
				       ref_s_module_code,
				       ref_s_user_schema_group_code,
				       ref_s_user_schema_elements_code,
				       value,ref_ref_s_user_schema_code,
					   created_by,
					created_date,
					modified_by,
					modified_date
					   
				       )
				        values ( '".addslashes($larr_schema_data[$i]->ref_s_user_schema_code)  ."','"
				                   .  $internal_code  ."','"
				                   .   addslashes($larr_schema_data[$i]->ref_s_user_schema_group_code)  ."','"
				                   .   addslashes($larr_schema_data[$i]->ref_s_user_schema_elements_code)  ."','"
				                   .   addslashes($larr_schema_data[$i]->value)  ."',".$lobj_ele_code[ref_module_code].",
								 ".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()  
								)";
							   $lobj_rs1 = $aobj_context->mobj_db->Execute($insert_qry);
				 	   
					}
			 
			   
			
		     }
			#######################To Inser tMultiple Group Details STARTS#############################
		 $select_distinct_group_names="select internal_code,name,
								concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name,
								concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name
								from s_user_schema_group 
								where ref_s_user_schema_code={$schema_id} 
								and ifnull(parent_group_code,0)=0 
								and multiple=1";
		 $lobj_select_distinct_group_names = $aobj_context->mobj_db->GetAll($select_distinct_group_names);
 	 
		foreach( $lobj_select_distinct_group_names as $gk=>$gv)
		{
			$group_id=$gv['internal_code'];
			$entry_table_name=$gv['entry_table_name'];
			$group_table_name=$gv['group_table_name'];
			 $get_delete_p_ids_of_child="select group_concat(internal_code) as code
									from {$group_table_name} 
									where ref_s_ref_data_code={$internal_code} ";
			$lobj_get_delete_ids_of_child =  $aobj_context->mobj_db->GetRow($get_delete_p_ids_of_child);
			$p_ref_code=$lobj_get_delete_ids_of_child[code];
			 // Delete From Parent Group
			$delete_from_group_table="delete from {$group_table_name} 
				where ref_s_ref_data_code={$internal_code}";
			$lobj_delete_from_group_table =  $aobj_context->mobj_db->Execute($delete_from_group_table);
			 
			 $get_child_groups="select internal_code,
							concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as child_entry_table,
							concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as child_group_table_name
							from s_user_schema_group
							where parent_group_code={$group_id}";
			 $lobj_get_child_groups =  $aobj_context->mobj_db->GetAll($get_child_groups);
			 
			$desc_table="desc {$entry_table_name}";
			 $lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
			 $elements='';
			 foreach($lobj_desc_table as $d=>$dv)
			 {
			 	if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code' &&  $dv['Field']!='ref_s_ref_data_code'&&  $dv['Field']!='group_int_code')
				{
				 $elements.=$dv['Field'].',';
				}
			 }
			$elements=substr($elements,0,strlen($elements)-1);
			 ########################### to Map the CHILD Group Table  Values STARTS #######################################
		 	
			if($lobj_get_child_groups)
			{
				$get_limit_cnt="select * from {$entry_table_name}
								where login_cnt={$login_cnt}";
				 $lobj_get_limit_cnt = $aobj_context->mobj_db->getAll($get_limit_cnt);
				   for($s=0;$s<count($lobj_get_child_groups);$s++)
					{
					$child_group_table_name=$lobj_get_child_groups[$s][child_group_table_name];
					$delete_from_child_group_table="delete from {$child_group_table_name} 
											where   
											 ref_s_ref_data_code in({$p_ref_code})";
					 $obj_delete_from_child_group_table =  $aobj_context->mobj_db->Execute($delete_from_child_group_table);
					  
					}  
					 
				for($limit=0;$limit<count($lobj_get_limit_cnt);$limit++)
				{
				$insert_into_group_table="insert into {$group_table_name} 
									(internal_code,ref_s_ref_data_code,{$elements})
									select group_int_code,{$internal_code},{$elements} from {$entry_table_name}
									where login_cnt={$login_cnt}  and
									internal_code={$lobj_get_limit_cnt[$limit][internal_code]}";
				$group_insrt=$aobj_context->mobj_db->Execute($insert_into_group_table);
				
				
				//$last_inserted_parent_group_id = $aobj_context->mobj_db->Insert_ID();
				
				$get_last_insert_id_qry= "select group_int_code from {$entry_table_name}
									where login_cnt={$login_cnt}  and
									internal_code={$lobj_get_limit_cnt[$limit][internal_code]}";
				 $obj_get_last_insert_id_qry=$aobj_context->mobj_db->GetRow($get_last_insert_id_qry);
				 $last_inserted_parent_group_id= $obj_get_last_insert_id_qry[group_int_code];
				 
				 
				 
					for($j=0;$j<count($lobj_get_child_groups);$j++)
					{
									$child_entry_table=$lobj_get_child_groups[$j][child_entry_table];
									$child_group_table_name=$lobj_get_child_groups[$j][child_group_table_name];
									$desc_table="desc {$child_entry_table}";
									 $lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
									 $child_elements='';
									 foreach($lobj_desc_table as $d=>$dv)
									 {
										if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code' &&  $dv['Field']!='ref_s_ref_data_code'&&  $dv['Field']!='group_int_code')
										{
										 $child_elements.=$dv['Field'].',';
										}
									 }
							$child_elements=substr($child_elements,0,strlen($child_elements)-1);
							  
							$insert_into_child_group_table="insert into {$child_group_table_name} 
									(internal_code,ref_s_ref_data_code,{$child_elements})
									select group_int_code,{$last_inserted_parent_group_id},{$child_elements} 
									from {$child_entry_table}
									where login_cnt={$login_cnt}
									and ref_s_ref_data_code= {$lobj_get_limit_cnt[$limit][internal_code] }";
							$group_insrt=$aobj_context->mobj_db->Execute($insert_into_child_group_table);	
					  
					}
					//die();
				 	}	
				for($d=0;$d<count($lobj_get_child_groups);$d++)
					{
					$del_child_entry_table=$lobj_get_child_groups[$d][child_entry_table];
					$delete_from_child_group_table="delete from {$del_child_entry_table} 
					where login_cnt={$login_cnt}";
					$delete_from_child_group_table =  $aobj_context->mobj_db->Execute($delete_from_child_group_table);
					}
			}	
			 
		
			 ########################### to Map the CHILD Group Table  Values ENDS #######################################
			else
			{
			$insert_into_group_table="insert into {$group_table_name} 
									(internal_code,ref_s_ref_data_code,{$elements})
									select group_int_code,{$internal_code},{$elements} from {$entry_table_name}
									where login_cnt={$login_cnt}";
			$group_insrt=$aobj_context->mobj_db->Execute($insert_into_group_table);
			UpldateGroupImagesFromEntryToGroupTable($aobj_context,$login_cnt,$last_inserted_id,$schema_id,$group_id,$group_table_name,$entry_table_name);
			}
			$delete_from_entry_group_table="delete from {$entry_table_name} where login_cnt={$login_cnt}";
			$lobj_delete_from_entry_group_table =  $aobj_context->mobj_db->Execute($delete_from_entry_group_table);
		}
			#######################To Inser tMultiple Group Details ENDS#############################
			  if (function_exists('postSave'))
					{
				 		postSave($aobj_context,$internal_code,$internal_code); 
					}
			if($lobj_rs)
			 {
			 $_SESSION['g_file_id'] ='';
			   $rdata['last_id'] = $internal_code;
		        $rdata['msg']= "Updated  Successfully.";
				 
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
		        return;
			 }
		    else
		    {
			$_SESSION['g_file_id'] ='';
		        $rdata['msg'] = "Udatation Failed.";
		        print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,-1,"Failure"));      
		     } 
	}		 
}
function GetSchemaModuleDetailsForUpdate($aobj_context)
  {
	include_once("format.php");
    $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);  
	$internal_code = $aobj_context->mobj_data["internal_code"]; 	
	$table_name = $aobj_context->mobj_data["table_name"]; 	
	$login_cnt = $aobj_context->mobj_data["login_cnt"]; 	
	$field_name = $aobj_context->mobj_data["field_name"]; 
	$field_name_spl1	=  explode(',',$field_name);
	$schema_id_explode=explode("_",$table_name);
	$schema_id=$schema_id_explode[1];
		$get_data_types="select s.internal_code,value from s_user_schema_elements s inner join s_ref_type t 
					on t.internal_code=data_type where s.ref_s_user_schema_code={$schema_id}";
		$lobj_get_data_types = $aobj_context->mobj_db->GetAll($get_data_types); 				
		$data_type = array();
	  for($k=0;$k<count($lobj_get_data_types);$k++)
		{
		$data_type[$lobj_get_data_types[$k]['internal_code']]=$lobj_get_data_types[$k][value];
		}
		$get_meta_data_qry="select * from {$table_name} where internal_code={$internal_code}";
	    $lobj_meta_data_qry = $aobj_context->mobj_db->GetRow($get_meta_data_qry); 
		 $created_by_id=$lobj_meta_data_qry[created_by];
		$l=0;
		$meta_arr='';
		foreach($lobj_meta_data_qry as $key=>$value)
		{		
			if($key!='internal_code' && $key !='ref_s_user_schema_code' && $key !='created_by' && $key !='created_date'&& $key !='modified_by' && $key !='modified_date')
			{
				$ele_code=explode('_ele_',$key);
				//to get the ref_data details
				$s_ref_data="select ref_module_code from 
				s_user_schema_elements where internal_code={$ele_code[1]} 
				and ref_module_code>0";
				$s_ref_data_obj=$aobj_context->mobj_db->GetRow($s_ref_data); 
				 
			 if(!empty($s_ref_data_obj))
			 {
			 $get_col_names_old=" select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name,
				ifnull(multiple,0) as multiple from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where s.internal_code={$s_ref_data_obj[ref_module_code]} 
				 and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where    multiple=0 limit 2) a group by schema_id";
				 
				 $get_col_names="select table_name,field_name AS name,
				 case when field_id2=''
				then field_id1 else concat(field_id1,',',field_id2)  end as field_name
				from module_meta_columns where module_id={$s_ref_data_obj[ref_module_code]}";
				 
				  $s_get_col_names_obj=$aobj_context->mobj_db->GetRow($get_col_names); 
				 
				$pos = strpos($s_get_col_names_obj['field_name'], ',');
				if($pos===false)
				{
				$ref_data_qry="select {$s_get_col_names_obj['field_name']}  as s_ref_value from {$s_get_col_names_obj[table_name]} where internal_code={$value}";
				}
				else {
				$field_name_spl	=  explode(',',$s_get_col_names_obj['field_name']);
				$ref_data_qry="select concat({$field_name_spl[0]},'-',{$field_name_spl[1]}) as
						s_ref_value from {$s_get_col_names_obj[table_name]} where internal_code={$value}";
				}
			 $s_ref_data_qry_obj=$aobj_context->mobj_db->GetRow($ref_data_qry); 
			 
				if(!empty($s_ref_data_qry_obj))
				{
				$field="txt_ref_schema_".$ele_code[1];
//				$field_value=$value;
				$pos = strpos($value,"-");
				if( $pos === false  )
				{
					$field_value=$value;
				}
				else
				{ 
					$arr = explode('-',$value);
					if(count($arr) == 3)
					{
						if( strlen($arr[0]) ==  4 && strlen($arr[1]) == 2 && strlen($arr[2]) == 2)
						{	 
						$field_value=$arr[2] . "/".$arr[1]."/".$arr[0];
						}
						else
						$field_value=$value;
					} 
					//$str.="<td ".$style."'>".$value1."</td>";
					else
						$field_value=$value;					
				}
				$meta_arr[$l][id]=$field; 
				$meta_arr[$l][data]=$s_ref_data_qry_obj['s_ref_value']; 
				$meta_arr[$l][flag]=1; 
				$meta_arr[$l][hidden_id]="details_".$ele_code[1]; 
				$meta_arr[$l][hidden_value]=$field_value;  
				$l++;
				}
			 }
			 else
				 {
				$field="details_".$ele_code[1];
				if($data_type[$ele_code[1]]=='Date')
					$field_value=ui_date_Format($value);
				else if($data_type[$ele_code[1]]=='Month')
					$field_value=ui_month_format($value);
				else 
				$field_value=$value;	
				$meta_arr[$l][id]=$field; 
				$meta_arr[$l][data]=$field_value; 
				$meta_arr[$l][flag]=0; 
				$meta_arr[$l][hidden_id]=""; 
				$meta_arr[$l][hidden_value]=""; 
				$l++;
				}
			}		
		}
		$edit_right=getEditRights($aobj_context,$schema_id, $created_by_id);
		
					 
		//var_dump($meta_arr);
		//take all the s_ref data table name where type=Users
 
	  $details_qry="select
				 suse.ref_module_code,
				 if(ref_ref_s_user_schema_code>0,concat('txt_ref_schema_',ref_s_user_schema_elements_code),
				concat('details_',ref_s_user_schema_elements_code)) as id, 
				ref_s_user_schema_elements_code,
				value,
				if(ref_ref_s_user_schema_code>0,1,0) as flag
				from {$table_name}_details m 
				inner join  s_user_schema_elements suse on suse.internal_code=m.ref_s_user_schema_elements_code
				where ref_s_module_code=  {$internal_code}";
		 
	$lobj_details=  $aobj_context->mobj_db->GetAll($details_qry);  
	 
	//ref display starts,'
	$s_id=explode('_',$table_name);
	$schema_id_ref=$s_id[1];
	$s_ref_display=GetRefDisplayArray($aobj_context,$schema_id_ref,0,$internal_code);
		 
			//####### FOR GROUP ENTRY STARTS
		//$login_cnt	
		$select_distinct_group_names="select internal_code,name,
								concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name,
								concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name
								from s_user_schema_group 
								where ref_s_user_schema_code={$schema_id}
								and multiple=1 
								and ifnull(parent_group_code,0)=0";
		 $lobj_select_distinct_group_names = $aobj_context->mobj_db->GetAll($select_distinct_group_names);
 	 $b=0;
	  
		foreach( $lobj_select_distinct_group_names as $gk=>$gv)
		{
			$entry_table_name=$gv['entry_table_name'];
			$group_table_name=$gv['group_table_name'];
			$group_id=$gv['internal_code'];
			$delete_entry_table_name="delete from {$entry_table_name} where login_cnt={$login_cnt}";
			$lobj_delete_from_group_table =  $aobj_context->mobj_db->Execute($delete_entry_table_name);
			$get_child_groups="select internal_code,
						concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as child_entry_table,
						concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as child_group_table 
						from s_user_schema_group
					where parent_group_code={$group_id} and multiple=1 ";
					 $lobj_get_child_groups =  $aobj_context->mobj_db->GetAll($get_child_groups);
					 $desc_table="desc {$entry_table_name}";
						$lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
						$elements='';
						foreach($lobj_desc_table as $d=>$dv)
						{
							if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code'&& $dv['Field']!='group_int_code')
							{
							$elements.=$dv['Field'].',';
							}
						}
						$elements=substr($elements,0,strlen($elements)-1);
					 
			
			 ### Child Data####
				
					 if($lobj_get_child_groups)
					 {
						 for($d=0;$d<count($lobj_get_child_groups);$d++)
						{
						$del_child_entry_table=$lobj_get_child_groups[$d][child_entry_table];
						$delete_from_child_group_table="delete from {$del_child_entry_table} where login_cnt={$login_cnt}";
						$delete_from_child_group_table =  $aobj_context->mobj_db->Execute($delete_from_child_group_table);
						}
					 	$get_parent_data="select * from {$group_table_name}
								where ref_s_ref_data_code={$internal_code}";
								$lobj_get_parent_data = $aobj_context->mobj_db->GetAll($get_parent_data);
						for($limit=0;$limit<count($lobj_get_parent_data);$limit++)
						{
							$insert_into_parent_entry_table="insert into {$entry_table_name} 
							(internal_code,login_cnt,group_int_code,{$elements})
							select 0,{$login_cnt},internal_code,{$elements} from {$group_table_name}
							where ref_s_ref_data_code={$internal_code}
							and internal_code={$lobj_get_parent_data[$limit][internal_code]} ";
							$group_insrt=$aobj_context->mobj_db->Execute($insert_into_parent_entry_table);
							 
							$last_parent_id = $aobj_context->mobj_db->Insert_ID();
									
							for($j=0;$j<count($lobj_get_child_groups);$j++)
							{
									$child_group_id=$lobj_get_child_groups[$j][internal_code];
									$child_entry_table=$lobj_get_child_groups[$j][child_entry_table];
									$child_group_table=$lobj_get_child_groups[$j][child_group_table];
									$desc_table="desc {$child_entry_table}";
									$lobj_desc_table = $aobj_context->mobj_db->GetAll($desc_table);
									$child_elements='';
									foreach($lobj_desc_table as $d=>$dv)
									{
										if($dv['Field']!='login_cnt' && $dv['Field']!='internal_code' && $dv['Field']!='group_int_code' &&    $dv['Field']!='ref_s_ref_data_code')
										{
										$child_elements.=$dv['Field'].',';
										}
									}
									$child_elements=substr($child_elements,0,strlen($child_elements)-1);
									$insert_into_child_entry_table="insert into {$child_entry_table} 
									(internal_code,login_cnt,group_int_code,ref_s_ref_data_code,{$child_elements})
									select 0,{$login_cnt},internal_code,{$last_parent_id},{$child_elements} 
									from {$child_group_table}
									where ref_s_ref_data_code={$lobj_get_parent_data[$limit][internal_code]}
									 ";
									$group_insrt=$aobj_context->mobj_db->Execute($insert_into_child_entry_table);
									 
									
									
								
							}
						}
						$group_details[$b]['table_name']= $group_table_name;
								$group_details[$b]['s_ref_data_code']= $internal_code;
								$group_details[$b]['group_id']= $group_id;
								$group_details[$b]['main_group_grid']= "main_group_grid_".$group_id;
								$b++;	
					 }
					 else
					 {
					 
						$insert_into_entry_table="insert into {$entry_table_name} 
						(internal_code,login_cnt,group_int_code,{$elements})
						select 0,{$login_cnt},internal_code,{$elements} from {$group_table_name}
						where ref_s_ref_data_code={$internal_code}";
						$group_insrt=$aobj_context->mobj_db->Execute($insert_into_entry_table);
						$group_details[$b]['table_name']= $group_table_name;
						$group_details[$b]['s_ref_data_code']= $internal_code;
						$group_details[$b]['group_id']= $group_id;
						$group_details[$b]['main_group_grid']= "main_group_grid_".$group_id;
						 $b++;
					 }
			
		
		}
		  //print_r($group_details);
	// ###### GROUP ENTRY ENDS
	 
	$data['internal_code']=$internal_code;
	$data['meta_arr']=$meta_arr;
	$data['details']=$lobj_details;
    $data['s_ref_display']=$s_ref_display;     
    $data['group_details']=$group_details;     
    $data['edit_right']=$edit_right;     
  
    if( ($meta_arr))
      echo $aobj_context->mobj_output->ToJSONEnvelope($data,0,"success"); 
    else
      echo $aobj_context->mobj_output->ToJSONEnvelope($data,-1,"Failure");
    return;
  }
function getEditRights($aobj_context,$schema_id, $created_by_id)
{
			$edit_right=1;
			session_start();
				$user_type=$_SESSION['user_type'];
				$user_id=$_SESSION['user_id'];
				$user_dept=$_SESSION['user_dept'];
				if(strtolower($user_type)!="admin")
				{
				$get_rights="select   is_edit,is_edit_group_records,is_edit_dep_records,is_edit_all_records
						from user_rights where ref_s_sysdb_code={$user_id}
						and module_id={$schema_id}";
						 
					 $obj_get_rights = $aobj_context->mobj_db->GetRow($get_rights);	
					 $own=$obj_get_rights[is_edit];
					 $group=$obj_get_rights[is_edit_group_records];
					 $dep=$obj_get_rights[is_edit_dep_records];
					 $all=$obj_get_rights[is_edit_all_records];
					if(strtolower($user_type)=='admin' || $all=='1')
					{
					$edit_right=1;
					}
					else if($dep=='1')//checks for Department Records Only
					 {
							$get_users_of_department="select GROUP_CONCAT(ref_user_code) as dep_users
								from dept_user_mapping where ref_dept_code={$user_dept}
								and ref_user_code={$created_by_id}";
							 $obj_u_dep = $aobj_context->mobj_db->GetRow($get_users_of_department);	
							  if($obj_u_dep)
							  	$edit_right=1;else $edit_right=0;						  
					}
					else if($own=='0')
					{
					$edit_right=0;
					}
					else if($own=='1' && $dep=='0') //checks for Own Records Only
					 {
						if($created_by_id==$user_id)
						$edit_right=1;
						else $edit_right=0;
						 $get_own_created_by_id="select created_by from {$table} 
											where internal_code in ({$lstr_ids})";
						 $obj_get_own_created_by_id = $aobj_context->mobj_db->GetRow($get_own_created_by_id);
					}
						 
				}
return $edit_right;				
}
function getFieldName($aobj_context)
{
		$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
		$internal_code = $aobj_context->mobj_data["internal_code"];
		$table_id = $aobj_context->mobj_data["table_id"];
		$table = "module_{$table_id}";
		$field_name = $aobj_context->mobj_data["field_name"];
		$schema_id = $aobj_context->mobj_data["schema_id"];
		$inputboxid = $aobj_context->mobj_data["inputboxid"];
		//to get the ref_display_names Starts
		$get_ref_display_table="select s.value,su.internal_code as field_id,
			ifnull(ref.ref_module_code,0) as ref_module_code,mmc.field_id as mmc_field_id,
			if(s.value='Meta',concat('module_',ref.ref_s_user_schema_code),
			concat('module_',ref.ref_s_user_schema_code,'_details')) as table_name,
			if(s.value='Meta',concat('m_',ref.ref_s_user_schema_code,'_ele_',su.source_field),
			su.source_field) as field_name
			,su.source_field from s_user_schema_elements su 
			inner join s_user_schema_elements ref on ref.internal_code=su.source_field
			inner join s_ref_type s on s.internal_code=ref.s_ref_type_meta
			left join module_meta_columns mmc on mmc.module_id=ref.ref_module_code
			where su.ref_s_user_schema_code={$schema_id} and su.linked_field={$inputboxid}";
			
		$lobj_get_ref_display_table = $aobj_context->mobj_db->GetAll($get_ref_display_table);
		//echo $get_ref_display_table;
		$s_ref_display[]='';
		for($k=0;$k<count($lobj_get_ref_display_table);$k++)
		{		
			if($lobj_get_ref_display_table[$k][value]=='Meta')
			{
				if($lobj_get_ref_display_table[$k][ref_module_code]=='0')
				{
				$get_ref_display_val="select internal_code,".$lobj_get_ref_display_table[$k][field_name]." as value,
				concat('details_','".$lobj_get_ref_display_table[$k][field_id]."') as field_id from ".$lobj_get_ref_display_table[$k][table_name]." where internal_code={$internal_code}";
				$lobj_get_ref_display_val = $aobj_context->mobj_db->GetRow($get_ref_display_val);
				$s_ref_display[$k]['value']=$lobj_get_ref_display_val['value'];
				$s_ref_display[$k]['field_id']=$lobj_get_ref_display_val['field_id'];
				}
				else
				{
				$base_table=$lobj_get_ref_display_table[$k][table_name];
				$join_table="module_".$lobj_get_ref_display_table[$k][ref_module_code];
				$get_ref_display_val="select 
					b.internal_code,
					concat({$lobj_get_ref_display_table[$k][mmc_field_id]}) as value,
				concat('details_','{$lobj_get_ref_display_table[$k][field_id]}') as field_id 
				from {$base_table} b
				left join {$join_table} j on b.{$lobj_get_ref_display_table[$k][field_name]}=j.internal_code
				where b.internal_code={$internal_code}";
				$lobj_get_ref_display_val = $aobj_context->mobj_db->GetRow($get_ref_display_val);
				//echo $get_ref_display_val;
				$s_ref_display[$k]['value']=$lobj_get_ref_display_val['value'];
				$s_ref_display[$k]['field_id']=$lobj_get_ref_display_val['field_id'];
				}
			 
		 	}
		}// ref_display_names Ends
		
		// OLD LOGIC
		/* $pos = strpos($field_name, ',');
		if($pos===false)
		{
		$get_data="select internal_code,{$field_name}  as name 
		from {$table}  where internal_code='".$internal_code."'";
		}
		else
		{
		$field_value= explode(',',$field_name);					 
		$get_data="select internal_code,concat({$field_value[0]},'-',{$field_value[1]})  as name 
		from {$table}  where internal_code='".$internal_code."'";
		} */	
		$get_key_fields="select field_id from module_meta_columns where table_name='{$table}'";
		$lobj_get_key_fields = $aobj_context->mobj_db->GetRow($get_key_fields);
		$get_data="select internal_code,concat({$lobj_get_key_fields[field_id]})  as name 
		from {$table}  where internal_code='{$internal_code}'";
		$lobj_rs = $aobj_context->mobj_db->GetRow($get_data);
	 //echo $get_data;
		$arr[0]=$lobj_rs;
		$arr[1]=$s_ref_display;
		$select_on_exit_event="select ifnull(on_exit,0) as on_exit
					from s_user_schema_elements where internal_code={$inputboxid}";
		$lobj_select_on_exit_event = $aobj_context->mobj_db->GetRow($select_on_exit_event);
		$arr['on_exit_event']=$lobj_select_on_exit_event;
		if(count($lobj_rs) > 0)
		echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success");
		else
		echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		return;
}
function getGroupRefDetails($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
		$name = $aobj_context->mobj_data["name"];
		$ele_id = $aobj_context->mobj_data["ele_id"];
		$field_id = $aobj_context->mobj_data["field_id"];
		  
		$get_schema_id="select  ref_module_code,ifnull(on_exit,'') as on_exit 
		from s_user_schema_elements where internal_code = {$ele_id}";
	 	$lobj_rs = $aobj_context->mobj_db->GetRow($get_schema_id);
		$on_exit_function=$lobj_rs['on_exit'];
		$get_key_field="select table_name,field_id,field_id1,field_id2 from module_meta_columns
							where module_id={$lobj_rs[ref_module_code]}";
			$lobj_get_key_field = $aobj_context->mobj_db->GetRow($get_key_field);				
			 $search_field_id=	$lobj_get_key_field[field_id];
			 $table_name=	$lobj_get_key_field[table_name];
			 $field_id1=	$lobj_get_key_field[field_id1];
			 $field_id2=	$lobj_get_key_field[field_id2];
			 if(!empty($field_id2))
			 $field_2_cond=" or {$field_id1} like '%{$field_id2}%' ";
			
			$get_row_value="select '{$field_id}'  as field_id,internal_code,'{$on_exit_function}' as on_exit
				  from {$table_name}
			where (concat({$search_field_id}) like '%{$name}%' {$field_2_cond}) limit 1";
			$lobj_get_row_value = $aobj_context->mobj_db->GetRow($get_row_value);
 			//echo $get_row_value;
		if(count($lobj_get_row_value) > 0)
		echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_get_row_value,0,"success");
		else
		echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_get_row_value,-1,"Failure");
		return;
}
function getReferenceNameForLovForIntCode($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
		$ele_id = $aobj_context->mobj_data["ele_id"];
		$int_code = $aobj_context->mobj_data["int_code"];
		$get_schema_id="select  ref_module_code 
		from s_user_schema_elements where internal_code = {$ele_id}";
	 	$lobj_rs = $aobj_context->mobj_db->GetRow($get_schema_id);
		$get_key_field="select table_name,field_id,field_id1,field_id2 from module_meta_columns
							where module_id={$lobj_rs[ref_module_code]}";
			$lobj_get_key_field = $aobj_context->mobj_db->GetRow($get_key_field);				
			 $search_field_id=	$lobj_get_key_field[field_id];
			 $table_name=	$lobj_get_key_field[table_name];
			 $field_id1=	$lobj_get_key_field[field_id1];
			 $field_id2=	$lobj_get_key_field[field_id2];
			
			$get_row_value="select concat({$search_field_id}) as value,internal_code
				  from {$table_name}
			where internal_code={$int_code} limit 1";
			$lobj_get_row_value = $aobj_context->mobj_db->GetRow($get_row_value);
			// echo $get_row_value;
			
		if(count($lobj_get_row_value) > 0)
		echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_get_row_value,0,"success");
		else
		echo $aobj_context->mobj_output->ToJSONEnvelope($lobj_get_row_value,-1,"Failure");
		return;
}
function getEmpMultipleGroupDetails($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
			$table_name = $aobj_context->mobj_data["table_name"];	
			$ref_s_ref_data_code = $aobj_context->mobj_data["ref_s_ref_data_code"];
			$str_desc = "desc $table_name";
			$obj_desc=$aobj_context->mobj_db->GetAll($str_desc);
			//popudating insert command
			$insert_qry="insert into $table_name(ref_s_user_schema_code,ref_s_user_schema_group_code,ref_s_ref_data_code,";
			$id='';
			// starts from -4 since we are eeminating first 4 fields
			$i=-5;
						foreach ($obj_desc as $key=>$value)
						{
							if($value['Field']!='internal_code' && $value['Field']!='ref_s_user_schema_code' &&
							$value['Field']!='ref_s_user_schema_group_code' && $value['Field']!='ref_s_ref_data_code' &&
							$value['Field']!='login_cnt' &&
							$value['Field']!='created_by' && $value['Field']!='created_date' &&
							$value['Field']!='modified_by' && $value['Field']!='modified_date')
							{
							$ele_id=explode('ele_',$value['Field']);
							 
							$id.=$ele_id[1].",";
							$insert_qry.=$value['Field'].",";
							}
							$i++;
						}
				 
					$insert_qry.="created_by,created_date,modified_by,modified_date) values (";
					
					$schema_code=explode('user_schema_',$table_name);
					$all_code=explode('_group_',$schema_code[1]);
					$insert_qry.=$all_code[0].",".$all_code[1].",".$ref_s_ref_data_code.",";
					$id= substr($id,0,strlen($id) - 1);
					$get_name="select su.internal_code,name,value as Type,is_read_only,default_value,optional,su.ref_module_code,list_of_values,linked_field,source_field,suffix,width*9 as width from 
						s_user_schema_elements su left join  s_ref_type s on s.internal_code=su.data_type where su.internal_code in (".$id.") order by su.internal_code";
			  // echo $get_name;
			 $lobj_get_name =  $aobj_context->mobj_db->GetAll($get_name);
			//sends Table Name for div id
			$arr['table_name'] = $table_name;
			$arr['insert_qry'] = $insert_qry;
			$arr['elements'] = $lobj_get_name;
			$arr['ref_s_ref_data_code'] = $ref_s_ref_data_code;
			if($lobj_rs) 
		{
		
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
		
		}
		 else
		{	
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		
		}
}
function getGroupDetailsRowData($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	$internal_code = $aobj_context->mobj_data["internal_code"];	 
	$group_table_name = $aobj_context->mobj_data["table_name"];
	 $group_table_name=str_ireplace("group","entry",$group_table_name);
	session_start();
	$login_cnt=	$_SESSION['login_cnt'];
	$split_data=explode("user_schema_",$group_table_name);
	$table_data=explode('_entry_',$split_data[1]);
	$schema_id=$table_data[0];
	$group_id=$table_data[1]; 
	 /* $aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
							$select_ref_module_code="select 
								GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from 
								(select  parent_group_code,ref_s_user_schema_group_code, @a:=@a+1,ref_module_code,
								concat(' left join module_',suse.ref_module_code, ' as module_',suse.ref_module_code,'_',suse.internal_code,' on module_',suse.ref_module_code,'_',suse.internal_code,'.internal_code =',suse.db_field) as join_table_name
								from s_user_schema_elements suse
								left join s_user_schema_group ug on ug.internal_code=suse.ref_s_user_schema_group_code
								where suse.ref_s_user_schema_code={$schema_id}  
								and (is_multiple_group=1 or parent_group_code<>0) 
								and (ref_s_user_schema_group_code={$group_id} or parent_group_code={$group_id}) 
								and ref_module_code>0)j";
							$obj_select_ref_module_code =  $aobj_context->mobj_db->GetRow($select_ref_module_code);
							 $join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
							// to form the fields   dynamically 
							$select_field_ids="select 
								db_field as field_id,
								su.name,t.value as data_type,
								su.ref_module_code from 
								s_user_schema_elements	su
								inner join s_ref_type t on t.internal_code=su.data_type
								left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
								where su.ref_s_user_schema_code={$schema_id} and
								( su.is_multiple_group=1  or parent_group_code<>0)
								and (ug.internal_code={$group_id} or parent_group_code={$group_id}) 
								order by su.internal_code";
								 
							$lobj_select_field_ids =  $aobj_context->mobj_db->GetAll($select_field_ids);
 							foreach($lobj_select_field_ids as $key =>$value)
							{
								if($value[data_type]=='Reference Data')
								{
								$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
								$qry=" select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,
									GROUP_CONCAT(field_name separator ',\'-\',') as field_name from 
									(select * from 
									(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
									su.ref_s_user_schema_code=s.internal_code
									inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
									left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
									where s.internal_code=$value[ref_module_code] and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
								 						 
									$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
								$fields.="concat(".$lobj_rs[field_name].") as $value[field_id]".",";
								}
								else if($value[data_type]=='Date')
								{								 
								$fields.='DATE_FORMAT('.$value[field_id].",'%d/%m/%Y') as ".$value[field_id] .",";
								}
								else
								{
								$fields.=$value[field_id].",";
								}
							}
							$fields=substr($fields,0,strlen($fields)-1);
							$get_group_details="select '{$group_table_name}' as table_name, 
								$group_table_name.internal_code,$fields from 	$group_table_name  $join_qry  
							 where $group_table_name.internal_code= $internal_code  " */;
							 
							 $get_group_details=getGroupDetailsQryForIntCode($aobj_context,$schema_id,$group_id,$internal_code);
							$lobj_group_details=  $aobj_context->mobj_db->GetRow($get_group_details);
							 
							$get_child_groups="select internal_code as group_id,
							concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name,
							concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name,
							concat('main_group_grid_',internal_code) as main_group_grid_div 
							from s_user_schema_group
							where parent_group_code={$group_id}
							and multiple=1";
							$lobj_get_child_groups=  $aobj_context->mobj_db->GetAll($get_child_groups);
							 for($h=0;$h<count($lobj_get_child_groups);$h++)
							 {
							 $entry_table=$lobj_get_child_groups[$h][entry_table_name];
							 $delete_entry_table_with_0="delete from {$entry_table}
											where ref_s_ref_data_code=0
											and login_cnt={$login_cnt}";
							$lobj_delete_entry_table_with_0=  $aobj_context->mobj_db->Execute($delete_entry_table_with_0);				
							 }
			######### REF Display#########################
		$s_ref_display=GetRefDisplayArray($aobj_context,$schema_id,$group_id,$internal_code);
		 	 $arr["parent_group"]=$lobj_group_details;
			 $arr["child_group"]=$lobj_get_child_groups;
			 $arr["s_ref_display"]=$s_ref_display;
			 
			echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
}
function getGroupDetailsQryForIntCode($aobj_context,$schema_id,$group_id,$internal_code)
{
$table_name="user_schema_{$schema_id}_entry_{$group_id}";
$aobj_context->mobj_db->execute("SET @@session.group_concat_max_len=10000");
$aobj_context->mobj_db->execute("set @a:=0");
 		$select_ref_module_code="select 
			GROUP_CONCAT(join_table_name SEPARATOR ' ') as qry from 
			(select  parent_group_code,ref_s_user_schema_group_code, @a:=@a+1,ref_module_code,
			concat(' left join module_',suse.ref_module_code, ' as module_',suse.ref_module_code,'_',suse.internal_code,' on module_',suse.ref_module_code,'_',suse.internal_code,'.internal_code =',suse.db_field) as join_table_name
			from s_user_schema_elements suse
			left join s_user_schema_group ug on ug.internal_code=suse.ref_s_user_schema_group_code
			where suse.ref_s_user_schema_code={$schema_id} 
			and (is_multiple_group=1 or parent_group_code<>0) 
			and ((ref_s_user_schema_group_code={$group_id} or (parent_group_code={$group_id} and multiple=0)) and is_grid_edit=0) 
			and ref_module_code>0)j";
		$obj_select_ref_module_code =  $aobj_context->mobj_db->GetRow($select_ref_module_code);
				
		$join_qry=(count($obj_select_ref_module_code)>0)?$obj_select_ref_module_code[qry]:'';
				
		$get_display_cols="select GROUP_CONCAT(field_name) as field_name  from 
								(select table_name,name,field_name as grid_field_name,
								if(data_type='date',concat('date_format(',field_name,',\"%d/%m/%Y\"',\") as \",field_name)
								,if((ref_module_code=0 or is_ref_module_code_lov=1),
								 field_name ,
								concat(\"concat(\",f1,f2,\") as \",field_name)))

									as field_name,
								if(ref_module_code=0,
								concat('module_',internal_code,'.',field_name ),
								concat(\"concat(\",f1,f2,\")\" )) as search_field_name
								,ref_module_code from 
								(select  s.internal_code, su.internal_code as ele_id,ifnull(is_ref_module_code_lov,0) as is_ref_module_code_lov,
								ref_module_code,concat('module_',s.internal_code) as table_name ,
								field_id,typ.value as data_type,	
								if(ifnull(field_id1,'')!='',concat('module_',ref_module_code,'_',su.internal_code,'.',field_id1),'') as f1,
								if(ifnull(field_id2,'')!='',concat(',\'-\',module_',ref_module_code,'_',su.internal_code,'.',field_id2),'') as f2,
								LCASE(REPLACE(REPLACE(REPLACE(REPLACE(su.system_name,' ','_'),'.','_'),'&','_'),'/','_')) as name
								,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,
								db_field as field_name 
								from s_user_schema s inner join s_user_schema_elements su on 
								su.ref_s_user_schema_code=s.internal_code
								inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
								inner join s_ref_type as typ on typ.internal_code=su.data_type
								left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
								left join module_meta_columns mmc on mmc.module_id=su.ref_module_code
								where s.internal_code={$schema_id} and t.value='Meta'  
								 
								and (ug.internal_code={$group_id} or (parent_group_code={$group_id} and multiple=0)) and is_grid_edit = '0'
								order by ifnull(ug.sequence,0),su.sequence,su.internal_code ) l 
								 
								 ) a ";
		$lobj_get_display_cols = $aobj_context->mobj_db->GetRow($get_display_cols);
		 
		   

$qry = " select '{$table_name}' as table_name,{$table_name}.internal_code,{$lobj_get_display_cols[field_name]}  from 
				{$table_name}  {$join_qry}
				where  {$table_name}.internal_code={$internal_code}";
	 		  
return 	$qry;		
}

function GetRefDisplayArray($aobj_context,$schema_id_ref,$group_id,$internal_code)
{
$get_ref_display_table_fields="select  ref.name,su. ref_s_user_schema_group_code,
								s.value as ref_value,s1.value as basevalue,
								concat('details_',su.internal_code) as field_id,
								if(s.value='Meta',concat('module_',ref.ref_s_user_schema_code),
								concat('module_',ref.ref_s_user_schema_code,'_details')) as table_name,
								if(s.value='Meta',concat('m_',ref.ref_s_user_schema_code,'_ele_',su.source_field),
								su.source_field) as field_name,
								if(s1.value='Meta',
								if(su. ref_s_user_schema_group_code=0,
								concat('module_',linked.ref_s_user_schema_code),
								concat('user_schema_',linked.ref_s_user_schema_code,'_entry_',
								linked.ref_s_user_schema_group_code)),
								concat('module_',linked.ref_s_user_schema_code,'_details')
								) as base_table_name,
								if(s1.value='Meta',
								if(su. ref_s_user_schema_group_code=0,
								concat('m_',linked.ref_s_user_schema_code,'_ele_',linked.internal_code),
								concat('u_',linked.ref_s_user_schema_code,'_g_',linked.ref_s_user_schema_group_code,'_ele_',
								linked.internal_code)),
								linked.internal_code) 
								as base_table_field_name 
								,su.source_field from s_user_schema_elements su 
								inner join s_user_schema_elements ref on ref.internal_code=su.source_field
								inner join s_user_schema_elements linked on linked.internal_code=su.linked_field
								inner join s_ref_type s on s.internal_code=ref.s_ref_type_meta
								inner join s_ref_type s1 on s1.internal_code=linked.s_ref_type_meta
								where su.ref_s_user_schema_code={$schema_id_ref}
								and su. ref_s_user_schema_group_code={$group_id}";
			  
			$lobj_get_ref_display_table_fields=  $aobj_context->mobj_db->GetAll($get_ref_display_table_fields);
			$k=0;
			$s_ref_display[]='';
			foreach($lobj_get_ref_display_table_fields as $k=>$v)
			{
				//if ref module is of type meta seacch the value in meta table by passing the id as below
				if($v[ref_value]=='Meta')
				{
				$obj_get_base_id='';
					if($v[basevalue]=='Meta')
					{
					//need to get the id stored for this element and use that id as internal_code in next query
					$get_base_id="select ".$v[base_table_field_name]." as id
						from " .$v[base_table_name]. " where 
						internal_code={$internal_code}";
					 
					$obj_get_base_id=$aobj_context->mobj_db->Getrow($get_base_id);

					//echo  $get_base_id;
					$get_ref_meta_value="select ".$v[field_name]. " as value from ".$v[table_name]." where 
					internal_code=".$obj_get_base_id[id];
					$obj_get_ref_meta_value=$aobj_context->mobj_db->Getrow($get_ref_meta_value);
					 
					$s_ref_display[$k]['value']=$obj_get_ref_meta_value['value'];
					$s_ref_display[$k]['field_id']=$v[field_id];
					$k++;
					}
					else if($v[basevalue]=='User')
					{
					//need to get the id stored for this element and use that id as internal_code in next query
					$get_base_id="select value as id from " .$v[base_table_name]. " where 
						ref_s_module_code={$internal_code} and ref_s_user_schema_elements_code=".$v[base_table_field_name];
						
					$obj_get_base_id=$aobj_context->mobj_db->Getrow($get_base_id);	
					$get_ref_meta_value="select ".$v[field_name]. " as value from ".$v[table_name]." where 
					internal_code=".$obj_get_base_id[id];
					 //echo $get_ref_meta_value;
					$obj_get_ref_meta_value=$aobj_context->mobj_db->Getrow($get_ref_meta_value);
					$s_ref_display[$k]['value']=$obj_get_ref_meta_value['value'];
					$s_ref_display[$k]['field_id']=$v[field_id];
					$k++;
					}
				}
				else if($v[ref_value]=='User')
				{
				 
				$obj_get_base_id='';
					if($v[basevalue]=='Meta')
					{
					//need to get the id stored for this element and use that id as internal_code in next query
					$get_base_id="select ".$v[base_table_field_name]." as id from " .$v[base_table_name]. " where 
						internal_code={$internal_code}";
					$obj_get_base_id=$aobj_context->mobj_db->Getrow($get_base_id);	
					
					$get_ref_usr_value="select value  from ".$v[table_name]." where 
					ref_s_module_code=  {$internal_code} and ref_s_user_schema_elements_code =".$obj_get_base_id[id];
					$obj_get_ref_usr_value=$aobj_context->mobj_db->Getrow($get_ref_usr_value);
					$s_ref_display[$k]['value']=$obj_get_ref_meta_value['value'];
					$s_ref_display[$k]['field_id']=$v[field_id];
					$k++;
					}
					else if($v[basevalue]=='User')
					{
					//need to get the id stored for this element and use that id as internal_code in next query
					$get_base_id="select value as id from " .$v[base_table_name]. " where 
						ref_s_module_code={$internal_code} and ref_s_user_schema_elements_code=".$v[base_table_field_name];
						 
				 	$obj_get_base_id=$aobj_context->mobj_db->Getrow($get_base_id);
					 
						$get_ref_usr_value="select value  from ".$v[table_name]." where 
						ref_s_module_code=  {$obj_get_base_id[id]} and ref_s_user_schema_elements_code =".$v[field_name];
						 
						$obj_get_ref_usr_value=$aobj_context->mobj_db->Getrow($get_ref_usr_value);
						 
						$s_ref_display[$k]['value']=$obj_get_ref_usr_value['value'];
						$s_ref_display[$k]['field_id']=$v[field_id];
						$k++;
					}
				
				 
				} 
			}
		 
	return 	$s_ref_display;	
}
function deleteChildTableZeroValues($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$group_id = $aobj_context->mobj_data["group_id"];	 
$get_child_groups="select internal_code as group_id,
							concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name,
							concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name,
							concat('main_group_grid_',internal_code) as main_group_grid_div 
							 
							from s_user_schema_group
							where parent_group_code={$group_id}";
							$lobj_get_child_groups=  $aobj_context->mobj_db->GetAll($get_child_groups);
							 $b=0;
							 for($h=0;$h<count($lobj_get_child_groups);$h++)
							 {
							 $entry_table=$lobj_get_child_groups[$h][entry_table_name];
							 $group_id=$lobj_get_child_groups[$h][group_id];
							 $group_table_name=$lobj_get_child_groups[$h][group_table_name];
							 $delete_entry_table_with_0="delete from {$entry_table}
											where ref_s_ref_data_code=0
											and login_cnt={$login_cnt}";
								$lobj_delete_entry_table_with_0=  $aobj_context->mobj_db->Execute($delete_entry_table_with_0);				
							 $group_details[$b]['table_name']= $group_table_name;
							$group_details[$b]['s_ref_data_code']= 0;
							$group_details[$b]['group_id']= $group_id;
							$group_details[$b]['main_group_grid']= "main_group_grid_".$group_id;
							$b++;	
							 }
 $arr["group_details"]=$group_details;
 echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success");							 
}
function addSchemaGroupDetailsBeforeUPdatingUpdatelogic($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
session_start();
include_once("/JSON.php"); 
    $json = new Services_JSON();
			$del_id = $aobj_context->mobj_data["del_int_code"];	 
			$is_update_visible_field = $aobj_context->mobj_data["is_update_visible_field"];	 
			$insert_qry = $aobj_context->mobj_data["insert_qry"];
			$login_ctr = $aobj_context->mobj_data["login_ctr"];	 
			$validation = $aobj_context->mobj_data["validation"];	 
			$ref_s_ref_data_code = $aobj_context->mobj_data["ref_s_ref_data_code"];	 
			$tab_name = $aobj_context->mobj_data["table_name"];	 
			$user_id=$_SESSION['user_id'];
			$values = stripcslashes($aobj_context->mobj_data["values"]);
			$values.=$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()";	
			$_SESSION['error_flag']=1;
			$group_int_code=0;
			$group_details_split=explode("_",$tab_name);
			$schema_id=$group_details_split[2];
			$group_id=$group_details_split[4];
	
	$lstr_save_schema_details_arr = stripslashes($aobj_context->mobj_data["save_schema_group_details_arr_jsn_text"]);
	$mobj_jsondata = $json->decode($lstr_save_schema_details_arr);
	$larr_save_data = get_object_vars($mobj_jsondata); 
	foreach($larr_save_data as $pk=>$pv)
	{
		$insert_cols.=$pv->group_field_id.",";
		$insert_col_values.="'".addslashes($pv->group_field_id_val)."',";
		$update_cond.=$pv->group_field_id."='".addslashes($pv->group_field_id_val)."',";
	}
	$insert_cols=substr($insert_cols,0,strlen($insert_cols)-1);
	$insert_col_values=substr($insert_col_values,0,strlen($insert_col_values)-1);
	$update_cond.=" modified_by={$user_id}, modified_date=now() ";
	$update_qry=" update {$tab_name} set {$update_cond} where internal_code={$del_id}";
	 
	$group_insert_qry="insert into {$tab_name}
					(login_cnt,
					group_int_code,
					ref_s_user_schema_code,
					ref_s_user_schema_group_code,
					ref_s_ref_data_code,{$insert_cols} 
					,created_by,created_date,modified_by,modified_date)
					values(
					{$login_ctr},{$group_int_code},{$schema_id},{$group_id},{$ref_s_ref_data_code},
					{$insert_col_values},
					{$user_id},
					now(),
					{$user_id},
					now() 
					)";
		 	 
	if (function_exists('validateGroupDetails'))
	{
	     validateGroupDetails($aobj_context); 
	}
	if($_SESSION['error_flag']==1)
	{
		if($del_id>0)
		{
		$old_data_arr="";
		$select_group_int_code="select * from {$tab_name} where internal_code={$del_id}";
		$lobj_select_group_int_code =  $aobj_context->mobj_db->GetRow($select_group_int_code);
		foreach( $lobj_select_group_int_code as $k=>$v)
		$old_data_arr[$k]=$v;
		$group_int_code=empty($lobj_select_group_int_code[group_int_code])?0:($lobj_select_group_int_code[group_int_code]);
		$del_qry="delete from $tab_name where internal_code=$del_id";	
		$del_obj=$aobj_context->mobj_db->Execute($del_qry); 
		}
		$insert_qry =str_replace("modified_date) values (","modified_date)values ({$del_id},{$login_ctr},{$group_int_code}, ",$insert_qry);
			
		$lst_insert=$insert_qry .$ref_s_ref_data_code.",".$values.")" ;	
 
		$insert_obj=$aobj_context->mobj_db->Execute($lst_insert); 
 	 
		$last_inserted_id = $aobj_context->mobj_db->Insert_ID();
		// To Update the Hidden Fields
		if($is_update_visible_field && $del_id>0)
		{
		$group_id_obj=explode("_",$tab_name);
		$group_id=$group_id_obj[4];
		
			$select_db_field="select db_field from s_user_schema_elements where 
				 ref_s_user_schema_group_code={$group_id}
				  and is_visible=0";
			$lobj_select_db_field = $aobj_context->mobj_db->GetAll($select_db_field); 
			$update_cond="";
			foreach($lobj_select_db_field  as $ku=>$kv)
			{
			$update_cond.="{$kv[db_field]}='{$old_data_arr[$kv[db_field]]}',";
			}
			$update_cond=substr($update_cond,0,strlen($update_cond)-1);
			$update_old_val="update {$tab_name} set 
					{$update_cond} where internal_code={$del_id}";
			$lobj_update_old_val = $aobj_context->mobj_db->Execute($update_old_val); 
		 }
		 
	 
		 if(!$last_inserted_id)
		 {
			$get_max_int_code="select max(internal_code)  as code from {$tab_name} 
			where login_cnt={$login_ctr}";
			$lobj_get_max_int_code =  $aobj_context->mobj_db->GetRow($get_max_int_code);
			$last_inserted_id = $lobj_get_max_int_code[code];
			if($del_id>0) $last_inserted_id = $del_id;
		  }
		#TO insert the Parent Group Internal Code in Child group Code Starts
		$get_group_id=explode("_",$tab_name);
		$group_id=$get_group_id[4];
		 $get_child_groups="select internal_code,
				concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as child_table
				from s_user_schema_group
				where parent_group_code={$group_id} and multiple=1";
		 $lobj_get_child_groups =  $aobj_context->mobj_db->GetAll($get_child_groups);
		 if($lobj_get_child_groups)
		 {
			for($j=0;$j<count($lobj_get_child_groups);$j++)
				{
					$child_group_table=$lobj_get_child_groups[$j][child_table];
					$update_ref_data_code="update {$child_group_table}
											set ref_s_ref_data_code={$last_inserted_id}
											where ref_s_ref_data_code=0
											and login_cnt={$login_ctr}";
					$insert_update_ref_data_code=$aobj_context->mobj_db->Execute($update_ref_data_code); 
			 				
				}
		 }
		
		if(mysql_error()!='')
		 { $pos=strpos(mysql_error(),'Duplicate');
			 if($pos>=0)
			 {
				$arr[0]='Check for Unique values'.mysql_error();
				echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
				 return;
			 }  
		 }
		 
		 if (function_exists('postsavegroupdetails'))
			{
			     postsavegroupdetails($aobj_context,$last_inserted_id); 
			}
		 
		 if($insert_obj) 
		{
			if($del_id>0)
			$arr[0]='Group Details updated Successfully';
			else
			$arr[0]=' Group Details Inserted Successfully';
			$arr[1]=$tab_name;
			$arr['last_insert_id']=$last_inserted_id;
		    echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
		}
		else
		{	
		$arr[0]='Inserted Failed';
		$arr[1]=$tab_name;
		$arr['last_insert_id']=$last_inserted_id;
		echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		}
	}		
}
function addSchemaGroupDetails($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	session_start();
	include_once("/JSON.php"); 
	$json = new Services_JSON();
	 
			$del_id = $aobj_context->mobj_data["del_int_code"];	 
			$is_update_visible_field = $aobj_context->mobj_data["is_update_visible_field"];	 
			$insert_qry = $aobj_context->mobj_data["insert_qry"];
			$login_ctr = $aobj_context->mobj_data["login_ctr"];	 
			$validation = $aobj_context->mobj_data["validation"];	 
			$ref_s_ref_data_code = $aobj_context->mobj_data["ref_s_ref_data_code"];	 
			$tab_name = $aobj_context->mobj_data["table_name"];	 
			$user_id=$_SESSION['user_id'];
			$values = stripcslashes($aobj_context->mobj_data["values"]);
			$values.=$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now()";	
			$_SESSION['error_flag']=1;
			$group_int_code=0;
			$group_details_split=explode("_",$tab_name);
			$schema_id=$group_details_split[2];
			$group_id=$group_details_split[4];
	
	$lstr_save_schema_details_arr = stripslashes($aobj_context->mobj_data["save_schema_group_details_arr_jsn_text"]);
	$mobj_jsondata = $json->decode($lstr_save_schema_details_arr);
	$larr_save_data = get_object_vars($mobj_jsondata); 
	foreach($larr_save_data as $pk=>$pv)
	{
 
		$insert_cols.=$pv->group_field_id.",";
		$insert_col_values.="'".addslashes($pv->group_field_id_val)."',";
		$update_cond.=$pv->group_field_id."='".addslashes($pv->group_field_id_val)."',";
	}
	$insert_cols=substr($insert_cols,0,strlen($insert_cols)-1);
	$insert_col_values=substr($insert_col_values,0,strlen($insert_col_values)-1);
	$update_cond.=" modified_by={$user_id}, modified_date=now() ";
	$update_qry=" update {$tab_name} set {$update_cond} where internal_code={$del_id}";
	 
	$group_insert_qry="insert into {$tab_name}
					(login_cnt,
					group_int_code,
					ref_s_user_schema_code,
					ref_s_user_schema_group_code,
					ref_s_ref_data_code,{$insert_cols} 
					,created_by,created_date,modified_by,modified_date)
					values(
					{$login_ctr},{$group_int_code},{$schema_id},{$group_id},{$ref_s_ref_data_code},
					{$insert_col_values},
					{$user_id},
					now(),
					{$user_id},
					now() 
					)";
		 
	if (function_exists('validateGroupDetails'))
	{
	     validateGroupDetails($aobj_context); 
	}
	if($_SESSION['error_flag']==1)
	{
		if($del_id=='0')
		{
		$insert_obj=$aobj_context->mobj_db->Execute($group_insert_qry); 
		$last_inserted_id = $aobj_context->mobj_db->Insert_ID();
		}
		else
		{
		$insert_obj=$aobj_context->mobj_db->Execute($update_qry);
       // mysql_error();
		//echo $update_qry;
//die();		
		$last_inserted_id=$del_id;
		}
		 
		 
		#TO insert the Parent Group Internal Code in Child group Code Starts
		$get_group_id=explode("_",$tab_name);
		$group_id=$get_group_id[4];
		 $get_child_groups="select internal_code,
				concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as child_table
				from s_user_schema_group
				where parent_group_code={$group_id} and multiple=1";
		 $lobj_get_child_groups =  $aobj_context->mobj_db->GetAll($get_child_groups);
		 if($lobj_get_child_groups)
		 {
			for($j=0;$j<count($lobj_get_child_groups);$j++)
				{
					$child_group_table=$lobj_get_child_groups[$j][child_table];
					$update_ref_data_code="update {$child_group_table}
											set ref_s_ref_data_code={$last_inserted_id}
											where ref_s_ref_data_code=0
											and login_cnt={$login_ctr}";
					$insert_update_ref_data_code=$aobj_context->mobj_db->Execute($update_ref_data_code); 
			 				
				}
		 }
		
		if(mysql_error()!='')
		 { $pos=strpos(mysql_error(),'Duplicate');
			 if($pos>=0)
			 {
				$arr[0]='Check for Unique values'.mysql_error();
				echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
				 return;
			 }  
		 }
		 
		 if (function_exists('postsavegroupdetails'))
			{
			     postsavegroupdetails($aobj_context,$last_inserted_id); 
			}
		 
		 if($insert_obj) 
		{
			if($del_id>0)
			$arr[0]='Group Details updated Successfully';
			else
			$arr[0]=' Group Details Inserted Successfully';
			$arr[1]=$tab_name;
			$arr['last_insert_id']=$last_inserted_id;
		    echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
		}
		else
		{	
		$arr[0]='Inserted Failed';
		$arr[1]=$tab_name;
		$arr['last_insert_id']=$last_inserted_id;
		echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		}
	}		
}
function deleteSchemaGroupDetails($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
			
			$table_name = $aobj_context->mobj_data["table_name"];	 
			$ids = $aobj_context->mobj_data["ids"];
			$del_qry="delete from $table_name  where internal_code in ($ids)";
 $delete_obj=$aobj_context->mobj_db->Execute($del_qry); 
 if($delete_obj) 
		{
		$arr[0]='Deleted Successfully';
		$arr[1]=$table_name;
	
		
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
		
		}
		 else
		{	
		$arr[0]='Deletion Failed';
		$arr[1]=$table_name;
		 
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		
		}
}
function uploadGroupCsvFileIntoDB($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	$table_name = $aobj_context->mobj_data["table_name"];
	$s_ref_data_code = $aobj_context->mobj_data["s_ref_data_code"];
	$schema_details=explode("_",$table_name);
	 
	$ref_s_user_schema_code=$schema_details[2];
	$ref_s_user_schema_group_code=$schema_details[4];
	$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
	$main_src=$main_src_obj[1];
	$root_file_name=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/imported_files/";
	$root_file_name = $root_file_name . $_SESSION['user_id']."_".basename( $_FILES['uploadedfile']['name']); 
$failed=0;
 
			$str_desc = "desc $table_name";
			 
			$obj_desc=$aobj_context->mobj_db->GetAll($str_desc);
				foreach ($obj_desc as $key=>$value)
				{
					if($value['Field']!='internal_code' && $value['Field']!='ref_s_user_schema_code' &&
					$value['Field']!='ref_s_user_schema_group_code' && $value['Field']!='ref_s_ref_data_code')
					{
					$ele_id=explode('ele_',$value['Field']);
					$id.=$ele_id[1].",";
					$insert_qry.=$value['Field'].",";
					}
					$i++;
				}
		 			 $id= substr($id,0,strlen($id) - 1);
						$get_name="select su.internal_code,
						concat('u_',ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',su.internal_code) as field_id,name,
						if(su.ref_module_code!=0,concat('module_',su.ref_module_code),'') as ref_table_name,value as Type,is_read_only,default_value,optional,su.ref_module_code,list_of_values,linked_field,source_field,suffix,width*9 as width from 
						s_user_schema_elements su left join  s_ref_type s on s.internal_code=su.data_type where su.internal_code in (".$id.") order by su.internal_code";
			  
			 $lobj_get_name =  $aobj_context->mobj_db->GetAll($get_name);
			 
 
        if(isset($_FILES['uploadedfile']['name']) && $_FILES['uploadedfile']['name'] != '')         
        { 
		 	 
		  if(move_uploaded_file($_FILES['uploadedfile']['tmp_name'],$root_file_name))
		  {
		   $handle = fopen($root_file_name,"r"); 
		    $ldata1  = fgetcsv($handle,1024,",");
	 		$i=0;
			foreach ($lobj_get_name as $key=>$value)
			{
				$cond.="'".$value[name]."' == '".$ldata1[$i]. "'"."&&"; 
				if(strtolower($value[name]) == strtolower($ldata1[$i]))
				{
				$field_ids.=$value[field_id].",";
				$i++;
				$failed=0;
				}
				else
				{
				
				$error_data.= $value[name] ." and ".$ldata1[$i]."are not matchng";
				$error_data.="\n";
				header("Content-type:application/txt");
				header("Content-Disposition:attachment;filename=error_log");  
				echo $error_data;
				return;
				$failed=1;
				break;
				}
			}
				$field_ids=substr($field_ids,0,strlen($field_ids)-1);
				
				$first_ins_qry="\$insert_qry=\"insert into {$table_name} (ref_s_user_schema_code,
						ref_s_user_schema_group_code,
						ref_s_ref_data_code,{$field_ids})
						values
						({\$ref_s_user_schema_code},{\$ref_s_user_schema_group_code},{\$s_ref_data_code},";
			if($failed==0)
			{
			$data_str.="<?php while ((\$data = fgetcsv(\$handle,1024,\",\")) !== FALSE) {	
	                if(!empty(\$data))
	                {";
			$k=0;
			 
			 foreach ($lobj_get_name as $key=>$value)
			{
		
			if($value[ref_module_code]!=0)
			{
			$qry="  select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where s.internal_code= $value[ref_module_code] and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
	 
			$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
			
			$cond=explode(",",$lobj_rs[field_name]);
			
			 $data_str.="\$where_cond1=\"{$cond[0]} like '%{\$data[$k]}%'\";";
			//$where_cond1= $data[".$k."] ;
			
			 
			if(!empty($cond[1]))
			$data_str.="\$where_cond2=\" or  {$cond[1]} like '%{\$data[$k]}%'\";";
			
			$data_str.="\$select_ref_data_{$value[ref_module_code]}=\"select internal_code from {$value[ref_table_name]} where {\$where_cond1}  {\$where_cond2}\";";
			 $data_str.="\$obj_select_ref_data_{$value[ref_module_code]} =  \$aobj_context->mobj_db->GetRow(\$select_ref_data_{$value[ref_module_code]});";
			 $data_str.="$".$value[field_id]."  = \$obj_select_ref_data_{$value[ref_module_code]}[internal_code];";
			$insert_value.="'{\$".$value[field_id]."}',";
			$k++;
			}
			else
			{
			$data_str.="$".$value[field_id]."  = addslashes(\$data[{$k}]);";
			$insert_value.="'{\$".$value[field_id]."}',";
			$k++;
			}
			}
					$insert_value=substr($insert_value,0,strlen($insert_value)-1);
				$data_str.=$first_ins_qry.$insert_value.")\";";
 							$data_str.="echo \$insert_qry;";
 							$data_str.="	\$obj_qry =  \$aobj_context->mobj_db->Execute(\$insert_qry);";
			$data_str.=" }}  ?>";
			 
			 
				$tmp_root_file_name=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/imported_files/upload_report_qry_".$_SESSION['user_id']."_.php";
		 
		file_put_contents($tmp_root_file_name,$data_str);
		 
require($tmp_root_file_name);
			 

			}
			 unlink($tmp_root_file_name);
			unlink($root_file_name); 
		 /*   echo "The file ".  basename( $_FILES['uploadedfile']['name']). 
			" has been uploaded"; */
			 //echo "<script type='text/javascript'> window.close();</script>";
		/* 	header("Content-type:application/csv");
			header("Content-Disposition:attachment;filename=".basename($root_file_name)); */
			//readfile($root_file_name);
			//echo $root_file_name;
		  }
          else
		  echo "faied";
		}	 
		
     //echo "<script type='text/javascript'> getEmpMultipleGroupDetails('{$table_name}');</script>";
}
function uploadGroupXlsFileIntoDB($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	$table_name = $aobj_context->mobj_data["table_name"];
	$s_ref_data_code = $aobj_context->mobj_data["s_ref_data_code"];
	$schema_details=explode("_",$table_name);
	 
	$ref_s_user_schema_code=$schema_details[2];
	$ref_s_user_schema_group_code=$schema_details[4];
	$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
	$main_src=$main_src_obj[1];
	$root_file_name=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/imported_files/";
	$root_file_name = $root_file_name . $_SESSION['user_id']."_".basename( $_FILES['uploadedfile']['name']); 
$failed=0;
  
/* $array1 = array("a" => "green", "b" => "brown");
$array2 = array("a" => "green", "b"=>"yellow");
$result = array_diff_assoc($array1, $array2);
print_r($result); */
 
			$str_desc = "desc $table_name";
			 
			$obj_desc=$aobj_context->mobj_db->GetAll($str_desc);
				foreach ($obj_desc as $key=>$value)
				{
					if($value['Field']!='internal_code' && $value['Field']!='ref_s_user_schema_code' &&
					$value['Field']!='ref_s_user_schema_group_code' && $value['Field']!='ref_s_ref_data_code'&&
					$value['Field']!='created_by' && $value['Field']!='created_date'&&
					$value['Field']!='modified_by' && $value['Field']!='modified_date')
					{
					$ele_id=explode('ele_',$value['Field']);
					$id.=$ele_id[1].",";
					$insert_qry.=$value['Field'].",";
					}
					$i++;
				}
		 			 $id= substr($id,0,strlen($id) - 1);
						$get_name="select su.internal_code,
						concat('u_',ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',su.internal_code) as field_id,name,
						if(su.ref_module_code!=0,concat('module_',su.ref_module_code),'') as ref_table_name,value as Type,is_read_only,default_value,optional,su.ref_module_code,list_of_values,linked_field,source_field,suffix,width*9 as width,is_unique from 
						s_user_schema_elements su left join  s_ref_type s on s.internal_code=su.data_type where su.internal_code in (".$id.") order by su.internal_code";
			 
			 $lobj_get_name =  $aobj_context->mobj_db->GetAll($get_name);
			 
 
        if(isset($_FILES['uploadedfile']['name']) && $_FILES['uploadedfile']['name'] != '')         
        {
	 
		if(move_uploaded_file($_FILES['uploadedfile']['tmp_name'],$root_file_name))
		  {
		  
		 $reader_path=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/Excel_reader/reader.php";
		require_once $reader_path;
		$data = new Spreadsheet_Excel_Reader();
		$data->setOutputEncoding('CP1251');
		$data->read($root_file_name);
		error_reporting(E_ALL ^ E_NOTICE);
	 
		 
		for ($i = 1; $i <=1; $i++) 
				{
					for ($j = 1; $j <= $data->sheets[0]['numCols']; $j++) {
						$xls_header_columns[$j]=trim(strtolower($data->sheets[0]['cells'][$i][$j]));
					}					
				}
					$l=1;	 
		foreach ($lobj_get_name as $key=>$value)
			{
			$db_header_columns[$l]=strtolower($value[name]);
			$field_ids.=$value[field_id].",";
			$l++;
			}
			$result = array_diff($xls_header_columns, $db_header_columns);
			 
			 if(!empty($result))
			{
			$error_data='';
			foreach($result as $key=>$value)
			{
			
			$error_data.="\"".strtoupper($value)."\" column are not matching with DB Column";
			$error_data.="\n";
			}
			 
			header("Content-type:application/txt");
			header("Content-Disposition:attachment;filename=error_log");  
			//readfile($root_file_name);
			echo $error_data;
			return; 
			}  
		 $field_ids=substr($field_ids,0,strlen($field_ids)-1);
				$first_ins_qry="\$insert_qry=\"insert into {$table_name} (ref_s_user_schema_code,
						ref_s_user_schema_group_code,
						ref_s_ref_data_code,{$field_ids},created_by,created_date,modified_by,modified_date)
						values
						({\$ref_s_user_schema_code},{\$ref_s_user_schema_group_code},{\$s_ref_data_code},";
				//$update_qry="update {$table_name} set "		
				$data_str="<?php \n";
				$data_str.="\$s_ref_error_flag=0; \n";
				$data_str.="\$original_value=''; \n";
				$data_str.="\$down_load_value=''; \n";
				$data_str.="\$header_value='Following Records are not inserted'.\"\\n\"; \n";
			 	$data_str.="for (\$i = 2; \$i <= \$data->sheets[0]['numRows']; \$i++) 
				{
				\$values='';
				\$original_value='';
				\$s_ref_error_flag=0;
					for (\$j = 1; \$j <= \$data->sheets[0]['numCols']; \$j++) {
					if(\$i==2)
					{
					\$header_value.=\$data->sheets[0]['cells'][1][\$j].\",\";
					}";
			
				$cell_row=1;
			 foreach ($lobj_get_name as $key=>$value)
			{
			if($value[is_unique]==1)
			{
			$update_cond.="{$value[field_id]} = '{\$".$value[field_id]."}' and ";
			}
			if($value[ref_module_code]!=0)
			{
			$qry="  select concat('module_',schema_id) as table_name,GROUP_CONCAT(name SEPARATOR '-ele-') as name,GROUP_CONCAT(field_name) as field_name from 
				(select * from 
				(select s.internal_code as schema_id,su.name,ifnull(multiple,0) as multiple,ifnull(ug.name,'0None') as group_name,concat('m_',s.internal_code,'_ele_',su.internal_code) as field_name from s_user_schema s inner join s_user_schema_elements su on 
				su.ref_s_user_schema_code=s.internal_code
				inner join s_ref_type t on t.internal_code=su.s_ref_type_meta
				left join s_user_schema_group ug on ug.internal_code=su.ref_s_user_schema_group_code
				 where s.internal_code= $value[ref_module_code] and t.value='Meta' order by ug.sequence,su.sequence,su.internal_code ) l where   multiple=0 limit 2) a group by schema_id"; 
	 
			$lobj_rs = $aobj_context->mobj_db->GetRow($qry);
			
			$cond=explode(",",$lobj_rs[field_name]);
			 $data_str.="\n if(TRIM(strtolower(\$data->sheets[0]['cells'][1][\$j]))==strtolower('{$value[name]}')) \n { \n";
			 $data_str.="\$original_value.=(\$data->sheets[0]['cells'][\$i][\$j]).\",\"; \n";
			 $data_str.="\$where_cond1=''; \n";
			 $data_str.="\$where_cond2=''; \n";
			 $data_str.="\$where_cond_1_2=''; \n";
			 $data_str.="\$where_cond1=\"{$cond[0]} like '\".trim(\$data->sheets[0]['cells'][\$i][\$j]).\"'\"; \n";
			//$where_cond1= $data[".$k."] ;
			
			 
			if(!empty($cond[1]))
			{
			$data_str.="\$where_cond2=\" or  {$cond[1]} like '\".trim(\$data->sheets[0]['cells'][\$i][\$j]).\"'\"; \n";
			$data_str.="\$where_cond_1_2=\" or  concat({$cond[0]},' - ',{$cond[1]}) like '{\$data->sheets[0]['cells'][\$i][\$j]}'\"; \n";
			}
			$data_str.="\$select_ref_data_{$value[ref_module_code]}=\"select internal_code from {$value[ref_table_name]} where ( {\$where_cond1}  {\$where_cond2} {\$where_cond_1_2})\"; \n";
			 $data_str.="\$obj_select_ref_data_{$value[ref_module_code]} =  \$aobj_context->mobj_db->GetRow(\$select_ref_data_{$value[ref_module_code]}); \n";
			$data_str.=" if(empty(\$obj_select_ref_data_{$value[ref_module_code]})) \n
					{ \n
					\$s_ref_error_flag=1; \n
					} \n";
			 $data_str.="$".$value[field_id]."  = \$obj_select_ref_data_{$value[ref_module_code]}[internal_code]; \n } \n ";
			$insert_value.="'{\$".$value[field_id]."}',";
			$update_cond_value.=$value[field_id]."= '{\$".$value[field_id]."}' , ";
			$k++;
			}
			else if($value[list_of_values]!='')
			{
			
			$data_str.="if(TRIM(strtolower(\$data->sheets[0]['cells'][1][\$j]))==strtolower('{$value[name]}')) { \n ";
			$data_str.="\$original_value.=(\$data->sheets[0]['cells'][\$i][\$j]).\",\"; \n";
			 $data_str.="\$pos1 = stripos(\"{$value[list_of_values]}\", \$data->sheets[0]['cells'][\$i][\$j]);
				if(\$pos1===false)
				{ \n
					\$s_ref_error_flag=1; \n
					} \n else \n";
			
			 $data_str.="$".$value[field_id]."  = addslashes(\$data->sheets[0]['cells'][\$i][\$j]); \n } \n";
			$insert_value.="'{\$".$value[field_id]."}',";
			$update_cond_value.=$value[field_id]."= '{\$".$value[field_id]."}' , ";
			$k++;
			}
			else if($value[type]=='Date')
			{ 
			 $data_str.="if(TRIM(strtolower(\$data->sheets[0]['cells'][1][\$j]))==strtolower('{$value[name]}')) { \n ";
			 $data_str.="\$original_value.=(\$data->sheets[0]['cells'][\$i][\$j]).\",\"; \n";
			 $data_str.="\$date_obj  =explode(\"/\",addslashes(\$data->sheets[0]['cells'][\$i][\$j])); \n  \n";
			$data_str.="$".$value[field_id]."  = \$date_obj[2].\"-\".\$date_obj[1].\"-\".\$date_obj[0]; }";
					
			
			//$data_str.="$".$value[field_id]."  = addslashes(\$data->sheets[0]['cells'][\$i][\$j]); \n } \n";
			$insert_value.="'{\$".$value[field_id]."}',";
			$update_cond_value.=$value[field_id]."= '{\$".$value[field_id]."}' , ";
			$k++;
			}
			else
			{ 
			 $data_str.="if(TRIM(strtolower(\$data->sheets[0]['cells'][1][\$j]))==strtolower('{$value[name]}')) { \n ";
			 $data_str.="\$original_value.=(\$data->sheets[0]['cells'][\$i][\$j]).\",\"; \n";
			 
			
			$data_str.="$".$value[field_id]."  = trim(addslashes(\$data->sheets[0]['cells'][\$i][\$j]))==''?'0':trim(addslashes(\$data->sheets[0]['cells'][\$i][\$j])); \n } \n";
			$insert_value.="'{\$".$value[field_id]."}',";
			$update_cond_value.=$value[field_id]."= '{\$".$value[field_id]."}' , ";
			$k++;
			}
			}
			$who_fields_update=" ,modified_by=".$_SESSION['user_id'].",modified_date=now()";
			 $update_cond_value=substr($update_cond_value,0,strlen($update_cond_value)-2) ;
			$final_update_qry.=" update {$table_name}  set ".$update_cond_value.$who_fields_update."\n"; 
			$pos=strripos($update_cond,"and"); 
			  $final_update_qry.=" where ref_s_ref_data_code={$s_ref_data_code} and ".substr($update_cond,0,$pos-1); 
				$insert_value=substr($insert_value,0,strlen($insert_value)-1);
				$data_str.="\n }";
				$data_str.="if(\$s_ref_error_flag==0) \n
					{ \n";
				$who_fields=",".$_SESSION['user_id'].",now(),".$_SESSION['user_id'].",now() ";	
				$data_str.=$first_ins_qry.$insert_value.$who_fields.")\"; \n";
 							//$data_str.="echo \$insert_qry;\n";
 							$data_str.="\$obj_qry =  \$aobj_context->mobj_db->Execute(\$insert_qry); \n 
							if(mysql_error()!='') \n
						{ \n
						\$pos=strpos(mysql_error(),'Duplicate');
						if(\$pos===false) 
						 {
						  \$down_load_value.=\$original_value.\",\".mysql_error().\"\\n\";
						 }
						 else
						
						 \$update_qry=\" {$final_update_qry} \"; \n 
						  \$obj_qry =  \$aobj_context->mobj_db->Execute(\$update_qry); \n 
						} 
						\n
						}";
				$data_str.="			
						else
					{
					\$original_value.=\"\\n\";
					\$down_load_value.=\$original_value \n;
					} \n";	
					
			$data_str.=" } "; 
			$data_str.=" if(!empty(\$down_load_value)) \n
			{ \n
			header(\"Content-type:application/csv\"); \n
			header(\"Content-Disposition:attachment;filename=error_log.csv\");   \n
			echo \$header_value.\"\\n\".\$down_load_value; \n
			return; \n
			}
			else \n
			echo \"<script type='text/javascript'> alert('File has been uploaded. Please click on Group Name to Refresh');</script>\";
		
			?>";
			 
			 
				$tmp_root_file_name=$_SERVER["DOCUMENT_ROOT"]."/".$main_src."/imported_files/upload_group_details_".$_SESSION['user_id']."_.php";
		 //echo $tmp_root_file_name;
		    file_put_contents($tmp_root_file_name,$data_str);
		   require_once($tmp_root_file_name);
		    unlink($tmp_root_file_name);
		    unlink($root_file_name);
		    unset($_FILES);
			}
		}
 //echo "<script type='text/javascript'> alert('done');</script>";
}
function getSerieslastNoInFile($aobj_context,$prefix,$ref_module_code,$ref_module_element_code)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	$get_details="select concat(prefix,'-',(last_no+1)) as last_no from 
	transaction_series_prefix where ref_module_code={$ref_module_code}
	and ref_module_element_code={$ref_module_element_code} and 
	internal_code='{$prefix}' limit 1";
	$get_details_obj=$aobj_context->mobj_db->getRow($get_details);
	return $get_details_obj["last_no"];
}

function getSerieslastNo($aobj_context)
{
	$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
	$prefix = $aobj_context->mobj_data["prefix"];
	$ref_module_code = $aobj_context->mobj_data["ref_module_code"];
	$ref_module_element_code = $aobj_context->mobj_data["ref_module_element_code"];
	
	$get_details="select concat(prefix,'-',(last_no+1)) as last_no from 
	transaction_series_prefix where ref_module_code={$ref_module_code}
	and ref_module_element_code={$ref_module_element_code} and 
	internal_code='{$prefix}' limit 1";
	$get_details_obj=$aobj_context->mobj_db->getRow($get_details);
	  
		if($get_details_obj) 
		{
		$arr[0]=$get_details_obj["last_no"];
		$arr[1]=$ref_module_element_code;
	
		
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
		
		}
		 else
		{	
		$arr[0]='';
		$arr[1]=$ref_module_element_code;
		 
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"Failure");
		
		}
}
function getAutoIncrementDefaultPrefix($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
 
	$ref_module_code = $aobj_context->mobj_data["ref_module_code"];
	$ref_module_element_code = $aobj_context->mobj_data["ref_module_element_code"];
	
	$get_details="select {$ref_module_element_code} as ele_id,internal_code,prefix as value
				from transaction_series_prefix 
				where ref_module_element_code={$ref_module_element_code} and ref_module_code={$ref_module_code}
				and starting_date<=current_date() and ending_date>=current_date()";
	$get_details_obj=$aobj_context->mobj_db->getAll($get_details);
	   
		if(!empty($get_details_obj))
            echo $aobj_context->mobj_output->ToJSONEnvelope($get_details_obj,0,"success"); 
			else
			  echo $aobj_context->mobj_output->ToJSONEnvelope($get_details_obj,-1,"failure"); 
		
		 
}
function getAutoIncrementDocRootPrefix($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
 
	$ref_module_code = $aobj_context->mobj_data["ref_module_code"];
	$ref_module_element_code = $aobj_context->mobj_data["ref_module_element_code"];
	$date = $aobj_context->mobj_data["date"];
	
	$get_details="select {$ref_module_element_code} as ele_id,internal_code,prefix as value
				from transaction_series_prefix 
				where ref_module_element_code={$ref_module_element_code} and ref_module_code={$ref_module_code}
				and starting_date<='{$date}' and ending_date>='{$date}'";
	$get_details_obj=$aobj_context->mobj_db->getAll($get_details);
	   
		if(!empty($get_details_obj))
            echo $aobj_context->mobj_output->ToJSONEnvelope($get_details_obj,0,"success"); 
			else
			  echo $aobj_context->mobj_output->ToJSONEnvelope($get_details_obj,-1,"failure"); 
}
function ClearEntryTableNameForLoginCnt($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$login_cnt = $aobj_context->mobj_data["login_cnt"];
$entry_table = $aobj_context->mobj_data["entry_table"];
$delete_qry="delete from {$entry_table} where login_cnt={$login_cnt}";
$delete_qry_obj=$aobj_context->mobj_db->Execute($delete_qry);
 echo $aobj_context->mobj_output->ToJSONEnvelope($delete_qry_obj,0,"success"); 
}
function CreateGroupEntryTable($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$get_schema_names="select internal_code,module_name 
							from s_user_schema   
							";
		 $lobj_get_schema_names = $aobj_context->mobj_db->GetAll($get_schema_names);
 	 
	foreach($lobj_get_schema_names as $k=>$v)	 
	{
		$schema_id=$v['internal_code'];
		$select_distinct_group_names="select internal_code,name,
								concat('user_schema_',ref_s_user_schema_code,'_group_',internal_code) as group_table_name,
								concat('user_schema_',ref_s_user_schema_code,'_entry_',internal_code) as entry_table_name
								from s_user_schema_group 
							where ref_s_user_schema_code={$schema_id}
							and multiple=1";
		 $lobj_select_distinct_group_names = $aobj_context->mobj_db->GetAll($select_distinct_group_names);	
		
		foreach($lobj_select_distinct_group_names as $gk=>$gv)
		{
			$group_table_name =$gv["group_table_name"];	
			$entry_table_name =$gv["entry_table_name"];	
			$str_desc = "show create table $group_table_name";
			$obj_desc=$aobj_context->mobj_db->GetAll($str_desc);
		   $create_table=$obj_desc[0]['Create Table'];
		   $create_table=str_ireplace("`ref_s_user_schema_code` bigint(20)","`login_cnt` int(11) default NULL ,group_int_code bigint(11),`ref_s_user_schema_code  bigint(20)`",$create_table);
		    $create_table=str_ireplace("`","",$create_table);
		
			 
			$create_table=str_ireplace($group_table_name,$entry_table_name,$create_table);
 
			$lobj_create_table =  $aobj_context->mobj_db->Execute("drop table {$entry_table_name}");
			$lobj_create_table =  $aobj_context->mobj_db->Execute($create_table);
			
		 	$alter_auto_inc="alter table  {$entry_table_name} AUTO_INCREMENT=1";
			$lobj_alter_auto_inc = $aobj_context->mobj_db->Execute($alter_auto_inc); 
			
			$add_indx="ALTER   TABLE {$entry_table_name} add     INDEX   login_cnt(login_cnt)"; 
				$lobj_add_indx = $aobj_context->mobj_db->Execute($add_indx); 
		}
	}
	echo $aobj_context->mobj_output->ToJSONEnvelope($delete_qry_obj,0,"success"); 
}
function UpdateMultiGroupTableWithGridEdit($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$internal_code = $aobj_context->mobj_data["internal_code"];
$table_name = $aobj_context->mobj_data["table_name"];
$val = $aobj_context->mobj_data["val"];
$system_name = $aobj_context->mobj_data["system_name"];
$schema_ids=explode("_",$table_name);
$schema_id=$schema_ids[2]; 
$group_id=$schema_ids[4];

		$get_db_field="select internal_code,db_field,name,system_name 
						from s_user_schema_elements 
						where ref_s_user_schema_code={$schema_id}
						and ref_s_user_schema_group_code={$group_id}
						and system_name='{$system_name}'";
		$lobj_get_db_field = $aobj_context->mobj_db->GetRow($get_db_field); 				
		$db_filed=$lobj_get_db_field['db_field'];
		$update_entry_table="update {$table_name} set {$db_filed}='{$val}'
							where internal_code={$internal_code}";
			 			
		$lobj_update_entry_table = $aobj_context->mobj_db->Execute($update_entry_table); 
		if(!empty($lobj_update_entry_table))
            echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
			else
			 echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"failure"); 		

}
function uploadHeaderImageDocuments($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$internal_code = $aobj_context->mobj_data["internal_code"];
$module_name = $aobj_context->mobj_data["module_name"];
$module_name=replace($module_name);
$ref_s_user_schema_code = $aobj_context->mobj_data["ref_s_user_schema_code"];
mkdir($aobj_context->main_src."/user_images/m_{$ref_s_user_schema_code}");
$get_type="select ue.internal_code,
		ue.name,s.value
		from s_user_schema_elements ue
		inner join s_user_schema u on u.internal_code=ue.ref_s_user_schema_code
		inner join s_ref_type s on s.internal_code=ue.data_type
		where ref_s_user_schema_code={$ref_s_user_schema_code}
		and value='Image' and is_multiple_group=0";
$lobj_get_type = $aobj_context->mobj_db->GetAll($get_type);
$non_group_ids_arr=getIdsArray($lobj_get_type);	
$db_field_path="/user_images/m_{$ref_s_user_schema_code}/";
foreach($_FILES as $k=>$v)
	{ 
		$text_id_split=explode("_",$k);
		$text_id=$text_id_split[2];
		$file_ext=basename($v['name']);
		$file_ext_arr=explode(".",$file_ext);
		$file_ext=$file_ext_arr[count($file_ext_arr)-1];
		 
		$root_file_name=$internal_code."_".$text_id.".".$file_ext;
		$update_field_value=$db_field_path.$root_file_name;
		$storage_file_name=$aobj_context->main_src."/user_images/m_{$ref_s_user_schema_code}/{$root_file_name}";
		if(in_array($text_id,$non_group_ids_arr))
		{
		  if(isset($v['name']) && $v['name'] != '')         
			{ 
				if(move_uploaded_file($v['tmp_name'],$storage_file_name))
				{
					$field_id="m_{$ref_s_user_schema_code}_ele_{$text_id}";
					$update_db="update module_{$ref_s_user_schema_code}
								set {$field_id}='{$update_field_value}'
								where internal_code={$internal_code}";
					$lobj_update_db = $aobj_context->mobj_db->Execute($update_db); 
				 
				
				}
			}
		}
 	}
}
function uploadGroupImageDocuments($aobj_context)
{
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$internal_code = $aobj_context->mobj_data["internal_code"];
$module_name = $aobj_context->mobj_data["module_name"];
$group_name = $aobj_context->mobj_data["group_name"];
$module_name=replace($module_name);
$group_name=replace($group_name);
$ref_s_user_schema_code = $aobj_context->mobj_data["ref_s_user_schema_code"];
$group_id = $aobj_context->mobj_data["group_id"];
$get_type="select ue.internal_code
		from s_user_schema_elements ue
		inner join s_user_schema u on u.internal_code=ue.ref_s_user_schema_code
		inner join s_ref_type s on s.internal_code=ue.data_type
		where ref_s_user_schema_code={$ref_s_user_schema_code}
		and value='Image' and is_multiple_group=1";
$lobj_get_type = $aobj_context->mobj_db->GetAll($get_type); 
$group_ids_arr=getIdsArray($lobj_get_type);
 
mkdir($aobj_context->main_src."/user_images/m_{$ref_s_user_schema_code}");
mkdir($aobj_context->main_src."/user_images/m_{$ref_s_user_schema_code}/tmp");
echo "<pre>";
print_r($_FILES);  
$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
$db_field_path="/user_images/m_{$ref_s_user_schema_code}/tmp/";
 
 
	foreach($_FILES as $k=>$v)
	{ 
		$text_id_split=explode("_",$k);
		$text_id=$text_id_split[2];
		$file_ext=basename($v['name']);
		$file_ext_arr=explode(".",$file_ext);
		$file_ext=$file_ext_arr[count($file_ext_arr)-1];
		$root_file_name=$group_id."_".$internal_code."_".$text_id.".".$file_ext;
		$update_field_value=$db_field_path.$root_file_name;
		$storage_file_name=$aobj_context->main_src."/user_images/m_{$ref_s_user_schema_code}/tmp/{$root_file_name}";
		if(in_array($text_id,$group_ids_arr))
		{	
			if(isset($v['name']) && $v['name'] != '')         
			{ 
				if(move_uploaded_file($v['tmp_name'],$storage_file_name))
				{	 
					$field_id="u_{$ref_s_user_schema_code}_g_{$group_id}_ele_{$text_id}";
					$entry_table="user_schema_{$ref_s_user_schema_code}_entry_{$group_id}";
					$update_db="update {$entry_table}
								set {$field_id}='{$update_field_value}'
								where internal_code={$internal_code}";
					$lobj_update_db = $aobj_context->mobj_db->Execute($update_db); 
				}
			}
		}
 
	}
}
function UpldateGroupImagesFromEntryToGroupTable($aobj_context,$login_cnt,$last_inserted_id,$schema_id,$group_id,$group_table_name,$entry_table_name)
{
 
	$entry_table_name="user_schema_{$schema_id}_entry_{$group_id}";
	$group_table_name="user_schema_{$schema_id}_group_{$group_id}";
	$main_src_path=$aobj_context->main_src;
	$select_group_image_ids="select ue.internal_code,
			concat('u_',ref_s_user_schema_code,'_g_',ref_s_user_schema_group_code,'_ele_',ue.internal_code) as group_field
			,ue.name,s.value
			from s_user_schema_elements ue
			inner join s_user_schema u on u.internal_code=ue.ref_s_user_schema_code
			inner join s_ref_type s on s.internal_code=ue.data_type
			where ref_s_user_schema_code={$schema_id}
			and value='Image' 
			and is_multiple_group=1";
	$lobj_select_group_image_ids = $aobj_context->mobj_db->GetAll($select_group_image_ids);
	$group_fields="";	
	foreach($lobj_select_group_image_ids as $k=>$v)
	{
		$group_fields.=$v[group_field].',';
	}
	$group_fields=substr($group_fields,0,strlen($group_fields)-1);
	
	$get_dat_from_group_table="select internal_code,{$group_fields} from 
					{$group_table_name} where ref_s_ref_data_code={$last_inserted_id}";
	$lobj_get_dat_from_group_table = $aobj_context->mobj_db->GetAll($get_dat_from_group_table);	
	
	foreach($lobj_get_dat_from_group_table as $key=>$val)
	{
		foreach($val as $k=>$v)
			if($k!="internal_code")
			{
				$field_id_arr=explode("ele_",$k);
				$field_id=$field_id_arr[1];
				$tmp_image_path=$main_src_path.$v;
				$file_ext=basename($v);
				$file_ext_arr=explode(".",$file_ext);
				$file_ext=$file_ext_arr[count($file_ext_arr)-1];
				$original_path="{$main_src_path}/user_images/m_{$schema_id}/{$group_id}_{$val[internal_code]}_{$field_id}.{$file_ext}";
				$update_field_value="/user_images/m_{$schema_id}/{$group_id}_{$val[internal_code]}_{$field_id}.{$file_ext}";
				$tmp_pos= strpos($tmp_image_path,"tmp");
				if ($tmp_pos === false)  continue;
				copy($tmp_image_path, $original_path);
				unlink($tmp_image_path);
				$update_group_table_field="update {$group_table_name} set 
					{$k}=\"{$update_field_value}\"
						where internal_code={$val[internal_code]}";
				$lobj_update_group_table_field = $aobj_context->mobj_db->Execute($update_group_table_field);		
				
			}
	}
}
function getModuleImage($aobj_context)
{
$internal_code = $aobj_context->mobj_data["internal_code"];
$schema_id = $aobj_context->mobj_data["schema_id"];
$ele_id = $aobj_context->mobj_data["ele_id"];
$field_id="m_{$schema_id}_ele_{$ele_id}";
$table_name="module_{$schema_id}";
$doc_path=$aobj_context->main_src;
$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
$pdf_main_src=$main_src_obj[1]; 
$image_path=  "http://".$_SERVER["SERVER_NAME"] ."/{$pdf_main_src}";

$get_data="select {$field_id} as path_name from {$table_name} where internal_code={$internal_code}" ;
$lobj_get_data = $aobj_context->mobj_db->GetRow($get_data);	
	if(!empty($lobj_get_data))
	{
	$type_arr=$lobj_get_data['path_name'];
		if(getDisplayType($type_arr)=="Image")
		{
		$arr['type']="Image";
		$arr['path']=$image_path.$type_arr;
		}
		else
		{
		$arr['type']="Doc";
		$arr['path']=$doc_path.$type_arr;
		}
	 echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
	}
    else
	echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"failure"); 
}

function getGroupImage($aobj_context)
{
$internal_code = $aobj_context->mobj_data["internal_code"];
$schema_id = $aobj_context->mobj_data["schema_id"];
$ele_id = $aobj_context->mobj_data["ele_id"];
$group_id = $aobj_context->mobj_data["group_id"];
$field_id="u_{$schema_id}_g_{$group_id}_ele_{$ele_id}";
$group_table_name="user_schema_{$schema_id}_group_{$group_id}";
$entry_table_name="user_schema_{$schema_id}_entry_{$group_id}";
$doc_path=$aobj_context->main_src;
$main_src_obj=(explode("/",$_SERVER["REQUEST_URI"]));
$pdf_main_src=$main_src_obj[1]; 
$image_path=  "http://".$_SERVER["SERVER_NAME"] ."/{$pdf_main_src}";

	$select_group_table_int_code="select group_int_code from {$entry_table_name} where
							internal_code={$internal_code}";
	$lobj_select_group_table_int_code = $aobj_context->mobj_db->GetRow($select_group_table_int_code);	
	$group_int_code=$lobj_select_group_table_int_code['group_int_code'];	
	
	$get_data="select {$field_id} as path_name from {$group_table_name} where internal_code={$group_int_code}" ;
	$lobj_get_data = $aobj_context->mobj_db->GetRow($get_data);	
	if(!empty($lobj_get_data))
	{
	$type_arr=$lobj_get_data['path_name'];
		if(getDisplayType($type_arr)=="Image")
		{
		$arr['type']="Image";
		$arr['path']=$image_path.$type_arr;
		}
		else
		{
		$arr['type']="Doc";
		$arr['path']=$doc_path.$type_arr;
		}
	 echo $aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success"); 
	}
    else
	echo $aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"failure"); 
}

function displayUserUploadedFiles($aobj_context)
{
		$path = $aobj_context->mobj_data["path"];
		$len = filesize($path);
		$file_ext=basename($path);
		$file_name=basename($path);
		$file_ext_arr=explode(".",$file_ext);
		$file_ext=strtolower($file_ext_arr[count($file_ext_arr)-1]);
		switch( $file_ext ) {
         case "pdf": $ctype="application/pdf"; break;
		 case "exe": $ctype="application/octet-stream"; break;
		 case "zip": $ctype="application/zip"; break;
		 case "doc": $ctype="application/msword"; break;
		 case "txt": $ctype="application/txt"; break;
		 case "php": $ctype="application/php"; break;
		 case "htm": $ctype="application/htm"; break;
		 case "html": $ctype="application/html"; break;
		 case "xls": $ctype="application/vnd.ms-excel"; break;
		 case "ppt": $ctype="application/vnd.ms-powerpoint"; break;
		 case "gif": $ctype="image/gif"; break;
		 case "png": $ctype="image/png"; break;
		 case "jpeg":
		 case "jpg": $ctype="image/jpg"; break;
		 case "mp3": $ctype="audio/mpeg"; break;
		 case "wav": $ctype="audio/x-wav"; break;
		 case "mpeg":
		 case "mpg":
		 case "mpe": $ctype="video/mpeg"; break;
		 case "mov": $ctype="video/quicktime"; break;
		 case "avi": $ctype="video/x-msvideo"; break;
		 //The following are for extensions that shouldn't be downloaded (sensitive stuff, like php files)
		 case "phpa":
		 case "htma":
		 case "htmla":
		 die("<b>Cannot be used for ". $file_extension ." files!</b>"); break;
		 default: $ctype="application/force-download";
		}
	header("Pragma: public");
	header("Expires: 0");
	header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
	header("Cache-Control: public"); 
	header("Content-Description: File Transfer");
	header("Content-Type: $ctype");
	$header="Content-Disposition: attachment; filename=".$file_name.";";
	header($header );
	header("Content-Transfer-Encoding: binary");
	header("Content-Length: ".$len);
	readfile($path);
}
function getIdsArray($obj)
{
$ids_arr='';
$i=0;
	foreach($obj as $k=>$v)
	{
	  $ids_arr[$i]=$v[internal_code];
	  $i++;
	}
return $ids_arr;
}
function replace($name)
{
	$spl_char = array("*","/","~","!","@","#","$","%","^","&",":",";","?","/","\\","_","-","'"," ",".");
	$name = strtolower(str_replace($spl_char,"_",$name));
	return str_ireplace("__","_",$name);
}
function getDisplayType($path)
{
$image_type_arr=array("jpg","jpeg","gif","png");
		$file_ext=$path;
		$file_ext_arr=explode(".",$file_ext);
		$file_ext=strtolower($file_ext_arr[count($file_ext_arr)-1]);
		if(in_array($file_ext,$image_type_arr))
		return "Image";
		else
		return "Doc";
}
function AssignParentModuleIdToSession($aobj_context)
{
   $_SESSION['g_file_id']=$aobj_context->mobj_data["module_id"]; 
   $aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
   
  
	print_r($aobj_context->mobj_output->ToJSONEnvelope($rdata,0,"success"));
	return;
	 
}
?>