<?php
// +----------------------------------------------------------------------
// | OneThink [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.onethink.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: huajie <banhuajie@163.com>
// +----------------------------------------------------------------------

namespace Admin\Model;
use Think\Model;

/**
 * 设备记录模型
 * @author 鹿文学
 */
class DeviceRecordModel extends Model{

    

    /* 自动验证规则 */
    protected $_validate = array(
        
    );

    /* 自动完成规则 */
    protected $_auto = array(
        
    );

    /**
     * 构造函数
     * @param string $name 模型名称
     * @param string $tablePrefix 表前缀
     * @param mixed $connection 数据库连接信息
     */
    public function __construct($name = '', $tablePrefix = '', $connection = '') {
        /* 设置默认的表前缀 */
        $this->tablePrefix ='tab_';
        /* 执行构造方法 */
        parent::__construct($name, $tablePrefix, $connection);
    }

		/**
		 * 累计设备
		 * @author 鹿文学
		 */
    public function all_device() {

//			$list =  $this->field('unique_code')->group('unique_code')->count();
			$sql = "SELECT count(1) as count from  (select unique_code from tab_device_record group by unique_code)t;";

			$list = $this->query($sql);

			return $list[0]['count'];
			
		}
		
		/**
		 * 统计新增设备
		 * @author 鹿文学
		 */
		public function total_device($map=array(),$flag=0) {
			
			if($flag) {
				$list = $this->active($map);
			} else {
				$list = $this->news($map);								
			}
			
			return count($list);
			
		}
		
		/**
		 * 新增设备
		 * @author 鹿文学
		 */
		public function news($map=array()) {
			
			$sql = $this->field('min(create_time) as create_time,model,unique_code,id')->group('unique_code')->select(false);

			return $this->table('(' . $sql . ') as a')->where($map)->order('create_time')->select();
			
		}
		
		/*
		 * 新增设备 
		 * @param  array    $map      条件数组
		 * @param  string   $field	  字段别名
		 * @param  string   $group    分组字段名
		 * @author 鹿文学
		 */
		public function news_on_time($map=array(),$field='news',$flag=1,$group='time',$order='time') {

			switch($flag) {
				case 2:{$dateform = '%Y-%m';};break;
				case 3:{$dateform = '%Y-%u';};break;
				case 4:{$dateform = '%Y';};break;
				case 5:{$dateform = '%Y-%m-%d %H';};break;
				default:$dateform = '%Y-%m-%d';
			}

			$sql = $this->field('min(create_time) as create_time,version,unique_code,id')->group('unique_code')->select(false);
					
			$news = $this->table('(' . $sql . ') as a')
					->field('FROM_UNIXTIME(a.create_time, "'.$dateform.'") as '.$group.',group_concat(a.id) as id,group_concat(a.unique_code) as unique_code ,COUNT(a.unique_code) AS '.$field)
					->where($map)->group($group)->order($order)->select();

			return $news;
			
		}
		
		/**
		 * 活跃设备
		 * @author 鹿文学
		 */
		public function active($map=array()) {
			
			$sql = $this->field('create_time,model,unique_code')->where($map)->select(false);
			
			return $this->table('(' . $sql . ') as a')->group('unique_code')->order('create_time')->select();
			
		}
		
		/*
		 * 活跃设备 
		 * @param  array    $map      条件数组
		 * @param  string   $field	  字段别名
		 * @param  string   $group    分组字段名
		 * @author 鹿文学
		 */
		public function active_on_time($map=array(),$field='active',$flag=1,$group='time',$order='time') {
			
			switch($flag) {
				case 2:{$dateform = '%Y-%m';};break;
				case 3:{$dateform = '%Y-%u';};break;
				case 4:{$dateform = '%Y';};break;
				case 5:{$dateform = '%Y-%m-%d %H';};break;
				default:$dateform = '%Y-%m-%d';
			}
			
			
			$sql = $this->field('create_time,version,unique_code,id')->where($map)->select(false);
			
			$mid = $this->table('(' . $sql . ') as m')->group('unique_code')->select(false);
					
			$active = $this->table('(' . $mid . ') as a')
					->field('FROM_UNIXTIME(a.create_time, "'.$dateform.'") as '.$group.',group_concat(a.id) as id,group_concat(a.unique_code) as unique_code ,COUNT(a.unique_code) AS '.$field)
					->group($group)->order($order)->select();
//            echo $this->_sql();die();
			return $active;
			
		}
		
		/**
		 * 启动机型
		 * @author 鹿文学
		 */
		public function model($map=array()) {
			
			$sql = $this->field('create_time,model,version,unique_code')->where($map)->select(false);
			
			
			$mid = $this->table('(' .$sql. ') as m')->group('unique_code')->select(false);
//			echo $this->_sql();die();
			
			return $this->table('(' .$mid. ') as a')->field('a.model,version,count(a.unique_code) as count')->group('model,version')->order('count desc')->select();
			
		}
		
		
		/**
		 * 单设备累计时长
		 * @author 鹿文学
		 */
		public function single_duration($map=array()) {
			
			$duration = $this->duration($map);
			
			$total = $this->total_device($map);

			return $duration/$total;
			
		}
		
		/**
		 * 累计时长
		 * @author 鹿文学
		 */
		public function duration($map=array()) {
			
			return $this->where($map)->sum('duration');
			
		}
    

    /**
     * 创建时间不写则取当前时间
     * @return int 时间戳
     * @author huajie <banhuajie@163.com>
     */
    protected function getCreateTime(){
        $create_time    =   I('post.create_time');
        return $create_time?strtotime($create_time):NOW_TIME;
    }

		/**
     * 新增或更新一个游戏
     * @param array  $data 手动传入的数据
     * @return boolean fasle 失败 , int  成功 返回完整的数据
     * @author 王贺 
     */
    public function update($data = null){
        /* 获取数据对象 */
        $data = $this->token(false)->create($data);
        if(empty($data)){
            return false;
        }     
        /* 添加或新增基础内容 */
        if(empty($data['id'])){ //新增数据
            $id = $this->add($data); //添加基础内容

            if(!$id){
                $this->error = '新增基础内容出错!';
                return false;
            }
        } else { //更新数据
            $status = $this->save(); //更新基础内容
            if(false === $status){
                $this->error = '更新基础内容出错!';
                return false;
            }
        }
        
        
        return $data;
    }
    
    
	
	
	
	
}