| 1 | <?php |
|---|
| 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 | if( $_POST['login'] && $_POST['passwd']) |
|---|
| 27 | { |
|---|
| 28 | $user =& $db->getRow('SELECT id, login, fname, lname, nick, status, passwd FROM user WHERE login=? AND (passwd_md5=? OR passwd=OLD_PASSWORD(?))', array( $_POST['login'], md5($_POST['passwd']), $_POST['passwd'])); |
|---|
| 29 | |
|---|
| 30 | if( $user['id'] ) |
|---|
| 31 | { |
|---|
| 32 | |
|---|
| 33 | if(!is_null($user['passwd'])) |
|---|
| 34 | $db->query('UPDATE user SET passwd_md5=?, passwd=NULL WHERE id=?', array(md5($_POST['passwd']), $user['id'])); |
|---|
| 35 | |
|---|
| 36 | session_destroy(); |
|---|
| 37 | session_set_save_handler ('_sess_open', '_sess_close', '_sess_read', '_sess_write', '_sess_destroy', '_sess_gc'); |
|---|
| 38 | session_start(); |
|---|
| 39 | |
|---|
| 40 | $_SESSION['my_ip'] = $_SERVER['REMOTE_ADDR']; |
|---|
| 41 | srand(time()); |
|---|
| 42 | $SecID = md5(rand(1,10000000)); |
|---|
| 43 | setcookie('SecID', $SecID, time()+31536000, '/'); |
|---|
| 44 | $_SESSION['SecID'] = $SecID; |
|---|
| 45 | $_SESSION['status'] = 'member'; |
|---|
| 46 | $_SESSION['my_id'] = $user['id']; |
|---|
| 47 | $_SESSION['my_login'] = $user['login']; |
|---|
| 48 | $_SESSION['my_fname'] = $user['fname']; |
|---|
| 49 | $_SESSION['my_lname'] = $user['lname']; |
|---|
| 50 | $_SESSION['my_nick'] = $user['nick']; |
|---|
| 51 | if($user['status']=='jail') |
|---|
| 52 | { |
|---|
| 53 | session_unset(); |
|---|
| 54 | session_destroy(); |
|---|
| 55 | header('Location: /pub/join'); |
|---|
| 56 | exit(); |
|---|
| 57 | } |
|---|
| 58 | $_SESSION['my_status'] = $user['status']; |
|---|
| 59 | $_SESSION['my_photo'] = build_image_url($user['id']); |
|---|
| 60 | |
|---|
| 61 | $cache_user = get_cache_user_info($user['id'], 'country, friends_id, communities_id'); |
|---|
| 62 | $_SESSION['my_country'] = $cache_user['country']; |
|---|
| 63 | $_SESSION['my_friends_id'] = $cache_user['friends_id']; |
|---|
| 64 | $_SESSION['my_communities_id'] = $cache_user['communities_id']; |
|---|
| 65 | |
|---|
| 66 | $_SESSION['nb_new_messages'] = $db->getOne('SELECT COUNT(id_mess) FROM message WHERE id=? AND flag=? AND box=?', array($_SESSION['my_id'], 'new', 'inbox')); |
|---|
| 67 | $_SESSION['nb_new_messages_timestamp'] = time(); |
|---|
| 68 | |
|---|
| 69 | $_SESSION['lastaction_timestamp'] = 1; |
|---|
| 70 | |
|---|
| 71 | $db->query('UPDATE user SET last_visite=?, ip=? WHERE id=?', array(time(), $_SERVER['REMOTE_ADDR'], $_SESSION['my_id'] )) ; |
|---|
| 72 | |
|---|
| 73 | if($_POST['url']) |
|---|
| 74 | header('Location: '.urldecode($_POST['url'])); |
|---|
| 75 | else |
|---|
| 76 | header('Location: /my'); |
|---|
| 77 | } |
|---|
| 78 | else |
|---|
| 79 | header('Location: /error/wrong_login'); |
|---|
| 80 | } |
|---|
| 81 | else |
|---|
| 82 | header('Location: /error/no_login'); |
|---|
| 83 | |
|---|
| 84 | ?> |
|---|