-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathajax.status.php
103 lines (100 loc) · 3.58 KB
/
ajax.status.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
<?php
/**
* https://github.com/Bigjoos/
* Licence Info: GPL
* Copyright (C) 2010 U-232 v.3
* A bittorrent tracker source based on TBDev.net/tbsource/bytemonsoon.
* Project Leaders: Mindless, putyn.
*
*/
require_once (dirname(__FILE__).DIRECTORY_SEPARATOR.'include'.DIRECTORY_SEPARATOR.'bittorrent.php');
require_once (INCL_DIR.'user_functions.php');
dbconn();
loggedinorreturn();
function url2short($x)
{
preg_match_all('/((http|https)\:\/\/[^()<>\s]+)/i', $x, $t);
if (isset($t[0])) {
foreach ($t[0] as $l) {
if (strpos($l, 'is.gd')) continue;
$shorturls[1][] = file_get_contents('http://is.gd/api.php?longurl='.urlencode($l));
$shorturls[0][] = $l;
}
if (isset($shorturls)) $x = str_replace($shorturls[0], $shorturls[1], $x);
}
return $x;
}
function jsonmsg($arr)
{
global $mc1, $CURUSER;
$mc1->delete_value('userstatus_'.$CURUSER['id']);
$mc1->delete_value('user_status_'.$CURUSER['id']);
return json_encode(array(
'msg' => $arr[0],
'status' => $arr[1]
));
}
$vdo = array(
'edit' => 1,
'delete' => 1,
'new' => 1
);
$do = isset($_POST['action']) && isset($vdo[$_POST['action']]) ? $_POST['action'] : '';
$id = isset($_POST['id']) ? 0 + $_POST['id'] : '';
$ss = isset($_POST['ss']) && !empty($_POST['ss']) ? $_POST['ss'] : '';
switch ($do) {
case 'edit':
if (!empty($ss)) {
if (sql_query('UPDATE ustatus SET last_status = '.sqlesc(url2short($ss)).', last_update = '.TIME_NOW.' WHERE userid ='.sqlesc($CURUSER['id']))) $return = jsonmsg(array(
$ss,
true
));
else $return = jsonmsg(array(
'There was an error, mysql error'.((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res = mysqli_connect_error()) ? $___mysqli_res : false)) ,
false
));
} else $return = jsonmsg(array(
'nothing to update, string empty',
false
));
break;
case 'delete':
$status_history = unserialize($CURUSER['archive']);
if (isset($status_history[$id])) {
unset($status_history[$id]);
if (sql_query('UPDATE ustatus SET archive = '.sqlesc(serialize($status_history)).' WHERE userid = '.sqlesc($CURUSER['id']))) $return = jsonmsg(array(
'ok',
true
));
else $return = jsonmsg(array(
'there was an error',
false
));
} else $return = jsonmsg(array(
'incorrect id',
false
));
break;
case 'new':
$status_archive = ((isset($CURUSER['archive']) && is_array(unserialize($CURUSER['archive']))) ? unserialize($CURUSER['archive']) : array());
if (!empty($CURUSER['last_status'])) $status_archive[] = array(
'status' => $CURUSER['last_status'],
'date' => $CURUSER['last_update']
);
if (sql_query('INSERT INTO ustatus(userid,last_status,last_update,archive) VALUES('.sqlesc($CURUSER['id']).','.sqlesc(url2short($ss)).','.TIME_NOW.','.sqlesc(serialize($status_archive)).') ON DUPLICATE KEY UPDATE last_status=values(last_status),last_update=values(last_update),archive=values(archive)')) $return = jsonmsg(array(
'<h2>Status update successful</h2>',
true
));
else $return = jsonmsg(array(
'There was an error, mysql error'.((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res = mysqli_connect_error()) ? $___mysqli_res : false)) ,
false
));
break;
default:
$return = jsonmsg(array(
'Unknow action',
false
));
}
echo $return;
?>