mirror of
https://github.com/gamaio/lobli.git
synced 2025-01-08 17:52:50 +00:00
Work on tracking function
It doesn't quite work yet, but it should soon
This commit is contained in:
parent
d9d8338a3d
commit
ab4010b41f
@ -1,105 +1,88 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
require('Include/PHP/db.php');
|
require('Include/PHP/db.php');
|
||||||
|
|
||||||
// Returns will be in the structure: response code seperator extra data and will be formatted client side
|
// Returns will be in the structure: response code seperator extra data and will be formatted client side
|
||||||
/*
|
/*
|
||||||
Response codes:
|
Response codes:
|
||||||
0 - Successful shorten
|
0 - Successful shorten
|
||||||
1 - Existing link found
|
1 - Existing link found
|
||||||
2 - Dead link
|
2 - Dead link
|
||||||
3 - Database Error
|
3 - Database Error
|
||||||
4 - Sanitize failed
|
4 - Sanitize failed
|
||||||
5 - Successful lob.li link resolve
|
5 - Successful lob.li link resolve
|
||||||
6 - Successful lookup of non-lob.li link
|
6 - Successful lookup of non-lob.li link
|
||||||
7 - Unsuccessful lookup of non-lob.li link
|
7 - Unsuccessful lookup of non-lob.li link
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function shorten($sdb, $link, $seperator){
|
function shorten($sdb, $link, $seperator){
|
||||||
$sql = "SELECT * FROM `links` WHERE `link` = '$link' LIMIT 1;";
|
$sql = "SELECT * FROM `links` WHERE `link` = '$link' LIMIT 1;";
|
||||||
if($result = $sdb->query($sql)){
|
if($result = $sdb->query($sql)){
|
||||||
if($row = $result->fetch_assoc()){
|
if($row = $result->fetch_assoc()){
|
||||||
$short = $row['shortlink'];
|
$short = $row['shortlink'];
|
||||||
return "1$seperator$short";
|
return "1$seperator$short";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(checkRemoteFile($link) !== true) return "2$seperator$link";
|
if(checkRemoteFile($link) !== true) return "2$seperator$link";
|
||||||
$title = getRemoteTitle($link);
|
$title = getRemoteTitle($link);
|
||||||
|
|
||||||
$short = substr(number_format(time() * mt_rand(),0,'',''),0,5);
|
$short = substr(number_format(time() * mt_rand(),0,'',''),0,5);
|
||||||
$short = base_convert($short, 10, 36);
|
$short = base_convert($short, 10, 36);
|
||||||
|
|
||||||
$dpass = substr(number_format(time() * mt_rand(),0,'',''),0,10);
|
$dpass = substr(number_format(time() * mt_rand(),0,'',''),0,10);
|
||||||
$dpass = base_convert($short.$dpass, 10, 36);
|
$dpass = base_convert($short.$dpass, 10, 36);
|
||||||
|
|
||||||
$sql = "INSERT INTO `links` (link, shortlink, title, dpass, ddate) VALUES ('$link', '$short', '$title', '$dpass', NOW())";
|
$sql = "INSERT INTO `links` (link, shortlink, title, dpass, ddate) VALUES ('$link', '$short', '$title', '$dpass', NOW())";
|
||||||
|
|
||||||
if($result = $sdb->query($sql)): return "0$seperator$short$seperator$title";
|
if($result = $sdb->query($sql)): return "0$seperator$short$seperator$title";
|
||||||
else: return '3'.$seperator.$sdb->error;
|
else: return '3'.$seperator.$sdb->error;
|
||||||
endif;
|
endif;
|
||||||
}
|
}
|
||||||
|
|
||||||
function stats($sdb, $seperator){
|
function stats($sdb, $seperator){
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function tracking($sdb, $lId){ // Very basic - counts number of total visits to a certain short link
|
function getRemoteTitle($url){
|
||||||
$sql = "SELECT * FROM `tracking` WHERE `id` = '$lId' LIMIT 1;"; // Testing to see if the link has been visited before
|
$url = parse_url($url);
|
||||||
if($result = $sdb->query($sql)){
|
$tags = get_meta_tags($url['scheme'].'://'.$url['host']);
|
||||||
if($row = $result->fetch_assoc()){
|
$ret = sanitize($tags['description']);
|
||||||
$sql = "UPDATE `tracking` SET `clicks` = `clicks` + 1 WHERE `id` = '$lId'"; // Yes it has, increment clicks by 1
|
return $ret;
|
||||||
if($result = $sdb->query($sql)){}else{
|
}
|
||||||
return $sdb->error;
|
|
||||||
}
|
function checkRemoteFile($ip=null){
|
||||||
}
|
if($ip==null) return false;
|
||||||
}else{
|
|
||||||
$sql = "INSERT INTO `tracking` (id, clicks) VALUES ('$lId', 1)"; // No it hasn't, add 1 click to the table
|
// Setup the connection and only get the headers
|
||||||
if($result = $sdb->query($sql)){}else{
|
$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,";
|
||||||
return $sdb->error;
|
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5";
|
||||||
}
|
$header[] = "Cache-Control: max-age=0";
|
||||||
}
|
$header[] = "Connection: keep-alive";
|
||||||
}
|
$header[] = "Keep-Alive: 300";
|
||||||
|
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7";
|
||||||
function getRemoteTitle($url){
|
$header[] = "Accept-Language: en-us,en;q=0.5";
|
||||||
$url = parse_url($url);
|
$header[] = "Pragma: ";
|
||||||
$tags = get_meta_tags($url['scheme'].'://'.$url['host']);
|
|
||||||
$ret = sanitize($tags['description']);
|
$curlInit = curl_init($ip);
|
||||||
return $ret;
|
curl_setopt($curlInit, CURLOPT_CONNECTTIMEOUT, 10);
|
||||||
}
|
curl_setopt($curlInit, CURLOPT_HEADER, true);
|
||||||
|
curl_setopt($curlInit, CURLOPT_RETURNTRANSFER, true);
|
||||||
function checkRemoteFile($ip=null){
|
curl_setopt($curlInit, CURLOPT_USERAGENT, 'UnPS-GAMATechnologies (UnPS WebQuery/4-2.9; +http://lob.li)');
|
||||||
if($ip==null) return false;
|
curl_setopt($curlInit, CURLOPT_HTTPHEADER, $header);
|
||||||
|
|
||||||
// Setup the connection and only get the headers
|
$response = curl_exec($curlInit);
|
||||||
$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,";
|
curl_close($curlInit);
|
||||||
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5";
|
|
||||||
$header[] = "Cache-Control: max-age=0";
|
if($response) return true;
|
||||||
$header[] = "Connection: keep-alive";
|
return false;
|
||||||
$header[] = "Keep-Alive: 300";
|
}
|
||||||
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7";
|
|
||||||
$header[] = "Accept-Language: en-us,en;q=0.5";
|
function sanitize($input){
|
||||||
$header[] = "Pragma: ";
|
if ($input == null) die("4");
|
||||||
|
$output = strip_tags($input);
|
||||||
$curlInit = curl_init($ip);
|
$output = stripslashes($output);
|
||||||
curl_setopt($curlInit, CURLOPT_CONNECTTIMEOUT, 10);
|
$output = mysql_real_escape_string($output);
|
||||||
curl_setopt($curlInit, CURLOPT_HEADER, true);
|
return $output;
|
||||||
curl_setopt($curlInit, CURLOPT_RETURNTRANSFER, true);
|
}
|
||||||
curl_setopt($curlInit, CURLOPT_USERAGENT, 'UnPS-GAMATechnologies (UnPS WebQuery/4-2.9; +http://lob.li)');
|
|
||||||
curl_setopt($curlInit, CURLOPT_HTTPHEADER, $header);
|
|
||||||
|
|
||||||
$response = curl_exec($curlInit);
|
|
||||||
curl_close($curlInit);
|
|
||||||
|
|
||||||
if($response) return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function sanitize($input){
|
|
||||||
if ($input == null) die("4");
|
|
||||||
$output = strip_tags($input);
|
|
||||||
$output = stripslashes($output);
|
|
||||||
$output = mysql_real_escape_string($output);
|
|
||||||
return $output;
|
|
||||||
}
|
|
||||||
|
|
||||||
?>
|
?>
|
Loading…
Reference in New Issue
Block a user