/home/smartonegroup/www/system/system/autoload/Contacts.php
<?php

class Contacts
{
    public static function options($selected = '')
    {
        $c = ORM::for_table('crm_accounts')
            ->select('id')
            ->select('account')
            ->find_array();
        $options = '';
        if ($c) {
            foreach ($c as $cs) {
                $s = '';
                if ($cs['id'] == $selected) {
                    $s = 'selected';
                }
                $options .=
                    '<option value="' .
                    $cs['id'] .
                    '" ' .
                    $s .
                    '>' .
                    $cs['account'] .
                    '</option>';
            }
        }

        return $options;
    }

    public static function add(
        $data = [],
        $email_required = false,
        $notify = false
    ) {
        if (isset($data['account'])) {
            $account = trim($data['account']);

            if ($account == '') {
                return 'Account Name is Required';
            }

            $email = '';
            $phone = '';
            $address = '';
            $city = '';
            $zip = '';
            $state = '';
            $country = '';
            $tags = '';
            $company = '';
            $password = '';
            $img = '';

            $d = ORM::for_table('crm_accounts')->create();

            $d->account = $data['account'];

            if (isset($data['email']) && trim($data['email']) != '') {
                $email = $data['email'];

                if (filter_var($email, FILTER_VALIDATE_EMAIL) == false) {
                    return 'Invalid Email';
                }
                $f = ORM::for_table('crm_accounts')
                    ->where('email', $data['email'])
                    ->first();

                if ($f) {
                    return 'Email already exist';
                }
            }

            if ($email_required && $data['email'] == '') {
                return 'Email is Required';
            }

            if (isset($data['phone'])) {
                $phone = $data['phone'];
            }

            if (isset($data['address'])) {
                $address = $data['address'];
            }

            if (isset($data['city'])) {
                $city = $data['city'];
            }

            if (isset($data['zip'])) {
                $zip = $data['zip'];
            }

            if (isset($data['state'])) {
                $state = $data['state'];
            }

            if (isset($data['country'])) {
                $country = $data['country'];
            }

            $cid = 0;

            if (isset($data['cid'])) {
                $company_id = $data['cid'];
                if ($company_id != '' || $company_id != '0') {
                    $company_db = db_find_one('sys_companies', $company_id);

                    if ($company_db) {
                        $company = $company_db->company_name;
                        $cid = $company_id;
                    }
                }
            }

            if (isset($data['password'])) {
                $password = $data['password'];
                $password = Password::_crypt($password);
            } else {
                $data['password'] = _raid(6);
                $password = Password::_crypt($data['password']);
            }

            if (isset($data['tags'])) {
                $tags = $data['tags'];
            }

            if (isset($data['img'])) {
                $img = $data['img'];
            }

            $d->email = $email;
            $d->phone = $phone;
            $d->address = $address;
            $d->city = $city;
            $d->zip = $zip;
            $d->state = $state;
            $d->country = $country;
            $d->tags = $tags;

            $d->fname = '';
            $d->lname = '';
            $d->company = $company;
            $d->jobtitle = '';
            $d->cid = $cid;
            $d->o = '0';
            $d->balance = '0.00';
            $d->status = 'Active';
            $d->notes = '';
            $d->password = $password;
            $d->token = '';
            $d->ts = '';
            $d->img = $img;
            $d->web = '';
            $d->facebook = '';
            $d->google = '';
            $d->linkedin = '';

            //
            $d->save();
            $cid = $d->id();

            if ($notify) {
                Email::send_client_welcome_email($data, true);
            }

            return $cid;
        } else {
            return 'Invalid Data Posted or Data is Null';
        }
    }

    public static function login($username, $password)
    {
        $d = Contact::where('email', $username)
            ->orWhere('username', $username)
            ->orWhere('phone', $username)
            ->first();

        if ($d) {
            $db_password = $d->password;

            if (Password::_verify($password, $db_password) == true) {
                $auth_key = Misc::random_string(20) . md5(time());

                $d->token = $auth_key;

                if (isset($_COOKIE['ib_cart_secret'])) {
                    $cart = ORM::for_table('sys_cart')
                        ->where('secret', $_COOKIE['ib_cart_secret'])
                        ->first();

                    if ($cart) {
                        $cart->cid = $d->id;
                        $cart->save();
                    }
                }

                $d->lastlogin = date('Y-m-d H:i:s');

                $d->save();

                if (!empty($d->language)) {
                    $_SESSION['language'] = $d->language;
                }

                return $auth_key;
            } else {
                return false;
            }
        } else {
            return false;
        }
    }

    public static function logout_using_token($token)
    {
        $d = ORM::for_table('crm_accounts')
            ->where('token', $token)
            ->first();
        if ($d) {
            $d->token = '';

            $d->save();

            return true;
        } else {
            return false;
        }
    }

    public static function details()
    {
        $d = false;

        if (isset($_COOKIE['cloudonex_client_token'])) {
            $cloudonex_client_token = $_COOKIE['cloudonex_client_token'];
        } elseif (isset($_SESSION['cloudonex_client_token'])) {
            $cloudonex_client_token = $_SESSION['cloudonex_client_token'];
        } else {
            exit(
                'You have logged out. <a href="' .
                    U .
                    'client/login/">Click Here to Login.</a>'
            );
        }

        $d = ORM::for_table('crm_accounts')
            ->where('token', $cloudonex_client_token)
            ->first();

        if (!$d) {
            exit(
                'You have logged out. <a href="' .
                    U .
                    'client/login/">Click Here to Login.</a>'
            );
        }

        return $d;
    }

    public static function isLogged()
    {
        if (isset($_COOKIE['cloudonex_client_token'])) {
            $cloudonex_client_token = $_COOKIE['cloudonex_client_token'];
        } elseif (isset($_SESSION['cloudonex_client_token'])) {
            $cloudonex_client_token = $_SESSION['cloudonex_client_token'];
        } else {
            return;
        }

        $d = ORM::for_table('crm_accounts')
            ->where('token', $cloudonex_client_token)
            ->first();

        if ($d) {
            r2(U . 'client/dashboard/');
        }
    }

    public static function all()
    {
        return Contact::all()->toArray();
    }

    public static function findByCompany($company_id)
    {
        $companies = ORM::for_table('crm_accounts')
            ->select('id')
            ->where('cid', $company_id)
            ->find_array();
        $cids = [];
        foreach ($companies as $company) {
            $cids[] = $company['id'];
        }

        if (count($cids) == 0) {
            return false;
        }

        return $cids;
    }
}