mirror of
https://github.com/gamaio/UnPS-Short.git
synced 2024-11-14 04:57:25 +00:00
3d04529e5a
Based on statistics, the Delete option is never used, so it's useless unps.core.js contains code primarly to change submit button to reflect current selected option
139 lines
5.6 KiB
PHP
139 lines
5.6 KiB
PHP
<?php
|
|
session_start();
|
|
|
|
$appname = " Shortener";
|
|
|
|
// Generate a token on the fly. This should prevent POST spam attacks directly into process.php
|
|
$token = substr(number_format(time() * mt_rand(),0,'',''),0,10);
|
|
$token = base_convert($token, 10, 36);
|
|
$_SESSION['token'] = $token;
|
|
|
|
$catchid = substr(number_format(time() * mt_rand(),0,'',''),0,10);
|
|
$catchVal = hash('sha256', $catchid.mt_rand().time().substr(number_format(time() * mt_rand(),0,'',''),0,10));
|
|
$catchVal = base_convert($catchVal.$catchid, 10, 36);
|
|
$_SESSION['catch'] = $catchid.":".$catchVal;
|
|
|
|
// This has been depreciated. Still here for backwards compatibility with existing links
|
|
if(!empty($_GET['l'])){
|
|
include('api/dbsettings.php');
|
|
$link = $shortdb->real_escape_string(strtolower(stripslashes(strip_tags($_GET['l']))));
|
|
$sql = "SELECT * FROM `links` WHERE `shortlink` = '$link' LIMIT 1;";
|
|
if($result = $shortdb->query($sql)){
|
|
if($row = $result->fetch_assoc()){
|
|
$link = $row['link'];
|
|
header("location:$link");
|
|
exit(); // Stop script execution to save on resources
|
|
}
|
|
}
|
|
}
|
|
|
|
// New way to check for valid short links, two characters shorter than the if statement above
|
|
if(!empty($_GET)){
|
|
$key = key($_GET);
|
|
include('api/dbsettings.php');
|
|
$link = $shortdb->real_escape_string(strtolower(stripslashes(strip_tags($key))));
|
|
$sql = "SELECT * FROM `links` WHERE `shortlink` = '$link' LIMIT 1;";
|
|
if($result = $shortdb->query($sql)){
|
|
if($row = $result->fetch_assoc()){
|
|
$link = $row['link'];
|
|
header("location:$link");
|
|
exit(); // Stop script execution to save on resources
|
|
}
|
|
}
|
|
}
|
|
?>
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml" prefix="og: http://ogp.me/ns# fb: http://www.facebook.com/2008/fbml">
|
|
<head>
|
|
<title>UnPS Link Shortener</title>
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
|
|
<meta name="description" content="UnPS Link Shortener"/>
|
|
<meta name="keywords" content="UnPS, GAMA, Shorten, Link"/>
|
|
<meta name="author" content="David Todd"/>
|
|
<meta property="og:image" content="http://fox.gy/fCDIjceUvkk.png"/>
|
|
|
|
<link href="assets/bootstrap/css/bootstrap.min.css" rel="stylesheet" media="screen" />
|
|
<link href="assets/css/elements.css?<?php echo time(); ?>" rel="stylesheet" />
|
|
|
|
<link rel="shortcut icon" type="image/ico" href="favicon.ico"/>
|
|
<link rel="shortcut icon" type="image/x-icon" href="favicon.ico"/>
|
|
|
|
</head>
|
|
<body>
|
|
<div id="wrap">
|
|
<?php include('navbar.php'); ?>
|
|
|
|
<div class="container" style="float:center;padding-bottom:7%;">
|
|
<p></p>
|
|
</div>
|
|
|
|
<div class="container">
|
|
<form class="form-shorten" id="form-shorten">
|
|
|
|
<h2 class="form-shorten-heading">Please give me a link to shorten...</h2>
|
|
<input type="text" id="link" class="form-control" name="link" placeholder="http://" autofocus>
|
|
<div id="shorten-password">
|
|
<input type="text" id="pass" class="form-control" name="password" placeholder="Password">
|
|
</div>
|
|
|
|
<input type="hidden" name="<?php echo $catchid; ?>" value="<?php echo $catchVal; ?>"/>
|
|
<button class="btn btn-block btn-primary" id="short-button" type="submit">Shorten</button>
|
|
|
|
</form>
|
|
<div id="message">
|
|
<div id="theLoader">
|
|
<div id="ajaxloader"></div><p id="loading">Loading...</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="footer" style="position:absolute;width:100%;bottom:1%;">
|
|
<div class="container">
|
|
<p class="text-muted credit" style="padding-bottom:2.3%;">
|
|
Copyright © 2014 Unified Programming Solutions - Fork me on <a href="https://github.com/alopexc0de/UnPS-Short">GitHub</a>
|
|
<a id="tos-link" href="terms.php">Terms Of Service</a>
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Load the JS after the DOM so speed up load times -->
|
|
<script type="text/javascript" language="JavaScript" src="//ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>
|
|
<script type="text/javascript" language="JavaScript" src="assets/bootstrap/js/bootstrap.min.js"></script>
|
|
|
|
<script type="text/javascript" language="JavaScript">
|
|
jQuery(document).ready(function(){
|
|
$('#link').focus();
|
|
$('#error').fadeIn("fast");
|
|
});
|
|
|
|
function copyToClipboard(text){
|
|
window.prompt ("Copy to clipboard: Ctrl+C, Enter (when closed I will open your link in a new tab)", text);
|
|
}
|
|
</script>
|
|
|
|
<script type="text/javascript" language="JavaScript">
|
|
// This is our AJAX - Thank you Wizzy <3
|
|
$("#form-shorten").submit(function(event){
|
|
$("#theLoader").fadeIn("fast");
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
$.post("process.php?token=<?php echo $token; ?>", $(this).serialize(), function(data){
|
|
$("#message").hide().html(data+'<br /><div class="gab"></div>').fadeIn("fast");
|
|
$("#theLoader").hide();
|
|
if($('#error').length){
|
|
$('#short-button').removeClass('btn-primary');
|
|
$('#short-button').removeClass('btn-success');
|
|
$('#short-button').addClass('btn-danger');
|
|
}else if($('#success').length){
|
|
$('#short-button').removeClass('btn-primary');
|
|
$('#short-button').removeClass('btn-danger');
|
|
$('#short-button').addClass('btn-success');
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|