<?php

/**
 *  PHP Mikrotik Billing (https://github.com/hotspotbilling/phpnuxbill/)
 *  by https://t.me/ibnux
 **/


class User
{
    public static function getID(){
        global $db_password;
        if(isset($_SESSION['uid'])){
            return $_SESSION['uid'];
        }else if(isset($_COOKIE['uid'])){
            // id.time.sha1
            $tmp = explode('.',$_COOKIE['uid']);
            if(sha1($tmp[0].$tmp[1].$db_password)==$tmp[2]){
                if($tmp[1] < 86400*30){
                    $_SESSION['uid'] = $tmp[0];
                    return $tmp[0];
                }
            }
        }
        return 0;
    }

    public static function setCookie($uid){
        global $db_password;
        if(isset($uid)){
            $time = time();
            setcookie('uid', $uid.'.'.$time.'.'.sha1($uid.'.'.$time.'.'.$db_password), time()+86400*30);
        }
    }

    public static function removeCookie(){
        if(isset($_COOKIE['uid'])){
            setcookie('uid', '', time()-86400);
        }
    }

    public static function _info()
    {
        $id = User::getID();
        $d = ORM::for_table('tbl_customers')->find_one($id);

        if(empty($d['username'])){
            r2(U . 'logout', 'd', '');
        }
        return $d;
    }

    public static function _billing()
    {
        $id = User::getID();
        $d = ORM::for_table('tbl_user_recharges')->where('customer_id', $id)->find_many();
        return $d;
    }
}