2009-11-24 14:07:18 +00:00
< ? php
/**
* Name : Random Tip
* Author : Sein Kraft < mail @ seinkraft . info >
* License : GPLv2
* Description : Show a random line of text in the subheader space
* Documentation :
* Formatting is done with HTML
*/
2012-02-08 12:07:01 +00:00
class Tips extends Extension {
2015-09-20 17:37:36 +00:00
protected $db_support = [ 'mysql' , 'sqlite' ]; // rand() ?
2015-08-09 11:16:06 +00:00
2012-02-08 11:24:25 +00:00
public function onInitExt ( InitExtEvent $event ) {
2009-11-24 14:07:18 +00:00
global $config , $database ;
if ( $config -> get_int ( " ext_tips_version " ) < 1 ){
$database -> create_table ( " tips " , "
id SCORE_AIPK ,
enable SCORE_BOOL NOT NULL DEFAULT SCORE_BOOL_N ,
image TEXT NOT NULL ,
text TEXT NOT NULL ,
" );
$database -> execute ( "
INSERT INTO tips ( enable , image , text )
VALUES ( ? , ? , ? ) " ,
array ( " Y " , " coins.png " , " Do you like this extension? Please support us for developing new ones. <a href= \" https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=8235933 \" target= \" _blank \" >Donate through paypal</a>. " ));
$config -> set_int ( " ext_tips_version " , 1 );
log_info ( " tips " , " extension installed " );
}
}
2012-02-08 11:24:25 +00:00
public function onPageRequest ( PageRequestEvent $event ) {
2009-11-24 14:07:18 +00:00
global $page , $user ;
$this -> getTip ();
2010-05-28 13:26:46 +00:00
if ( $event -> page_matches ( " tips " ) && $user -> is_admin ()) {
2009-11-24 14:07:18 +00:00
switch ( $event -> get_arg ( 0 )) {
case " list " :
2010-05-28 13:26:46 +00:00
$this -> manageTips ();
$this -> getAll ();
2009-11-24 14:07:18 +00:00
break ;
case " save " :
2010-05-28 13:26:46 +00:00
if ( $user -> check_auth_token ()) {
2009-11-24 14:07:18 +00:00
$this -> saveTip ();
$page -> set_mode ( " redirect " );
$page -> set_redirect ( make_link ( " tips/list " ));
}
break ;
case " status " :
2010-05-28 13:26:46 +00:00
// FIXME: HTTP GET CSRF
$tipID = int_escape ( $event -> get_arg ( 1 ));
$this -> setStatus ( $tipID );
$page -> set_mode ( " redirect " );
$page -> set_redirect ( make_link ( " tips/list " ));
2009-11-24 14:07:18 +00:00
break ;
case " delete " :
2010-05-28 13:26:46 +00:00
// FIXME: HTTP GET CSRF
$tipID = int_escape ( $event -> get_arg ( 1 ));
$this -> deleteTip ( $tipID );
$page -> set_mode ( " redirect " );
$page -> set_redirect ( make_link ( " tips/list " ));
2009-11-24 14:07:18 +00:00
break ;
}
}
}
2012-02-08 11:24:25 +00:00
public function onUserBlockBuilding ( UserBlockBuildingEvent $event ) {
2009-11-24 14:07:18 +00:00
global $user ;
if ( $user -> is_admin ()) {
$event -> add_link ( " Tips Editor " , make_link ( " tips/list " ));
}
}
private function manageTips () {
$data_href = get_base_href ();
$url = $data_href . " /ext/tips/images/ " ;
$dirPath = dir ( './ext/tips/images' );
$images = array ();
while (( $file = $dirPath -> read ()) !== false ) {
if ( $file [ 0 ] != " . " ) {
$images [] = trim ( $file );
}
}
$dirPath -> close ();
sort ( $images );
$this -> theme -> manageTips ( $url , $images );
}
private function saveTip () {
global $database ;
$enable = isset ( $_POST [ " enable " ]) ? " Y " : " N " ;
$image = html_escape ( $_POST [ " image " ]);
$text = $_POST [ " text " ];
$database -> execute ( "
INSERT INTO tips ( enable , image , text )
VALUES ( ? , ? , ? ) " ,
array ( $enable , $image , $text ));
}
private function getTip () {
global $database ;
$data_href = get_base_href ();
$url = $data_href . " /ext/tips/images/ " ;
$tip = $database -> get_row ( " SELECT * " .
" FROM tips " .
" WHERE enable = 'Y' " .
" ORDER BY RAND() " .
" LIMIT 1 " );
if ( $tip ) {
$this -> theme -> showTip ( $url , $tip );
}
}
private function getAll () {
global $database ;
$data_href = get_base_href ();
$url = $data_href . " /ext/tips/images/ " ;
$tips = $database -> get_all ( " SELECT * FROM tips ORDER BY id ASC " );
$this -> theme -> showAll ( $url , $tips );
}
2014-04-28 05:26:22 +00:00
/**
* @ param int $tipID
*/
2009-11-24 14:07:18 +00:00
private function setStatus ( $tipID ) {
global $database ;
2014-04-28 05:26:22 +00:00
$tip = $database -> get_row ( " SELECT * FROM tips WHERE id = ? " , array ( int_escape ( $tipID )));
2009-11-24 14:07:18 +00:00
2014-04-25 21:39:46 +00:00
if ( bool_escape ( $tip [ 'enable' ])) {
2009-11-24 14:07:18 +00:00
$enable = " N " ;
2014-04-25 21:39:46 +00:00
} else {
2009-11-24 14:07:18 +00:00
$enable = " Y " ;
}
2014-04-28 05:26:22 +00:00
$database -> execute ( " UPDATE tips SET enable = ? WHERE id = ? " , array ( $enable , int_escape ( $tipID )));
2009-11-24 14:07:18 +00:00
}
2014-04-28 05:26:22 +00:00
/**
* @ param int $tipID
*/
2009-11-24 14:07:18 +00:00
private function deleteTip ( $tipID ) {
global $database ;
2014-04-28 05:26:22 +00:00
$database -> execute ( " DELETE FROM tips WHERE id = ? " , array ( int_escape ( $tipID )));
2009-11-24 14:07:18 +00:00
}
}
2014-04-25 21:34:20 +00:00