mirror of
https://github.com/kremalicious/krtmn.git
synced 2025-01-05 03:15:05 +01:00
280 lines
9.0 KiB
PHP
280 lines
9.0 KiB
PHP
|
<?php
|
||
|
define( 'YOURLS_ADMIN', true );
|
||
|
require_once( dirname(dirname(__FILE__)).'/includes/load-yourls.php' );
|
||
|
yourls_maybe_require_auth();
|
||
|
|
||
|
// Variables
|
||
|
$table_url = YOURLS_DB_TABLE_URL;
|
||
|
// Default SQL behavior
|
||
|
$where = $search_display = $search_text = $search_url = $url = $keyword = '';
|
||
|
$search_in_text = 'URL';
|
||
|
$search_in_sql = 'url';
|
||
|
$sort_by_text = 'Short URL';
|
||
|
$sort_by_sql = 'timestamp';
|
||
|
$sort_order_text = 'Descending Order';
|
||
|
$sort_order_sql = 'desc';
|
||
|
$page = ( isset( $_GET['page'] ) ? intval($_GET['page']) : 1 );
|
||
|
$search = ( isset( $_GET['s_search'] ) ? htmlspecialchars( trim($_GET['s_search']) ) : '' );
|
||
|
$perpage = ( isset( $_GET['perpage'] ) && intval( $_GET['perpage'] ) ? intval($_GET['perpage']) : 15 );
|
||
|
$link_limit = ( isset( $_GET['link_limit'] ) && !empty( $_GET['link_limit'] ) ) ? intval($_GET['link_limit']) : '' ;
|
||
|
if ( $link_limit !== '' ) {
|
||
|
$link_filter = ( isset( $_GET['link_filter'] ) && $_GET['link_filter'] == 'more' ? 'more' : 'less' ) ;
|
||
|
$link_moreless = ( $link_filter == 'more' ? '>' : '<' );
|
||
|
$where = " AND clicks $link_moreless $link_limit";
|
||
|
} else {
|
||
|
$link_filter = '';
|
||
|
}
|
||
|
$date_filter = 'before';
|
||
|
$date_first = $date_second = '';
|
||
|
$base_page = yourls_admin_url( 'index.php' );
|
||
|
|
||
|
// Searching
|
||
|
if( !empty($search) && !empty($_GET['s_in']) ) {
|
||
|
switch($_GET['s_in']) {
|
||
|
case 'keyword':
|
||
|
$search_in_text = 'Short URL';
|
||
|
$search_in_sql = 'keyword';
|
||
|
break;
|
||
|
case 'url':
|
||
|
$search_in_text = 'URL';
|
||
|
$search_in_sql = 'url';
|
||
|
break;
|
||
|
case 'title':
|
||
|
$search_in_text = 'Title';
|
||
|
$search_in_sql = 'title';
|
||
|
break;
|
||
|
case 'ip':
|
||
|
$search_in_text = 'IP Address';
|
||
|
$search_in_sql = 'ip';
|
||
|
break;
|
||
|
}
|
||
|
$search_text = stripslashes($search);
|
||
|
$search_display = "Searching for <strong>$search_text</strong> in <strong>$search_in_text</strong>. ";
|
||
|
$search_url = "&s_search=$search_text &s_in=$search_in_sql";
|
||
|
$search = str_replace('*', '%', '*'.$search.'*');
|
||
|
$where .= " AND `$search_in_sql` LIKE ('$search')";
|
||
|
}
|
||
|
|
||
|
// Time span
|
||
|
if( !empty($_GET['date_filter']) ) {
|
||
|
switch($_GET['date_filter']) {
|
||
|
case 'before':
|
||
|
$date_filter = 'before';
|
||
|
if( yourls_sanitize_date( $_GET['date_first'] ) ) {
|
||
|
$date_first_sql = yourls_sanitize_date_for_sql( $_GET['date_first'] );
|
||
|
$where .= " AND `timestamp` < '$date_first_sql'";
|
||
|
$date_first = $_GET['date_first'];
|
||
|
}
|
||
|
break;
|
||
|
case 'after':
|
||
|
$date_filter = 'after';
|
||
|
if( yourls_sanitize_date( $_GET['date_first'] ) ) {
|
||
|
$date_first_sql = yourls_sanitize_date_for_sql( $_GET['date_first'] );
|
||
|
$where .= " AND `timestamp` > '$date_first_sql'";
|
||
|
$date_first = $_GET['date_first'];
|
||
|
}
|
||
|
break;
|
||
|
case 'between':
|
||
|
$date_filter = 'between';
|
||
|
if( yourls_sanitize_date( $_GET['date_first'] ) && yourls_sanitize_date( $_GET['date_second'] ) ) {
|
||
|
$date_first_sql = yourls_sanitize_date_for_sql( $_GET['date_first'] );
|
||
|
$date_second_sql = yourls_sanitize_date_for_sql( $_GET['date_second'] );
|
||
|
$where .= " AND `timestamp` BETWEEN '$date_first_sql' AND '$date_second_sql'";
|
||
|
$date_first = $_GET['date_first'];
|
||
|
$date_second = $_GET['date_second'];
|
||
|
}
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Sorting
|
||
|
if( !empty($_GET['s_by']) || !empty($_GET['s_order']) ) {
|
||
|
switch($_GET['s_by']) {
|
||
|
case 'keyword':
|
||
|
$sort_by_text = 'Short URL';
|
||
|
$sort_by_sql = 'keyword';
|
||
|
break;
|
||
|
case 'url':
|
||
|
$sort_by_text = 'URL';
|
||
|
$sort_by_sql = 'url';
|
||
|
break;
|
||
|
case 'timestamp':
|
||
|
$sort_by_text = 'Date';
|
||
|
$sort_by_sql = 'timestamp';
|
||
|
break;
|
||
|
case 'ip':
|
||
|
$sort_by_text = 'IP Address';
|
||
|
$sort_by_sql = 'ip';
|
||
|
break;
|
||
|
case 'clicks':
|
||
|
$sort_by_text = 'Clicks';
|
||
|
$sort_by_sql = 'clicks';
|
||
|
break;
|
||
|
}
|
||
|
switch($_GET['s_order']) {
|
||
|
case 'asc':
|
||
|
$sort_order_text = 'Ascending Order';
|
||
|
$sort_order_sql = 'asc';
|
||
|
break;
|
||
|
case 'desc':
|
||
|
$sort_order_text = 'Descending Order';
|
||
|
$sort_order_sql = 'desc';
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Get URLs Count for current filter, total links in DB & total clicks
|
||
|
list( $total_urls, $total_clicks ) = array_values( yourls_get_db_stats() );
|
||
|
if ( $where ) {
|
||
|
list( $total_items, $total_items_clicks ) = array_values( yourls_get_db_stats( $where ) );
|
||
|
} else {
|
||
|
$total_items = $total_urls;
|
||
|
$total_items_clicks = false;
|
||
|
}
|
||
|
|
||
|
// This is a bookmarklet
|
||
|
if ( isset( $_GET['u'] ) ) {
|
||
|
$is_bookmark = true;
|
||
|
yourls_do_action( 'bookmarklet' );
|
||
|
|
||
|
$url = yourls_sanitize_url( $_GET['u'] );
|
||
|
$keyword = ( isset( $_GET['k'] ) ? yourls_sanitize_keyword( $_GET['k'] ) : '' );
|
||
|
$title = ( isset( $_GET['t'] ) ? yourls_sanitize_title( $_GET['t'] ) : '' );
|
||
|
$return = yourls_add_new_link( $url, $keyword, $title );
|
||
|
|
||
|
// If fails because keyword already exist, retry with no keyword
|
||
|
if ( isset( $return['status'] ) && $return['status'] == 'fail' && isset( $return['code'] ) && $return['code'] == 'error:keyword' ) {
|
||
|
$msg = $return['message'];
|
||
|
$return = yourls_add_new_link( $url, '', $ydb );
|
||
|
$return['message'] .= ' ('.$msg.')';
|
||
|
}
|
||
|
|
||
|
// Stop here if bookmarklet with a JSON callback function
|
||
|
if( isset( $_GET['jsonp'] ) && $_GET['jsonp'] == 'yourls' ) {
|
||
|
$short = $return['shorturl'] ? $return['shorturl'] : '';
|
||
|
$message = $return['message'];
|
||
|
header('Content-type: application/json');
|
||
|
echo yourls_apply_filter( 'bookmarklet_jsonp', "yourls_callback({'short_url':'$short','message':'$message'});" );
|
||
|
|
||
|
die();
|
||
|
}
|
||
|
|
||
|
$s_url = stripslashes( $url );
|
||
|
$where = " AND `url` LIKE '$s_url' ";
|
||
|
|
||
|
$page = $total_pages = $perpage = 1;
|
||
|
$offset = 0;
|
||
|
|
||
|
$text = ( isset( $_GET['s'] ) ? stripslashes( $_GET['s'] ) : '' );
|
||
|
|
||
|
|
||
|
// This is not a bookmarklet
|
||
|
} else {
|
||
|
$is_bookmark = false;
|
||
|
|
||
|
// Checking $page, $offset, $perpage
|
||
|
if(empty($page) || $page == 0) { $page = 1; }
|
||
|
if(empty($offset)) { $offset = 0; }
|
||
|
if(empty($perpage) || $perpage == 0) { $perpage = 50; }
|
||
|
|
||
|
// Determine $offset
|
||
|
$offset = ($page-1) * $perpage;
|
||
|
|
||
|
// Determine Max Number Of Items To Display On Page
|
||
|
if(($offset + $perpage) > $total_items) {
|
||
|
$max_on_page = $total_items;
|
||
|
} else {
|
||
|
$max_on_page = ($offset + $perpage);
|
||
|
}
|
||
|
|
||
|
// Determine Number Of Items To Display On Page
|
||
|
if (($offset + 1) > ($total_items)) {
|
||
|
$display_on_page = $total_items;
|
||
|
} else {
|
||
|
$display_on_page = ($offset + 1);
|
||
|
}
|
||
|
|
||
|
// Determing Total Amount Of Pages
|
||
|
$total_pages = ceil($total_items / $perpage);
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
// Begin output of the page
|
||
|
$context = ( $is_bookmark ? 'bookmark' : 'index' );
|
||
|
yourls_html_head( $context );
|
||
|
yourls_html_logo();
|
||
|
yourls_html_menu() ;
|
||
|
|
||
|
if ( !$is_bookmark ) { ?>
|
||
|
<p><?php echo $search_display; ?></p>
|
||
|
<p>Display <strong><?php echo $display_on_page; ?></strong> to <strong class='increment'><?php echo $max_on_page; ?></strong> of <strong class='increment'><?php echo $total_items; ?></strong> URLs<?php if( $total_items_clicks !== false ) echo ", counting <strong>$total_items_clicks</strong> " . yourls_plural('click', $total_items_clicks) ?>.</p>
|
||
|
<?php } ?>
|
||
|
<p>Overall, tracking <strong class='increment'><?php echo number_format($total_urls); ?></strong> links, <strong><?php echo number_format($total_clicks); ?></strong> clicks, and counting!</p>
|
||
|
|
||
|
<?php yourls_html_addnew(); ?>
|
||
|
|
||
|
<?php
|
||
|
// If bookmarklet, add message. Otherwise, hide hidden share box.
|
||
|
if ( !$is_bookmark ) {
|
||
|
yourls_share_box( '', '', '', '', '<h2>Your short link</h2>', '<h2>Quick Share</h2>', true );
|
||
|
} else {
|
||
|
echo '<script type="text/javascript">$(document).ready(function(){
|
||
|
feedback( "' . $return['message'] . '", "'. $return['status'] .'");
|
||
|
init_clipboard();
|
||
|
});</script>';
|
||
|
}
|
||
|
|
||
|
yourls_table_head();
|
||
|
|
||
|
if ( !$is_bookmark ) {
|
||
|
$params = array(
|
||
|
'search_text' => $search_text,
|
||
|
'search_in_sql' => $search_in_sql,
|
||
|
'sort_by_sql' => $sort_by_sql,
|
||
|
'sort_order_sql' => $sort_order_sql,
|
||
|
'page' => $page,
|
||
|
'perpage' => $perpage,
|
||
|
'link_filter' => $link_filter,
|
||
|
'link_limit' => $link_limit,
|
||
|
'total_pages' => $total_pages,
|
||
|
'search_url' => $search_url,
|
||
|
'date_filter' => $date_filter,
|
||
|
'date_first' => $date_first,
|
||
|
'date_second' => $date_second,
|
||
|
);
|
||
|
yourls_html_tfooter( $params );
|
||
|
}
|
||
|
|
||
|
yourls_table_tbody_start();
|
||
|
|
||
|
// Main Query
|
||
|
$where = yourls_apply_filter( 'admin_list_where', $where );
|
||
|
$url_results = $ydb->get_results("SELECT * FROM `$table_url` WHERE 1=1 $where ORDER BY `$sort_by_sql` $sort_order_sql LIMIT $offset, $perpage;");
|
||
|
$found_rows = false;
|
||
|
if( $url_results ) {
|
||
|
$found_rows = true;
|
||
|
foreach( $url_results as $url_result ) {
|
||
|
$keyword = yourls_sanitize_string( $url_result->keyword );
|
||
|
$timestamp = strtotime( $url_result->timestamp );
|
||
|
$url = stripslashes( $url_result->url );
|
||
|
$ip = $url_result->ip;
|
||
|
$title = $url_result->title ? $url_result->title : '';
|
||
|
$clicks = $url_result->clicks;
|
||
|
|
||
|
echo yourls_table_add_row( $keyword, $url, $title, $ip, $clicks, $timestamp );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$display = $found_rows ? 'display:none' : '';
|
||
|
echo '<tr id="nourl_found" style="'.$display.'"><td colspan="6">No URL</td></tr>';
|
||
|
|
||
|
yourls_table_tbody_end();
|
||
|
|
||
|
yourls_table_end();
|
||
|
|
||
|
if ( $is_bookmark )
|
||
|
yourls_share_box( $url, $return['shorturl'], $title, $text );
|
||
|
?>
|
||
|
|
||
|
<?php yourls_html_footer( ); ?>
|