-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsettings.php
120 lines (85 loc) · 3.01 KB
/
settings.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php
require_once dirname(__FILE__).'/libs/config.php';
/** @var Database4 $db */
/** @var Smarty $smarty */
//error_reporting(E_ALL);
//ini_set('display_errors','1');
_require_login();
if(!empty($_POST['action'])) {
$user = _get_user_array();
switch ($_POST['action']) {
case 'change_contacts':
$error ='';
if(!filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) {
$error .= 'Invalid e-mail. ';
}
//eliminate every char except 0-9
$phone = preg_replace("/[^0-9]/", '', $_POST['phone']);
if (strlen($phone) < 9){
$error .= "Invalid phone. ";
}
if (strlen($_POST['name']) < 3){
$error .= "Invalid name. ";
}
if(!$error){
$db->query('UPDATE users SET phone = ?, email=?, name=? WHERE id= #',$phone, $_POST['email'], $_POST['name'], $user['id']);
$smarty->assign('success', 'Contacts updated');
}else{
$smarty->assign('error', $error);
}
break;
case 'change_password':
if(!PasswordTools::checkPasswordStrength($_POST['password'])){
$smarty->assign('error', 'Use stronger password');
}elseif($_POST['password'] != $_POST['password2']){
$smarty->assign('error','Passwords do not match');
}else{
$db->query('UPDATE users SET password = ? WHERE id= #', PasswordTools::getHashedPassword($_POST['password']), $user['id']);
$smarty->assign('success', 'Password changed');
}
break;
case 'save_other_settings':
$db->query('UPDATE users SET geolocation_enabled = # WHERE id= #', $_POST['geolocation_enabled'] ? 1 : 0, $user['id']);
$smarty->assign('success', 'Settings saved');
break;
case 'add_phone_control':
// check phone
$error = '';
//eliminate every char except 0-9
$phone = preg_replace("/[^0-9]/", '', $_POST['phone']);
if (strlen($phone) < 9){
$error .= "Invalid phone. ";
}
// check if another user has this phone
if($db->fetch('SELECT 1 FROM phone_control WHERE phone=#', $phone)){
$error .= 'Phone already in use.';
}
if(empty($error)){
try {
$db->query('INSERT INTO phone_control SET user_id=#, phone=#, time_added = NOW()', $user['id'], $phone);
$smarty->assign('success', 'Phone added');
}catch (EDatabase $e){
$error = 'Unknown error';
}
}
if(!empty($error)){
$smarty->assign('error', $error);
}
break;
case 'remove_phone_control':
$db->query('DELETE FROM phone_control WHERE id=# AND user_id=#', $_POST['phone_control_id'], $user['id']);
$smarty->assign('success', 'Phone removed');
break;
}
}
$user = _get_user_array();
$smarty->assign('user', $user);
$smarty->assign('permissions', _get_permissions());
$nukis = array();
$db->queryall('SELECT * FROM nuki WHERE user_id=#', $nukis,'', $user['id']);
$smarty->assign('nukis', $nukis);
$phone_controls = array();
$db->queryall('SELECT * FROM phone_control WHERE user_id=#', $phone_controls,'', $user['id']);
$smarty->assign('phone_controls', $phone_controls);
$smarty->assign('_PHONE_CONTROL_NUMBER', PHONE_CONTROL_NUMBER);
$smarty->display('settings.tpl');