fetch() )
{
$query = $db -> prepare( 'SELECT * FROM pcms_layout WHERE id = :id' );
$query -> bindValue( ':id', $id, \PDO::PARAM_INT );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$layout = $row;
$query -> closeCursor();
}
return $layout;
}
public function getLayouts()
{
global $db;
$query = $db -> query( 'SELECT id, name FROM pcms_layout' );
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$layouts[] = $row;
$query -> closeCursor();
return $layouts;
}
public function getUserSurname( $id )
{
global $db , $config , $cache;
$key = 'getUserSurname:' . $id;
if ( !$surname = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT surname FROM pcms_user WHERE id = :id' );
$query -> bindValue( ':id' , $id , \PDO::PARAM_INT );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$name = $row['surname'];
$query -> closeCursor();
$cache -> store( $key , $surname , $config['cache_expire_long'] );
}
return $name;
}
public function getUserName( $id )
{
global $db , $config , $cache;
$key = 'getUserName:' . $id;
if ( !$name = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT name FROM pcms_user WHERE id = :id' );
$query -> bindValue( ':id' , $id , \PDO::PARAM_INT );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$name = $row['name'];
$query -> closeCursor();
$cache -> store( $key , $name , $config['cache_expire_long'] );
}
return $name;
}
public function checkEmailRegister( $email )
{
if ( !self::checkEmail( $email ) )
return 1;
else
{
if ( self::isBannedEmail( $email ) || !self::isEmailFree( $email ) )
return 2;
else
return 0;
}
}
public function checkPasswordRegister( $password , $password2 )
{
if ( strlen( $password ) < 5 )
return 1;
else
{
if ( $password != $password2 )
return 2;
else
return 0;
}
}
public function checkLoginRegister( $login )
{
if ( strlen( $login ) < 5 || preg_match( "/[^A-z0-9_-]/" , $login ) )
return 1;
else
{
if ( self::isBannedLogin( $login ) || !self::isLoginFree( $login ) )
return 2;
else
return 0;
}
}
function importDumpFile( $filePath )
{
global $db;
if (!is_file($filePath))
throw new Exception("Podany plik ($filePath) nie istniej!!");
$lines = file( $filePath );
$query = '';
foreach ( $lines as $line )
{
if( strncmp($line,'--',2) == 0 )
continue;
if( strncmp($line,'/*',2) == 0 )
continue;
$line = ' '.trim($line);
$query .= $line;
if( $line[strlen($line) - 1] == ';' )
{
$db -> query( $query );
$query = '';
}
}
}
function getFormatDate()
{
$date = date("l, d-F-Y", time());
$date_ang = array('Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday', 'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December');
$date_pl = array('Poniedziałek', 'Wtorek', 'Środa', 'Czwartek', 'Piątek', 'Sobota', 'Niedziela', 'Styczeń', 'Luty', 'Marzec', 'Kwiecień', 'Maj', 'Czerwiec', 'Lipiec', 'Sierpień', 'Wrzesień', 'Październik', 'Listopad', 'Grudzień');
$data = str_replace($date_ang, $date_pl, $date);
$data = str_replace('-',' ',$data);
return $data;
}
function getNameDay()
{
global $sys;
if ( file_exists( 'resources/namedays.php' ) )
{
include 'resources/namedays.php';
$days = explode( "*" , $namedays );
$today = date('d m');
for ( $x = 0; $x < sizeof( $days ); $x++ ) {
$day = explode( "-" , $days[$x] );
if ( $today == trim( $day[0] ) )
$out = $day[1];
}
return $out;
}
}
public function setSessionVar( $var , $val , $admin = false )
{
if ( !$admin )
$_SESSION[ $var ] = $val;
else
$_SESSION[ 'admin_' . $var ] = $val;
}
public function getSessionVar( $var , $admin = false )
{
if ( !$admin )
{
if ( isset( $_SESSION[ $var ] ) )
$out = $_SESSION[ $var ];
}
else
{
if ( isset( $_SESSION[ 'admin_' . $var ] ) )
$out = $_SESSION[ 'admin_' . $var ];
}
return $out;
}
public function deleteSessionVar( $var , $admin = false )
{
if ( !$admin )
unset( $_SESSION[ $var ] );
else
unset( $_SESSION[ 'admin_' . $var ] );
}
public function saveString( $val , $tolower = false )
{
if ( $tolower )
$val = strtolower($val);
return trim( strip_tags( $val ) );
}
public function formGetHash( $val )
{
$val = base64_encode( $val );
$val = self::formGet( $val );
return base64_decode( $val );
}
public function formGet( $var )
{
$out = '';
if ( isset( $_POST[ $var ] ) )
{
if ( is_string( $_POST[ $var ] ) )
$out = trim( $_POST[ $var ] );
else
$out = $_POST[ $var ];
}
else
{
if ( isset( $_GET[ $var ] ) )
{
if ( is_string( $_GET[ $var ] ) )
$out = trim( $_GET[ $var ] );
else
$out = $_GET[ $var ];
}
}
return $out;
}
public function formGetInt( $var )
{
return (int)self::formGet( $var );
}
public function setAlert( $val )
{
self::setSessionVar( 'alert' , $val );
}
public function getAlert()
{
$tpl = new \Savant3;
$tpl -> _alert = self::getSessionVar( 'alert' );
return $tpl -> fetch( 'templates/site-alert.php' );
}
public function getLangs()
{
global $db , $cache , $config;
$key = 'getLangs';
if ( !$langs = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT id , name FROM pcms_lang WHERE enabled=:enabled' );
$query -> bindValue( ':enabled' , 1 , PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$lg['id'] = $row['id'];
$lg['name'] = $row['name'];
$langs[] = $lg;
}
$query -> closeCursor();
$cache -> store( $key , $langs , $config['cache_expire_long' ] );
}
return $langs;
}
public function getComboYesNo()
{
global $lang;
$tab[0] = $lang -> getTrans( 'T_NIE' );
$tab[1] = $lang -> getTrans( 'T_TAK' );
return $tab;
}
public function deleteAction()
{
global $lang;
$akcja = "function mycallbackform(v,m,f){
if( v == true )
document.location.href='index.php?rw=del&id=[param]';
}";
$akcja .= "$.prompt('" . $lang -> getTrans( 'T_POTWIERDZ_USUNIECIE' ) . "',{ callback: mycallbackform, buttons: { " . $lang -> getTrans( 'T_TAK' ) . ": true, " . $lang -> getTrans( 'T_NIE' ) . ": false }, focus: 1 })";
$akcja = 'onClick="' . $akcja . '"';
return $akcja;
}
public function getPagingVar( $var , $bs , $ls )
{
if ( $var == 'a' )
{
if ( $bs == 1 )
return 6;
else if ( $bs == 2 )
return 5;
else if ( $bs == 3 )
return 4;
else
return 3;
}
else if ( $var == 'b' )
{
if ( $bs == $ls )
return 6;
else if ( $bs == $ls-1 )
return 5;
else if ( $bs == $ls-2 )
return 4;
else
return 3;
}
}
public function checkBrowseLimit( $limit )
{
switch ($limit)
{
case 5:
return 5;
break;
case 10:
return 10;
break;
case 25:
return 25;
break;
case 50:
return 50;
break;
case 100:
return 100;
break;
default:
return 25;
break;
}
}
public function getPagesTitle()
{
global $cache , $config , $db;
$key = 'getPagesTitle:all';
if ( !$pages = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT id FROM pcms_page' );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$pages[ $row['id'] ] = \System::getPageTitle( $row['id'] );
$query -> closeCursor();
$cache -> store( $key , $pages , $config['cache_expire_short'] );
}
return $pages;
}
public function getPageTitle ( $id , $language = 'pl' )
{
global $db , $cache , $config;
$key = 'pageTitle:' . $id . ':' . $language;
if ( !$title = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT title FROM pcms_page_translation WHERE page_id = :page_id AND lang_id = :lang_id' );
$query -> bindValue( ':page_id' , $id , PDO::PARAM_INT );
$query -> bindValue( ':lang_id' , $language , PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$title = $row['title'];
$query -> closeCursor();
$cache -> store( $key , $title , $config['cache_expire_long' ] );
}
if ( $title == '' )
{
$key = 'pageTitleRandom:' . $id;
if ( !$title = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT title FROM pcms_page_translation WHERE page_id = :page_id AND title != "" LIMIT 1' );
$query -> bindValue( ':page_id' , $id , PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$title = $row['title'];
$query -> closeCursor();
$cache -> store( $key , $title , $config['cache_expire_long' ] );
}
}
return $title;
}
public function rewriteHtacces()
{
global $db , $config;
$link_base = "http://" . $_SERVER['SERVER_NAME'] . "/";
$nl = chr( 13 ) . chr( 10 );
$rss_tmp = '';
$site_map = '' . $nl;
$site_map .= '' . $nl;
$site_map .= '' . $nl;
$site_map .= '' . $link_base . '' . $nl;
$site_map .= '' . date( 'Y-m-d' ) . '' . $nl;
$site_map .= 'daily' . $nl;
$site_map .= '1' . $nl;
$site_map .= '' . $nl;
$htaccess_data = file_get_contents( '../files/htaccess.conf' );
$htaccess_data = str_replace( '{MAIN_PAGE}' , self::getMainPage() , $htaccess_data );
$htaccess_data = str_replace( '{PAGE}' , $config['page'] , $htaccess_data );
$query = $db -> prepare( 'SELECT id, name FROM pcms_lang WHERE enabled = :enabled' );
$query -> bindValue( ':enabled' , 1 , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$query2 = $db -> prepare( 'SELECT title, seo_link, page_id FROM pcms_page_translation WHERE lang_id = :lang_id' );
$query2->bindValue( ':lang_id' , $row['id'] , \PDO::PARAM_STR );
$query2->execute();
if ( $query2->rowCount() ) while ( $row2 = $query2->fetch() )
{
$site_map .= '' . $nl;
if ( !$row2['seo_link'] )
$site_map .= '' . $link_base . 's,' . $row2['page_id'] . ',' . self::seo( $row2['title'] ) . '' . $nl;
else
$site_map .= '' . $link_base . $row['seo_link'] . '' . $nl;
$site_map .= '' . date( 'Y-m-d' ) . '' . $nl;
$site_map .= 'daily' . $nl;
$site_map .= '1' . $nl;
$site_map .= '' . $nl;
if ( $row2['seo_link'] )
$htaccess_data .= chr( 13 ).chr( 10 ) . 'RewriteRule ^' . $row2['seo_link'] . '$ index.php?rw=change_site&id=' . $row2['page_id'] . ' [L]';
}
$query2 = $db -> prepare( 'SELECT title, article_id, seo_link FROM pcms_article_translation WHERE lang_id = :lang_id' );
$query2->bindValue( ':lang_id' , $row['id'] , \PDO::PARAM_STR );
$query2->execute();
if ( $query2->rowCount() ) while ( $row2 = $query2->fetch() )
{
$site_map .= '' . $nl;
if ( !$row2['seo_link'] )
$site_map .= '' . $link_base . 'a,' . $row2['article_id'] . ',' . self::seo( $row2['title'] ) . '' . $nl;
else
$site_map .= '' . $link_base . $row2['seo_link'] . '' . $nl;
$site_map .= '' . date( 'Y-m-d' , strtotime( self::getDate() ) ) . '' . $nl;
$site_map .= 'daily' . $nl;
$site_map .= '1' . $nl;
$site_map .= '' . $nl;
if ( $row2['seo_link'] )
$htaccess_data .= chr( 13 ).chr( 10 ) . 'RewriteRule ^' . $row2['seo_link'] . '$ index.php?art=$1' . $row2['article_id'] . ' [L]';
}
$query2->closeCursor();
$query2 = $db -> prepare( 'SELECT title, article_id, text, seo_link FROM pcms_article_translation WHERE lang_id = :lang_id ORDER BY article_id DESC LIMIT 30' );
$query2->bindValue( ':lang_id' , $row['id'] , \PDO::PARAM_STR );
$query2->execute();
if ( $query2->rowCount() ) while ( $row2 = $query2->fetch() )
{
$rss_tmp .= '- ' . $nl;
$rss_tmp .= '' . $row2['title'] . '' . $nl;
if ( !$row2['seo_link'] )
$rss_tmp .= '' . $link_base . 'a,' . $row2['article_id'] . ',' . self::seo( $row2['title'] ) . '' . $nl;
else
$rss_tmp .= '' . $link_base . $row2['seo_link'] . '' . $nl;
$text = str_replace( 'ó' , 'ó' , stripslashes( $row2['text'] ) );
$text = str_replace( 'ó' , 'ó' , $text );
$text = System::deleteHTML( $text );
$text = mb_substr( $text , 0 , 150 , 'UTF-8' );
$rss_tmp .= '' . $text . '...' . $nl;
$rss_tmp .= '' . date( "d/m/Y H:i" , strtotime( self::getDate() ) ) . '' . $nl;
$rss_tmp .= '
' . $nl;
}
$query -> closeCursor();
}
$query -> closeCursor();
$site_map .= '';
$htaccess = '../.htaccess';
$fp = fopen( $htaccess , 'w' );
fwrite( $fp , $htaccess_data );
fclose( $fp );
$sitemap = '../files/sitemap.xml';
$fp = fopen( $sitemap , 'w' );
fwrite( $fp , $site_map );
fclose( $fp );
$rss_feed = '' . $nl;
$rss_feed .= '' . $nl;
$rss_feed .= '' . $nl;
$rss_feed .= '' . self::getSystemSettings( 'firm_name' ) . '' . $nl;
$rss_feed .= '' . $link_base . '' . $nl;
$rss_feed .= '' . $nl;
$rss_feed .= 'pl';
$rss_feed .= 'Copyright © ' . self::getSystemSettings('firm_name') . '' . $nl;
$rss_feed .= '' . date( 'm/d/Y H:i' , strtotime( self::getDate() ) ) . '' . $nl;
$rss_feed .= $rss_tmp;
$rss_feed .= '' . $nl;
$rss_feed .= '' . $nl;
$rssfeed = '../files/rss.xml';
$fp = fopen( $rssfeed , 'w' );
fwrite( $fp , $rss_feed );
fclose( $fp );
}
function deleteHTML( $text )
{
$search = array ("''si",
"'<[/!]*?[^<>]*?>'si",
"'([rn])[s]+'",
"'&(quot|#34);'i",
"'&(amp|#38);'i",
"'&(lt|#60);'i",
"'&(gt|#62);'i",
"'&(nbsp|#160);'i",
"'&(iexcl|#161);'i",
"'&(cent|#162);'i",
"'&(pound|#163);'i",
"'&(copy|#169);'i",
"'(d+);'e");
$replace = array ("",
"",
"\1",
"\"",
"&",
"<",
">",
" ",
chr(161),
chr(162),
chr(163),
chr(169),
"chr(\1)");
$text = preg_replace($search, $replace, $text);
return $text;
}
public function getMainPage()
{
global $db , $cache , $config;
$key = 'mainPage';
if ( !$main_page = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT id FROM pcms_page WHERE enabled = :enabled ORDER BY o ASC LIMIT 1' );
$query -> bindValue( ':enabled' , 1 , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$main_page = 's,' . $row['id'] . ',' . self::seo( self::getPageTitle ( $row[ 'id' ] ) );
}
$query -> closeCursor();
$cache -> store( $key , $main_page , $config['cache_expire'] );
}
return $main_page;
}
public function seo( $val )
{
$array_rep1 = array( ' ', '/', '+', '.', '"', "'", '?', '-', ',', '_' );
$array_rep2 = array( '-', '-', '-', '-', '-', '-', '-', '-', '-', '-' );
$val = self::noPl( $val );
$val = str_replace( $array_rep1 , $array_rep2 , $val );
$val = strtolower( $val );
$val = preg_replace( '/(-){2,}/', '-', $val );
return $val;
}
public function noPL( $val )
{
$table = Array(
//WIN
"\xb9" => "a", "\xa5" => "A", "\xe6" => "c", "\xc6" => "C",
"\xea" => "e", "\xca" => "E", "\xb3" => "l", "\xa3" => "L",
"\xf3" => "o", "\xd3" => "O", "\x9c" => "s", "\x8c" => "S",
"\x9f" => "z", "\xaf" => "Z", "\xbf" => "z", "\xac" => "Z",
"\xf1" => "n", "\xd1" => "N",
//UTF
"\xc4\x85" => "a", "\xc4\x84" => "A", "\xc4\x87" => "c", "\xc4\x86" => "C",
"\xc4\x99" => "e", "\xc4\x98" => "E", "\xc5\x82" => "l", "\xc5\x81" => "L",
"\xc3\xb3" => "o", "\xc3\x93" => "O", "\xc5\x9b" => "s", "\xc5\x9a" => "S",
"\xc5\xbc" => "z", "\xc5\xbb" => "Z", "\xc5\xba" => "z", "\xc5\xb9" => "Z",
"\xc5\x84" => "n", "\xc5\x83" => "N",
//ISO
"\xb1" => "a", "\xa1" => "A", "\xe6" => "c", "\xc6" => "C",
"\xea" => "e", "\xca" => "E", "\xb3" => "l", "\xa3" => "L",
"\xf3" => "o", "\xd3" => "O", "\xb6" => "s", "\xa6" => "S",
"\xbc" => "z", "\xac" => "Z", "\xbf" => "z", "\xaf" => "Z",
"\xf1" => "n", "\xd1" => "N");
$array_de = array('Ü');
$array_de_pl = array('U');
$val = str_replace( $array_de , $array_de_pl , $val );
$array_uk = array('А' , 'а' , 'Б' , 'б' , 'В' , 'в' , 'Г' , 'г' , 'ґ' , 'Д' , 'д' , 'Е' , 'е' , 'Є' , 'є' , 'Ж' , 'ж' , 'З' . 'з' , 'И' , 'и' , 'І' , 'і' , 'Ї' , 'ї' , 'Й' , 'й' , 'К' , 'к' , 'Л' , 'л' , 'М' , 'м' , 'Н' , 'н' , 'О' , 'о' , 'П' , 'п' , 'Р' , 'р' , 'С' , 'с' , 'Т' , 'т' , 'У' , 'у' , 'Ф' , 'ф' , 'Х' , 'х' , 'Ц' - 'ц' , 'Ч' , 'ч' , 'Ш' , 'ш' , 'Щ' , 'щ' , 'Ю' , 'ю' , 'Я' , 'я' , 'ь' );
$array_uk_pl = array('А' , 'a' , 'B' , 'b' , 'V' , 'v' , 'Gg', 'gh', 'Gg', 'D' , 'd' , 'E' , 'e' , 'Ye', 'yr', 'Zh', 'zh', 'Z' , 'z' , 'Y' , 'y' , 'I' , 'i' , 'Yi', 'yi', 'J' , 'j' , 'K' , 'k' , 'L' , 'l' , 'M' , 'm' , 'N' , 'n' , 'O' , 'o' , 'P' , 'p' , 'R' , 'r' , 'S' , 's' , 'T' , 't' , 'U' , 'u' , 'F' , 'f' , 'Kh', 'kh', 'Ts', 'ts', 'Ch', 'ch', 'Sh', 'sh', 'Shch', 'shch', 'Yu', 'yu', 'Ya', 'ya', '' );
$val = str_replace( $array_uk , $array_uk_pl , $val );
return strtr( $val , $table );
}
public function getDate()
{
return date( 'Y-m-d H:i:s' );
}
public function getSystemSettings( $param )
{
global $db , $cache , $config , $lang;
$key = 'systemSettings:' . $param;
if ( !$out = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT value FROM pcms_settings WHERE param = :param' );
$query -> bindValue( ':param' , $param , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$out = stripslashes( $row['value'] );
else
die( $lang -> getTrans( 'T_BRAK_PODANEGO_PARAMETRU' ) );
$query -> closeCursor();
$cache -> store( $key , $out , $config['cache_expire_short'] );
}
return $out;
}
public function getArticlesTitle()
{
global $cache , $config , $db;
$key = 'articlestitle:all';
if ( !$articles = $cache -> fetch( $key ) )
{
$query = $db -> prepare( 'SELECT id FROM pcms_article' );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$articles[ $row['id'] ] = \System::getArticleTitle( $row['id'] );
$query -> closeCursor();
$cache -> store( $key , $articles , $config['cache_expire_short'] );
}
return $articles;
}
public function getArticleTitle( $id , $language = 'pl' )
{
global $db , $cache , $config;
$query = $db -> prepare( 'SELECT title FROM pcms_article_translation WHERE article_id = :article_id AND lang_id = :lang_id' );
$query -> bindValue( ':article_id' , $id , PDO::PARAM_INT );
$query -> bindValue( ':lang_id' , $language , PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$title = $row['title'];
$query -> closeCursor();
if ( !$title )
{
$query2 = $db -> prepare( 'SELECT title FROM pcms_article_translation WHERE article_id = :article_id LIMIT 1' );
$query2 -> bindValue( ':article_id' , $id , PDO::PARAM_STR );
$query2 -> execute();
if ( $query2 -> rowCount() ) while ( $row2 = $query2 -> fetch() )
$title = $row2['title'];
$query2 -> closeCursor();
}
return $title;
}
public function getMenuList()
{
global $db;
$menu = array();
$query = $db -> prepare( 'SELECT id , name FROM pcms_menu' );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$mn['id'] = $row['id'];
$mn['name'] = $row['name'];
$menu[] = $mn;
}
$query -> closeCursor();
return $menu;
}
public function getPageTypes()
{
global $db , $lang;
$pages = array();
$query = $db -> prepare( 'SELECT id , name FROM pcms_page_type WHERE enabled = :enabled ORDER BY name ASC' );
$query -> bindValue( ':enabled' , 1 , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$pg['id'] = $row['id'];
$pg['name'] = $lang -> getTrans( $row['name'] );
$pages[] = $pg;
}
$query -> closeCursor();
return $pages;
}
public function getSortTypes()
{
global $db , $lang;
$sort = array();
$query = $db -> prepare( 'SELECT id , name FROM pcms_page_sort_type ORDER BY name ASC' );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
{
$st['id'] = $row['id'];
$st['name'] = $lang -> getTrans( $row['name'] );
$sort[] = $st;
}
$query -> closeCursor();
return $sort;
}
public function getCountPages( $menu_id )
{
global $db;
$query = $db -> prepare( 'SELECT count(id) FROM pcms_page WHERE id_menu=:id' );
$query -> bindValue( ':id' , $menu_id , \PDO::PARAM_INT );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
return $row[0];
}
public function deleteCacheAdmin( $str = 'temp/' ) {
if( is_file( $str ) ) {
return @unlink( $str );
} else if( is_dir( $str ) ) {
$scan = glob( rtrim( $str , '/' ) . '/*' );
if ( is_array( $scan ) ) foreach( $scan as $index => $path ) {
self::deleteCacheAdmin( $path );
}
if ( $str != 'temp/' && $str != 'admin/temp/' && is_dir( $str ) && self::isEmptyDir( $str ) )
return @rmdir( $str );
}
self::deleteCache();
}
public static function isEmptyDir($dir)
{
return (($files = @scandir($dir)) && count($files) <= 2);
}
public function deleteCache( $str = '../temp/' )
{
if( is_file( $str ) )
{
return @unlink( $str );
}
else if( is_dir( $str ) )
{
$scan = glob( rtrim( $str , '/' ) . '/*' );
if ( is_array( $scan ) ) foreach( $scan as $index => $path )
{
self::deleteCache( $path );
}
if ( $str != '../temp/' && $str != 'temp/' && is_dir( $str ) && self::isEmptyDir( $str ) )
return @rmdir( $str );
}
}
public function sendEmail( $email , $temat , $tresc , $replay = '' , $file = '' )
{
if ( file_exists('resources/phpmailer/class.phpmailer.php') )
require_once 'resources/phpmailer/class.phpmailer.php';
if ( file_exists('../resources/phpmailer/class.phpmailer.php') )
require_once'../resources/phpmailer/class.phpmailer.php';
if ( isset($email) && isset($temat) && isset($tresc) )
{
$admin_mail = self::getSystemSettings( 'admin_email');
$mail = new PHPMailer();
$mail -> IsSMTP();
$mail -> SMTPAuth = true;
$mail -> Host = self::getSystemSettings( 'email_host' );
$mail -> Port = self::getSystemSettings( 'email_port' );
$mail -> Username = self::getSystemSettings( 'email_login' );
$mail -> Password = self::getSystemSettings( 'email_password' );
$mail -> CharSet = "UTF-8";
if ( $replay == "" )
{
$mail -> AddReplyTo( $admin_mail, $admin_mail );
$mail -> SetFrom( $admin_mail, $admin_mail );
}
else
{
$mail -> AddReplyTo( $replay, '' );
$mail -> SetFrom( $admin_mail, '' );
}
$mail -> AddAddress( $email , '' );
$mail -> Subject = $temat;
$mail -> Body = str_replace( '
' , chr(13).chr(10) , $tresc );
if ( $file )
$mail -> AddAttachment($file);
$mail -> IsHTML(true);
$mail -> Send();
}
}
public function getCountBanners()
{
global $db;
$query = $db -> prepare( 'SELECT count(id) FROM pcms_banner' );
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
return $row[0];
}
public function getDateDiff( $data1 , $data2 , $rodz = '60' )
{
$d1_t = explode(' ',$data1);
$d1_tt = explode('-',$d1_t[0]);
$rok1 = $d1_tt[0];
$mc1 = $d1_tt[1];
$d1 = $d1_tt[2];
$d1_tt = explode(':',$d1_t[1]);
$g1 = $d1_tt[0];
$m1 = $d1_tt[1];
$s1 = $d1_tt[2];
$d2_t = explode(' ',$data2);
$d2_tt = explode('-',$d2_t[0]);
$rok2 = $d2_tt[0];
$mc2 = $d2_tt[1];
$d2 = $d2_tt[2];
$d2_tt = explode(':',$d2_t[1]);
$g2 = $d2_tt[0];
$m2 = $d2_tt[1];
$s2 = $d2_tt[2];
$lt = mktime( $g2 , $m2 , $s2 , $mc2 , $d2 , $rok2 );
$st = mktime( $g1 , $m1 , $s1 , $mc1 , $d1 , $rok1 );
return round( ( $lt - $st ) / $rodz );
}
public function checkEmail( $email )
{
if ( filter_var( $email , FILTER_VALIDATE_EMAIL ) )
return true;
else
return false;
}
public function gen_hash( $limit = 5 )
{
$out = '';
for ( $i = 0; $i < $limit; $i++ )
$out .= chr( rand( 97 , 122 ) );
return $out . rand( 1000 , 9999 );
}
public function isBannedEmail( $email )
{
global $db;
$query = $db -> prepare('SELECT id FROM pcms_banned_email WHERE email = :email');
$query -> bindValue(':email' , $email , \PDO::PARAM_STR);
$query -> execute();
if ( $query -> rowCount() )
return true;
else
return false;
}
public function isEmailFree( $email )
{
global $db;
$query = $db -> prepare( 'SELECT id FROM pcms_user WHERE email = :email' );
$query -> bindValue( ':email' , $email , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() )
return false;
else
return true;
}
public function isBannedLogin( $login )
{
global $db;
$query = $db -> prepare('SELECT id FROM pcms_banned_login WHERE login = :login');
$query -> bindValue(':login' , $login , \PDO::PARAM_STR);
$query -> execute();
if ( $query -> rowCount() )
return true;
else
return false;
}
public function isLoginFree( $login )
{
global $db;
$query = $db -> prepare( 'SELECT id FROM pcms_user WHERE login = :login' );
$query -> bindValue( ':login' , $login , \PDO::PARAM_STR );
$query -> execute();
if ( $query -> rowCount() )
return false;
else
return true;
}
public function updateVisitCounter() {
global $db;
$query = $db -> prepare( 'UPDATE pcms_settings SET value = value + 1 WHERE param = :param' );
$query -> bindValue( ':param' , 'visit_count' , \PDO::PARAM_STR );
$query -> execute();
$query -> closeCursor();
self::setSessionVar( 'visit_counter' , true );
}
public function getBanners()
{
global $db, $cache, $config;
$sKey = 'getBanners';
if ( !$aBanners = $cache -> fetch($sKey) )
{
$query = $db -> prepare('SELECT title, link, image FROM pcms_banner WHERE enabled = :enabled ORDER BY o');
$query -> bindValue(':enabled', 1 , \PDO::PARAM_STR);
$query -> execute();
if ( $query -> rowCount() ) while ( $row = $query -> fetch() )
$aBanners[] = $row;
$query -> closeCursor();
$cache -> store($sKey, $aBanners, $config['cache_expire']);
}
return $aBanners;
}
public function getIp()
{
if ( isset( $_SERVER['HTTP_X_FORWARDED_FOR'] ) )
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
else
$ip = $_SERVER['REMOTE_ADDR'];
return $ip;
}
public function random_color()
{
mt_srand((double)microtime()*1000000);
$c = '';
while(strlen($c)<6)
$c .= sprintf("%02X", mt_rand(0, 255));
return $c;
}
public function getRandomKeyWord( $keywords )
{
$keywords = explode( ',' , $keywords );
if ( is_array( $keywords ) )
return $keywords[ rand( 0 , count( $keywords ) -1 ) ];
}
public function isImage( $file )
{
if ( $file['type'] == 'image/pjpeg' || $file['type'] == 'image/jpg' || $file['type'] == 'image/jpeg' || $file['type'] == 'image/gif' || $file['type'] == 'image/png' )
{
if ( $file['size'] < 500000 )
{
$x = getimagesize( $file['tmp_name'] );
if ( is_array( $x ) && $x[0] > 0 && $x[1] > 0 )
return true;
}
}
}
}
?>