class.rang.php 3.88 KB
<?php
if ( defined("class_rang_file") ){
  return false;
}
define("class_rang_file", 1);

include_once(MAIN_SOURCE_PATH.'/inc/class.query.php');
include_once(MAIN_SOURCE_PATH.'/modules/users/inc/url.php');
include_once(MAIN_SOURCE_PATH.'/modules/users/lang/ru/lang.php');

	//	класс запросов к таблице модулей
class rang_q extends query{
	
	
	
	public function __construct($alias){
	global $MAIN_DB;
		$this -> set_table($MAIN_DB -> prefix("users_rang") );
		$this -> set_alias($alias);
	}
	
	/*public function include_modules($alias,$cols=''){
	global $MAIN_DB;
		if ( empty($alias) ){
			$this -> make_error(ERROR_500);
		}
		$this -> include_table($MAIN_DB -> prefix('system_modules'),$alias,'m_id',$cols );
		return true;
	}
	*/
	public function where_id($v){
		$v = intval($v);
		if ( empty($v)  ){
			return FALSE;
		}
		return $this -> set_where( $this -> alias.'.r_id',$v);
	}
	
	
	
	
	
	
	
	
	/***
		Функции - обработчики столбцов таблицы
	***/
	
		
	

}



class rang{
	
	private $debug = false;
	private $info = array();
	private $last_error = false;
	private $main_key = false;
	private $set_info = array();
	
	private function __construct( $array=array() ){
		$this -> info = $array;
		$this -> main_key = $array['r_id'];
	}
	
	public function error(){
  		return $this -> last_error;
	}
	
	
	public function get($k){
		if ( isset($this -> info[$k]) ){
			return $this -> info[$k];
		} 
		sys_error(500, sprintf(E_NOT_VAR,$k));
	}
	
	public function set($k,$v){
		if ( method_exists($this,'set_'.$k) ){
			$f = 'set_'.$k;
			return $this -> $f($v);
		}
		$this -> set_info[$k] = $v;
		return true;
	}
	
	/***
		SET-функции
	**/



	private function set_r_name($v){
		
		if ( empty($v) ){
			$this -> make_error( M_RANG_ERROR_EMPTY_NAME );
		}
		$this -> set_info['r_name']=$v;
		return true;
	}
	
	


	
	
	/***
	/***
		GET
	***/
	
	public function id(){
		return $this -> info['r_id'];
	}	
	
	
	public function set_debug($flag){
		$this -> debug = $flag;
	}
	
	public function delete(){
	global $MAIN_DB;
		$id = $this -> id();
		if ( empty($id) ){
			sys_error(500,E_EMPTY_ID);
		}
		$sql = "DELETE FROM ".$MAIN_DB -> prefix("users_rang")." WHERE r_id='$id'";
		$MAIN_DB -> query($sql);
		return TRUE;
	}
	
	
	public function update(){
	global $MAIN_DB;

		if ( false===$this -> main_key ){
			sys_error(500,E_EMPTY_ID);
		}
		if ( !empty($this -> last_error ) ){
			 return false; 
		}
		if ( sizeof($this -> set_info)==0 ){
			sys_error(500,E_EMPTY_ARRAY);
		}
		$sql = array();
		foreach( $this -> set_info as $k=>$v ){
			$sql[]="`$k`='".sys_in_sql($v)."'";
		}
		$sql = "
						UPDATE ".$MAIN_DB -> prefix("users_rang")." 
						SET ".implode(',',$sql)." 
						WHERE r_id='".$this -> main_key."'";
		if ( !empty($this -> debug) ){
			die($sql);
		}
		$MAIN_DB -> query($sql);
		
	
		return true;
	}
	
	public function insert(){
	global $MAIN_DB;
			//	при инициализации значений произошла ошибка
		if ( !empty($this -> last_error ) ){
			 return false; 
		}
		if ( sizeof($this -> set_info)==0 ){
			sys_error(500,E_EMPTY_ARRAY);
		}

		$sql = array();
		foreach( $this -> set_info as $k=>$v ){
			$sql[]="`$k`='".sys_in_sql($v)."'";
		}
		$sql = "INSERT INTO ".$MAIN_DB -> prefix("users_rang")." SET ".implode(',',$sql)."";
		if ( !empty($this -> debug) ){
			die($sql);
		}
		$MAIN_DB -> query($sql);
		return $MAIN_DB -> insert_id();
	}
	
	
	public function get_error(){
		return $this -> last_error;
	}
	
	private function make_error($msg){
 		$this -> last_error = $msg;	
	}
	
 	
		
		

		
	
		//STATIC

	
	static function load_id($id){
		$m = new rang_q('m');
		if ( !$m -> where_id($id) ){
			return false;
		}
		$m -> get('*');
		if ( !$m -> get_count_rows() ){
			return false;
		}
		return new rang($m -> row());
	}
	
	static function create(){
		return new rang( array('r_id'=>0) );
	}
		
 	
 	
 	
	
 	
 	
 	
  	
  	
	
  	
  	
	
	
}


	
?>