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

Last change on this file since 633 was 633, checked in by namnd, 11 years ago
File size: 15.5 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    }
14
15    public function profile() {
16        $user_info = $this->session->userdata('userInfo');
17        if ($user_info) {
18            $this->load->model('user_model');
19            $this->load->model('servicepackage_model');
20            $user = $user_info['user'];
21            $us_id = $user_info['us_id'];
22            $src = "SBG";
23            $token = md5($us_id . self::TOKENPW);
24            $data = $this->get_data($src, $token, $us_id);
25            $u = $this->user_model->get_user_by_id($us_id);
26            $data['current_tab'] = $this->uri->segment(4, 'edit-basic');
27            $data['packages'] = $this->servicepackage_model->getAllPackages();
28            $data['is_viettel'] = $user_info['is_viettel'];
29           
30            $data = array_merge($data, $u);
31            $data = array_merge($data, $user_info);
32                       
33            $this->load->view('frontend/user_profile', $data);
34        } else {
35            redirect('frontend/home');
36        }
37    }
38
39    public function packageRegister() {
40        $result = array();
41        $input = $this->input->post();
42        $this->load->model('user_model');
43        $user_info = $this->session->userdata('userInfo');
44        if ($user_info) {
45            parse_str($user_info['user'], $info);
46            $this->load->model('servicepackage_model');
47
48            $package = $this->servicepackage_model->getPackage($input['p_id']);
49            $user = $user_info['user'];
50            $us_id = $user_info['us_id'];
51            $user = $this->user_model->get_user_by_id($us_id);
52            $result['can_buy'] = 1;
53            $result['can_edit'] = 0;
54            if ($user['acc_balanced'] < $package['p_price']) {
55                $result['can_buy'] = 0;
56            }
57           
58            if ($user['p_id'] < 1) {
59                $result['can_edit'] = 1;
60            }
61            if ($info['fullname']=="")
62            {
63                $result['can_edit'] = 1;
64            }
65            $result['info'] = $info;
66            $result['user'] = $user;
67            $result['package'] = $package;
68            $result['modal'] = $this->load->view('frontend/package_register_modal', $result, true);
69        } else {
70           
71        }
72        echo json_encode($result);
73    }
74
75    public function finishRegisterPackage() {
76        $result = array();
77        $result['success'] = 0;
78        $this->load->model('user_model');
79        $input = $this->input->post();
80        $user_info = $this->session->userdata('userInfo');
81        parse_str($user_info['user'], $info);
82        if (isset($input['fullname'])) {
83            if (strlen($input['fullname']) < 1) {
84                $result['errors'][] = "Vui lòng nhập họ tên đầy đủ tiếng Việt";
85            }
86            if (strlen($input['school']) < 1) {
87                $result['errors'][] = "Vui lòng nhập đơn vị cÃŽng tác";
88            }
89            if (!isset($result['errors'])) {
90                $user_info = $this->session->userdata('userInfo');
91                if ($user_info) {
92
93                    $src = "SBG";
94                    $us_id = $user_info['us_id'];
95                    $input['password'] = '';
96                    $input['oldpass'] = '';
97                    $input['gender'] = '';
98                    $input['email'] = '';
99                    $input['province'] = '';
100                    $info['fullname'] = $input['fullname'];
101                    $info['school'] = $input['school'];
102                    $token = md5($us_id . self::TOKENPW);
103                    $user = $this->get_data($src, $token, $us_id);
104                    if ($input) {
105                        $this->load->model('user_model');
106                        $update = $this->user_model->update_user($src, $token, $input, $us_id);
107                        $info = urldecode(http_build_query($info));
108                        $userdata = array('username' => $user_info['username'], 'user' => $info, 'us_id' => $user_info['us_id'], 'logined_in' => TRUE, 'is_viettel' => $user_info['is_viettel']);
109                        $this->session->set_userdata('userInfo', $userdata);
110                    }
111                }
112            }
113        }
114        if (isset($result['errors'])) {
115            echo json_encode($result);
116            die();
117        }
118        $this->load->model('servicepackage_model');
119        $us_id = $user_info['us_id'];
120        $user = $this->user_model->get_user_by_id($us_id);
121        $package = $this->servicepackage_model->getPackage($input['p_id']);
122        $user['acc_balanced'] = $user['acc_balanced'] - $package['p_price'];
123       
124        $currentExpireDate = $user['expire_date'] == NULL || trim($user['expire_date']) == '' ? date('Y-m-d 00:00:00') : $user['expire_date'];
125        $user['expire_date'] = date('Y-m-d', strtotime("+" . $package['p_period'] . " ".$package['p_unit'], strtotime($currentExpireDate)));
126        $user['p_id'] = $package['p_id'];
127        $this->user_model->updateUser($us_id, $user);
128        $user['expire_date'] = date("d-m-Y", (strtotime($user['expire_date'])));
129        $result['expire_date'] = $user['expire_date'];
130        $result['success'] = 1;
131                $source = 'web';
132                $toDate = date("Y-m-d", (strtotime($result['expire_date'])));
133                $this->user_model->insertRegisterVipLog($source,  $package['p_code'], $toDate);
134        echo json_encode($result);
135    }
136
137    public function regpackage() {
138        $user_info = $this->session->userdata('userInfo');
139        parse_str($user_info['user'], $info);
140        $p_id = $this->input->post('p_id', TRUE);
141
142        $us_id = (int) $info['id'];
143        $this->load->model('servicepackage_model');
144        $this->load->model('user_model');
145
146        $user = $this->user_model->get_user_by_id($us_id);
147        $package = $this->servicepackage_model->getPackage($p_id);
148
149        if ($user['acc_balanced'] < $package['p_price']) {
150            $message = 'Số tiền trong Tài khoản SBG Online hiện tại cá»§a QuÜ vị là ' . $user['acc_balanced'] . ' đồng.<br /> Để Đăng kí Sá»­ dụng dịch vụ Soạn Bài giảng trá»±c tuyến, QuÜ vị cần nạp thêm tiền vào tài khoản.';
151        } else {
152            $user['acc_balanced'] = $user['acc_balanced'] - $package['p_price'];
153            $currentExpireDate = $user['expire_date'] == NULL || trim($user['expire_date']) == '' ? date('Y-m-d 00:00:00') : $user['expire_date'];
154
155            $user['expire_date'] = date('Y-m-d', strtotime("+" . $package['p_period'] . " " . $package['p_unit'], strtotime($currentExpireDate)));
156            //$user['expire_date'] = date("Y-m-d", (strtotime($user['expire_date']) - 1));
157
158            $user['p_id'] = $package['p_id'];
159
160            $this->user_model->updateUser($us_id, $user);
161                        $source = 'web';
162                        $this->user_model->insertRegisterVipLog($source,  $package['p_code']);
163            $message = 'QuÜ vị đã đăng kí sá»­ dụng CÃŽng cụ Soạn Bài giảng trức tuyến. QuÜ vị được sá»­ dụng dịch vụ đến hết ngày ' . date('d-m-Y', strtotime($user['expire_date']));
164        }
165
166        $this->session->set_flashdata('message', $message);
167        redirect('frontend/user/profile#services-register');
168    }
169
170    private function get_data($src, $token, $us_id) {
171        $this->load->model('user_model');
172        $user = $this->user_model->get_user_info($src, $token, $us_id);
173
174        if (strpos($user, '&')) {
175            parse_str($user);
176            $us = $this->user_model->get_user_by_id($us_id);
177            $data = array('us_id' => $us_id, 'username' => $username, 'fullname' => $fullname,
178                'gender' => $gender, 'email' => $email, 'phone' => $phone, 'school' => $school, 'province' => $province,
179                'acc_balanced' => $us['acc_balanced'], 'expire_date' => $us['expire_date'], 'date_diff' => $this->dateDiff($us['expire_date'])
180            );
181            return $data;
182        } else {
183            return "";
184        }
185    }
186
187    private function dateDiff($expire_date) {
188        $date1 = date("Y-m-d");
189        if ((strtotime($expire_date) - strtotime($date1)) < 0)
190            return "0 ngày còn lại";
191        $diff = strtotime($expire_date) - strtotime($date1);
192        $years = floor($diff / (365 * 60 * 60 * 24));
193        $months = floor(($diff - $years * 365 * 60 * 60 * 24) / (30 * 60 * 60 * 24));
194        $days = floor(($diff - $years * 365 * 60 * 60 * 24 - $months * 30 * 60 * 60 * 24) / (60 * 60 * 24));
195        if ($years > 0) {
196            return $years . " năm, " . $months . " tháng, " . $days . " ngày còn lại";
197        } else {
198            if ($months > 0) {
199                return $months . " tháng, " . $days . " ngày còn lại";
200            } else {
201                return $days . " ngày còn lại";
202            }
203        }
204    }
205   
206        public function update_info() {
207        $result['success']=0;
208        $user_info = $this->session->userdata('userInfo');
209        if ($user_info) {
210            $us_id = $user_info['us_id'];
211            $result = array();
212            $result['success'] = 0;
213            $src = "SBG";
214            $token = md5($us_id . self::TOKENPW);
215            $user = $this->get_data($src, $token, $us_id);
216            $input = $this->input->post();
217            parse_str($user_info['user'], $info);
218            if ($input) {
219                if (strlen($input['fullname']) == 0) {
220                    $result['errors'][] = array("content"=>"Họ tên khÃŽng được để trống!","field"=>"fullname");
221                }
222                if (strlen($input['school']) == 0) {
223                    $result['errors'][] = array("content"=>"Tên đơn vị khÃŽng được để trống!","field"=>"school");
224                }
225
226                $input['password'] = '';
227                $input['oldpass'] = '';
228                $input['province'] = '';
229                $this->load->model('user_model');
230                if (!isset($result['errors'])) {
231                    $result['data'] = $this->user_model->update_user($src, $token, $input, $us_id);
232                    $result['success'] = 1;
233                    $info['fullname']=$input['fullname'];
234                    $info['school']=$input['school'];
235                    $info = urldecode(http_build_query($info));
236                    $userdata = array('username' => $user_info['username'], 'user' => $info, 'us_id' => $user_info['us_id'], 'logined_in' => TRUE, 'is_viettel' => $user_info['is_viettel']);
237                    $this->session->set_userdata('userInfo', $userdata);
238                }
239                echo json_encode($result);
240            }
241        } else {
242            redirect('frontend/home');
243        }
244    }
245   
246    public function update_user() {
247        $us_id = $this->uri->segment(4);
248        $user_info = $this->session->userdata('userInfo');
249        if ($user_info) {
250            $result = array();
251            $result['success'] = 0;
252            $src = "SBG";
253            $token = md5($us_id . self::TOKENPW);
254            $user = $this->get_data($src, $token, $us_id);
255            $input = $this->input->post();
256            if ($input) {
257                $input['username'] = $user['username'];
258                if (array_key_exists('fullname', $input)) {
259                    if (strlen($input['fullname']) == 0) {
260                        $result['errors']['fullname_err'] = "Họ tên khÃŽng được để trống!";
261                    }
262                } else {
263                    $input['fullname'] = $user['fullname'];
264                }
265
266                $input['password'] = '';
267                $input['oldpass'] = '';
268                $this->load->model('user_model');
269                if (!isset($result['errors'])) {
270                    $result['data'] = $this->user_model->update_user($src, $token, $input, $us_id);
271                    $result['success'] = 1;
272                }
273                echo json_encode($result);
274            }
275        } else {
276            redirect('frontend/home');
277        }
278    }
279
280    public function change_password() {
281        $us_id = $this->uri->segment(4);
282        $user_info = $this->session->userdata('userInfo');
283        if ($user_info) {
284            $this->load->model('user_model');
285            $us_id = $user_info['us_id'];
286            $src = "SBG";
287            $token = md5($us_id . self::TOKENPW);
288            $input = $this->input->post();
289
290            if (strlen($input['passwd']) == 0) {
291                $result['errors']['passwd_old_err'] = "Mật khẩu khÃŽng được để trống!";
292            }
293                       
294            if (strlen($input['passwd_new']) == 0) {
295                $result['errors']['passwd_new_err'] = "Mật khẩu khÃŽng được để trống!";
296            } else if (strcmp($input['passwd'], $input['passwd_new']) == 0) {
297                $result['errors']['passwd_new_err'] = "Mật khẩu trùng với mật khẩu hiện tại!";
298            }else
299                        {
300                                if (!preg_match('/^([0-9a-zA-Z]{6,65})*$/', $input['passwd_new']))
301                                {
302                                        $result['errors']['passwd_new_err'] = "Mật khẩu ít nhất là 6 kí tá»±, và chỉ chứa các kí tá»± số hoặc chữ, <br> khÃŽng chứa khoảng trắng và khÃŽng chứa kÜ tá»± đặc biệt!";
303                                }
304                        }
305                       
306            if ($input['passwd_new'] != $input['confirm_passwd_new']) {
307                $result['errors']['confirm_passwd_new_err'] = "Mật khẩu khÃŽng trùng nhau!";
308            }
309
310            if (!isset($result['errors'])) {
311                $user = array('username' => $user_info['username'], 'fullname' => null, 'gender' => null, 'email' => null, 'school' => null, 'province' => null, 'password' => $input['passwd_new'], 'oldpass' => $input['passwd']);
312                $data = $this->user_model->update_user($src, $token, $user, $us_id);
313                parse_str($data);
314                switch ($status) {
315                    case 0:
316                        $result['success'] = 1;
317                        break;
318                    case 6:
319                        $result['errors']['passwd_old_err'] = "Mật khẩu cung cấp khÃŽng đúng!";
320                        break;
321                    default:
322                        break;
323                }
324            }
325
326            echo json_encode($result);
327        } else {
328            redirect('frontend/home');
329        }
330    }
331       
332        public function trade_history()
333        {
334                $this->load->helper('pagging');
335                $us_id = $this->uri->segment(4);
336        $user_info = $this->session->userdata('userInfo');
337        if ($user_info)
338                {
339                       
340                        $data['us_id'] = $us_id;
341                        $data['perpage'] = 10;
342                        $data['current_page'] = $this->uri->segment(6, 1);
343                        $data['start'] = ($data['current_page'] - 1) * $data['perpage'];
344                        $this->load->model('user_model');
345                        $result = $this->user_model->getPaidlog($data);
346                        $data['total'] = $this->user_model->countPaiglogs($us_id);
347                        $data['num_links'] = 2;
348                        $data['paging_url'] = base_url() . "frontend/user/trade_history/".$us_id."/page/";
349                        $data['paging'] = pagging($data);
350                        $paidlogs = array();
351                        foreach ($result as $paidlog):
352                                $paidlog['amount'] = number_format($paidlog['amount'], 0);
353                                $paidlog['paid_time'] = date('d-m-Y H:i:s', strtotime($paidlog['paid_time']));
354                                array_push($paidlogs, $paidlog);
355                        endforeach;
356                        $data['paidlogs'] = $paidlogs;
357                        echo json_encode($data);
358                }else {
359            redirect('frontend/home');
360        }
361        }
362
363}
Note: See TracBrowser for help on using the repository browser.