source: pro-violet-viettel/sourcecode/application/modules/frontend/controllers/user.php @ 700

Last change on this file since 700 was 700, checked in by namnd, 10 years ago
File size: 16.9 KB
Line 
1<?php
2
3if (!defined('BASEPATH'))
4    exit('No direct script access allowed');
5
6class User extends MX_Controller {
7
8    const TOKENPW = 'violet';
9
10    public function __construct() {
11        parent::__construct();
12        $this->load->helper('cookie');
13                $this->load->helper('language');
14                $this->lang->load('messages', 'message');
15    }
16
17    public function profile() {
18        $user_info = $this->session->userdata('userInfo');
19        if ($user_info) {
20            $this->load->model('User_model');
21            $this->load->model('Servicepackage_model');
22            $user = $user_info['user'];
23            $us_id = $user_info['us_id'];
24            $src = "SBG";
25            $token = md5($us_id . self::TOKENPW);
26            $data = $this->get_data($src, $token, $us_id);
27            $u = $this->User_model->get_user_by_id($us_id);
28            $data['current_tab'] = $this->uri->segment(4, 'edit-basic');
29            $data['packages'] = $this->Servicepackage_model->getAllPackages();
30            $data['is_viettel'] = isset($user_info['is_viettel']) ? $user_info['is_viettel']:FALSE;
31           
32            $data = (is_array($u)) ? array_merge($data, $u) : $data;
33            $data = (is_array($user_info)) ? array_merge($data, $user_info):$data;
34                       
35            $this->load->view('frontend/user_profile', $data);
36        } else {
37            redirect('frontend/home');
38        }
39    }
40
41    public function packageRegister() {
42        $result = array();
43        $input = $this->input->post();
44        $this->load->model('user_model');
45        $user_info = $this->session->userdata('userInfo');
46        if ($user_info) {
47            parse_str($user_info['user'], $info);
48            $this->load->model('servicepackage_model');
49
50            $package = $this->servicepackage_model->getPackage($input['p_id']);
51            $user = $user_info['user'];
52            $us_id = $user_info['us_id'];
53            $user = $this->user_model->get_user_by_id($us_id);
54            $result['can_buy'] = 1;
55            $result['can_edit'] = 0;
56            if ($user['acc_balanced'] < $package['p_price']) {
57                $result['can_buy'] = 0;
58            }
59           
60            if ($user['p_id'] < 1) {
61                $result['can_edit'] = 1;
62            }
63            if ($info['fullname']=="")
64            {
65                $result['can_edit'] = 1;
66            }
67            $result['info'] = $info;
68            $result['user'] = $user;
69            $result['package'] = $package;
70            $result['modal'] = $this->load->view('frontend/package_register_modal', $result, true);
71        } else {
72           
73        }
74        echo json_encode($result);
75    }
76
77    public function finishRegisterPackage() {
78        $result = array();
79        $result['success'] = 0;
80        $this->load->model('user_model');
81        $input = $this->input->post();
82        $user_info = $this->session->userdata('userInfo');
83        parse_str($user_info['user'], $info);
84        if (isset($input['fullname'])) {
85            if (strlen($input['fullname']) < 1) {
86                $result['errors'][] = lang('_SBG_REGISTER_VIP_FULLNAME_REQUIRED_MSG');
87            }
88            if (strlen($input['school']) < 1) {
89                $result['errors'][] = lang('_SBG_REGISTER_VIP_SCHOOL_REQUIRED_MSG');
90            }
91            if (!isset($result['errors'])) {
92                $user_info = $this->session->userdata('userInfo');
93                if ($user_info) {
94
95                    $src = "SBG";
96                    $us_id = $user_info['us_id'];
97                    $input['password'] = '';
98                    $input['oldpass'] = '';
99                    $input['gender'] = '';
100                    $input['email'] = '';
101                    $input['province'] = '';
102                    $info['fullname'] = $input['fullname'];
103                    $info['school'] = $input['school'];
104                    $token = md5($us_id . self::TOKENPW);
105                    $user = $this->get_data($src, $token, $us_id);
106                                        $input['district'] = '';
107                    if ($input) {
108                        $this->load->model('user_model');
109                        $update = $this->user_model->update_user($src, $token, $input, $us_id);
110                        $info = urldecode(http_build_query($info));
111                        $userdata = array('username' => $user_info['username'], 'user' => $info, 'us_id' => $user_info['us_id'], 'logined_in' => TRUE, 'is_viettel' => $user_info['is_viettel']);
112                        $this->session->set_userdata('userInfo', $userdata);
113                    }
114                }
115            }
116        }
117       
118        if (isset($result['errors'])) {
119            echo json_encode($result);
120            exit();
121        }
122       
123        $this->load->model('servicepackage_model');
124        $us_id = $user_info['us_id'];
125        //$user = $this->user_model->get_user_by_id($us_id);
126                $user = $this->user_model->getUserById($us_id);
127        $package = $this->servicepackage_model->getPackage($input['p_id']);
128        $user['acc_balanced'] = $user['acc_balanced'] - $package['p_price'];
129       
130        $currentExpireDate = $user['expire_date'] == NULL || trim($user['expire_date']) == '' ? date('Y-m-d 00:00:00') : $user['expire_date'];
131        $user['expire_date'] = date('Y-m-d', strtotime("+" . $package['p_period'] . " ".$package['p_unit'], strtotime($currentExpireDate)));
132        $user['p_id'] = $package['p_id'];
133                $user['district'] = '';
134        $this->user_model->updateUser($us_id, $user);
135        $user['expire_date'] = date("d-m-Y", (strtotime($user['expire_date'])));
136        $result['expire_date'] = $user['expire_date'];
137        $result['success'] = 1;
138        $message = str_replace(':period:', date("d/m/Y", (strtotime($user['expire_date']))), lang('_SBG_REGISTER_VIP_SUCCESS_MSG'));
139        $result['message'] = $message;
140
141                $toDate = date("Y-m-d", (strtotime($result['expire_date'])));
142                $this->user_model->insertRegisterVipLog($user['cellphone'],$package['p_code'], false);
143        echo json_encode($result);
144    }
145
146    public function regpackage() {
147        $user_info = $this->session->userdata('userInfo');
148        parse_str($user_info['user'], $info);
149        $p_id = $this->input->post('p_id', TRUE);
150
151        $us_id = (int) $info['id'];
152        $this->load->model('servicepackage_model');
153        $this->load->model('user_model');
154
155        $user = $this->user_model->get_user_by_id($us_id);
156        $package = $this->servicepackage_model->getPackage($p_id);
157
158        if ($user['acc_balanced'] < $package['p_price']) {
159                        $aryPatterns = array('/:acc_balanced:/');
160                        $message = preg_replace($aryPatterns, array(number_format($user['acc_balanced'], 0)), lang('_SBG_ACC_BALANCE_LESS_PACKAGE_PRICE_MSG'));
161        } else {
162            $user['acc_balanced'] = $user['acc_balanced'] - $package['p_price'];
163            $currentExpireDate = $user['expire_date'] == NULL || trim($user['expire_date']) == '' ? date('Y-m-d 00:00:00') : $user['expire_date'];
164
165            $user['expire_date'] = date('Y-m-d', strtotime("+" . $package['p_period'] . " " . $package['p_unit'], strtotime($currentExpireDate)));
166            //$user['expire_date'] = date("Y-m-d", (strtotime($user['expire_date']) - 1));
167
168            $user['p_id'] = $package['p_id'];
169
170            $this->user_model->updateUser($us_id, $user);
171                        $aryPatterns = array('/:period:/');
172                        $message = preg_replace($aryPatterns, array(date('d-m-Y', strtotime($user['expire_date']))), lang('_SBG_REGISTER_VIP_SUCCESS_MS'));
173                        $this->user_model->insertRegisterVipLog($user['cellphone'], $package['p_code'], false);
174        }
175
176        $this->session->set_flashdata('message', $message);
177        redirect('frontend/user/profile#services-register');
178    }
179
180    private function get_data($src, $token, $us_id) {
181        $this->load->model('user_model');
182        $user = $this->user_model->get_user_info($src, $token, $us_id);
183
184        if (strpos($user, '&')) {
185            parse_str($user);
186            $us = $this->user_model->get_user_by_id($us_id);
187            $data = array('us_id' => $us_id, 'username' => $username, 'fullname' => $fullname,
188                'gender' => $gender, 'email' => $email, 'phone' => $phone, 'school' => $school, 'province' => $province,
189                'acc_balanced' => $us['acc_balanced'], 'expire_date' => $us['expire_date'], 'date_diff' => $this->dateDiff($us['expire_date'])
190            );
191            return $data;
192        } else {
193            return "";
194        }
195    }
196
197    private function dateDiff($expire_date) {
198        $date1 = date("Y-m-d");
199        if ((strtotime($expire_date) - strtotime($date1)) < 0)
200            return "0 ngày còn lại";
201        $diff = strtotime($expire_date) - strtotime($date1);
202        $years = floor($diff / (365 * 60 * 60 * 24));
203        $months = floor(($diff - $years * 365 * 60 * 60 * 24) / (30 * 60 * 60 * 24));
204        $days = floor(($diff - $years * 365 * 60 * 60 * 24 - $months * 30 * 60 * 60 * 24) / (60 * 60 * 24));
205        if ($years > 0) {
206            return $years . " năm, " . $months . " tháng, " . $days . " ngày còn lại";
207        } else {
208            if ($months > 0) {
209                return $months . " tháng, " . $days . " ngày còn lại";
210            } else {
211                return $days . " ngày còn lại";
212            }
213        }
214    }
215   
216        public function update_info() {
217        $result['success'] = 0;
218        $user_info = $this->session->userdata('userInfo');
219        if ($user_info) {
220            $us_id = $user_info['us_id'];
221            $result = array();
222            $result['success'] = 0;
223            $src = "SBG";
224            $token = md5($us_id . self::TOKENPW);
225            $user = $this->get_data($src, $token, $us_id);
226            $input = $this->input->post();
227            parse_str($user_info['user'], $info);
228            if ($input) {
229                if (strlen($input['fullname']) == 0) {
230                    $result['errors'][] = array("content"=>lang('_SBG_FULLNAME_REQUIRED_MSG'),"field"=>"fullname");
231                }
232                if (strlen($input['school']) == 0) {
233                    $result['errors'][] = array("content"=>lang('_SBG_REGISTER_VIP_SCHOOL_REQUIRED_MSG'),"field"=>"school");
234                }
235
236                $input['password'] = '';
237                $input['oldpass'] = '';
238                $input['province'] = '';
239                $this->load->model('user_model');
240                if (!isset($result['errors'])) {
241                    $result['data'] = $this->user_model->update_user($src, $token, $input, $us_id);
242                    $result['success'] = 1;
243                    $info['fullname'] = $input['fullname'];
244                    $info['school'] = $input['school'];
245                    $info = urldecode(http_build_query($info));
246                    $userdata = array('username' => $user_info['username'], 'user' => $info, 'us_id' => $user_info['us_id'], 'logined_in' => TRUE, 'is_viettel' => $user_info['is_viettel']);
247                    $this->session->set_userdata('userInfo', $userdata);
248                }
249                echo json_encode($result);
250            }
251        } else {
252            redirect('frontend/home');
253        }
254    }
255   
256    public function update_user() {
257        $us_id = $this->uri->segment(4);
258        $user_info = $this->session->userdata('userInfo');
259        if ($user_info) {
260            $result = array();
261            $result['success'] = 0;
262            $src = "SBG";
263            $token = md5($us_id . self::TOKENPW);
264            $user = $this->get_data($src, $token, $us_id);
265            $input = $this->input->post();
266            if ($input) {
267                $input['username'] = $user['username'];
268                if (array_key_exists('fullname', $input)) {
269                    if (strlen($input['fullname']) == 0) {
270                        $result['errors']['fullname_err'] = lang('_SBG_FULLNAME_REQUIRED_MSG');
271                    }
272                } else {
273                    $input['fullname'] = $user['fullname'];
274                }
275
276                $input['password'] = '';
277                $input['oldpass'] = '';
278                $this->load->model('user_model');
279                if (!isset($result['errors'])) {
280                    $result['data'] = $this->user_model->update_user($src, $token, $input, $us_id);
281                    $result['success'] = 1;
282                }
283                echo json_encode($result);
284            }
285        } else {
286            redirect('frontend/home');
287        }
288    }
289
290    public function change_password() {
291        $us_id = $this->uri->segment(4);
292        $user_info = $this->session->userdata('userInfo');
293        if ($user_info) {
294            $this->load->model('user_model');
295            $us_id = $user_info['us_id'];
296            $src = "SBG";
297            $token = md5($us_id . self::TOKENPW);
298            $input = $this->input->post();
299
300            if (strlen($input['passwd']) == 0) {
301                $result['errors']['passwd_old_err'] = lang('_SBG_PASSWORD_REQUIRED_MSG');
302            }
303                       
304            if (strlen($input['passwd_new']) == 0) {
305                $result['errors']['passwd_new_err'] = lang('_SBG_PASSWORD_REQUIRED_MSG');
306            } else if (strcmp($input['passwd'], $input['passwd_new']) == 0) {
307                $result['errors']['passwd_new_err'] = lang('_SBG_PASSWORD_DUPLICATE_MSG');
308            }else
309                        {
310                                if (!preg_match('/^([0-9a-zA-Z]{6,65})*$/', $input['passwd_new']))
311                                {
312                                        $result['errors']['passwd_new_err'] = lang('_SBG_USER_PASSWORD_CHANGE_REQUIRED_MSG');
313                                }
314                        }
315                       
316            if ($input['passwd_new'] != $input['confirm_passwd_new']) {
317                $result['errors']['confirm_passwd_new_err'] = lang('_SBG_PASSWORD_CONFIRM_MSG');
318            }
319
320            if (!isset($result['errors'])) {
321                $user = array('username' => $user_info['username'], 'fullname' => null, 'gender' => null, 'email' => null, 'school' => null, 'province' => null, 'password' => $input['passwd_new'], 'oldpass' => $input['passwd']);
322                $data = $this->user_model->update_user($src, $token, $user, $us_id);
323                parse_str($data);
324                switch ($status) {
325                    case 0:
326                        $result['success'] = 1;
327                        break;
328                    case 6:
329                        $result['errors']['passwd_old_err'] = lang('_SBG_OLD_PASSWORD_FAIL_MSG');
330                        break;
331                    default:
332                        break;
333                }
334            }
335
336            echo json_encode($result);
337        } else {
338            redirect('frontend/home');
339        }
340    }
341       
342        public function trade_history()
343        {
344                $this->load->helper('pagging');
345                $us_id = $this->uri->segment(4);
346
347        $user_info = $this->session->userdata('userInfo');
348                $admin_info = $this->session->userdata('adminInfo');
349
350        if ($user_info || $admin_info)
351                {
352                        $data['us_id'] = $us_id;
353                        $data['perpage'] = 10;
354                        $data['current_page'] = $this->uri->segment(6, 1);
355                        $data['start'] = ($data['current_page'] - 1) * $data['perpage'];
356                        $this->load->model('user_model');
357                        $result = $this->user_model->getPaidlog($data);
358                        $data['total'] = $this->user_model->countPaiglogs($us_id);
359                        $data['num_links'] = 2;
360                        $data['paging_url'] = base_url() . "frontend/user/trade_history/".$us_id."/page/";
361                        $data['paging'] = pagging($data);
362                        $paidlogs = array();
363                        foreach ($result as $paidlog):
364                                $paidlog['amount'] = number_format($paidlog['amount'], 0);
365                                $paidlog['paid_time'] = date('d/m/Y H:i:s', strtotime($paidlog['paid_time']));
366                                array_push($paidlogs, $paidlog);
367                        endforeach;
368                        $data['paidlogs'] = $paidlogs;
369                        echo json_encode($data);
370                }else {
371            redirect('frontend/home');
372        }
373        }
374       
375        public function regis_history()
376        {
377                $this->load->helper('pagging');
378                $us_id = $this->uri->segment(4);
379                $this->load->model('user_model');
380                $user = $this->user_model->get_user_by_id($us_id);
381                $username = $user['cellphone'];
382                $user_info = $this->session->userdata('userInfo');
383                $admin_info = $this->session->userdata('adminInfo');
384                if ($user_info || $admin_info)
385                {
386                        $data['username'] = $username;
387                        $data['perpage'] = 10;
388                        $data['current_page'] = $this->uri->segment(6, 1);
389                        $data['start'] = ($data['current_page'] - 1) * $data['perpage'];
390                        $this->load->model('user_model');
391                        $result = $this->user_model->getPackagelog($data);
392                        $data['total'] = $this->user_model->countPackagelogs($username);
393                        $data['num_links'] = 2;
394                        $data['paging_url'] = base_url() . "frontend/user/regis_history/".$us_id."/page/";
395                        $data['paging'] = pagging($data);
396                        $packagelogs = array();
397                        foreach ($result as $packagelog):
398                                $packagelog['created_time'] = date('d/m/Y H:i:s', strtotime($packagelog['created_time']));
399                                array_push($packagelogs, $packagelog);
400                        endforeach;
401                        $data['packagelogs'] = $packagelogs;
402                        echo json_encode($data);
403                }else
404                {
405                         redirect('frontend/home');
406                }
407               
408        }
409
410}
Note: See TracBrowser for help on using the repository browser.