mirror of
https://port.numenaute.org/aleajactaest/khanat-code-old.git
synced 2025-01-13 10:25:23 +00:00
merging conflicts
This commit is contained in:
commit
cc6c18cb47
20 changed files with 1578 additions and 705 deletions
Binary file not shown.
|
@ -1,232 +1,245 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Handles the database connections. It uses PDO to connect to the different databases. It will use the argument of the constructor to setup a connection to the database
|
* Handles the database connections. It uses PDO to connect to the different databases. It will use the argument of the constructor to setup a connection to the database
|
||||||
* with the matching entry in the $cfg global variable.
|
* with the matching entry in the $cfg global variable.
|
||||||
* @author Daan Janssens, mentored by Matthew Lagoe
|
*
|
||||||
*
|
* @author Daan Janssens, mentored by Matthew Lagoe
|
||||||
*/
|
*/
|
||||||
class DBLayer{
|
class DBLayer {
|
||||||
|
|
||||||
private $PDO; /**< The PDO object, instantiated by the constructor */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The constructor.
|
|
||||||
* Instantiates the PDO object attribute by connecting to the arguments matching database(the db info is stored in the $cfg global var)
|
|
||||||
* @param $db String, the name of the databases entry in the $cfg global var.
|
|
||||||
*/
|
|
||||||
function __construct($db, $dbn = null)
|
|
||||||
{
|
|
||||||
if ($db != "install"){
|
|
||||||
|
|
||||||
global $cfg;
|
|
||||||
$dsn = "mysql:";
|
|
||||||
$dsn .= "host=". $cfg['db'][$db]['host'].";";
|
|
||||||
$dsn .= "dbname=". $cfg['db'][$db]['name'].";";
|
|
||||||
$dsn .= "port=". $cfg['db'][$db]['port'].";";
|
|
||||||
|
|
||||||
$opt = array(
|
|
||||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
|
|
||||||
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
|
|
||||||
);
|
|
||||||
$this->PDO = new PDO($dsn,$cfg['db'][$db]['user'],$cfg['db'][$db]['pass'], $opt);
|
|
||||||
} else {
|
|
||||||
global $cfg;
|
|
||||||
$dsn = "mysql:";
|
|
||||||
$dsn .= "host=". $cfg['db'][$dbn]['host'].";";
|
|
||||||
$dsn .= "port=". $cfg['db'][$dbn]['port'].";";
|
|
||||||
|
|
||||||
$opt = array(
|
|
||||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
|
|
||||||
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
|
|
||||||
);
|
|
||||||
$this->PDO = new PDO($dsn,$_POST['Username'],$_POST['Password'], $opt);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* execute a query that doesn't have any parameters
|
|
||||||
* @param $query the mysql query
|
|
||||||
* @return returns a PDOStatement object
|
|
||||||
*/
|
|
||||||
public function executeWithoutParams($query){
|
|
||||||
$statement = $this->PDO->prepare($query);
|
|
||||||
$statement->execute();
|
|
||||||
return $statement;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* execute a query that has parameters
|
|
||||||
* @param $query the mysql query
|
|
||||||
* @param $params the parameters that are being used by the query
|
|
||||||
* @return returns a PDOStatement object
|
|
||||||
*/
|
|
||||||
public function execute($query,$params){
|
|
||||||
$statement = $this->PDO->prepare($query);
|
|
||||||
$statement->execute($params);
|
|
||||||
return $statement;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* execute a query (an insertion query) that has parameters and return the id of it's insertion
|
|
||||||
* @param $query the mysql query
|
|
||||||
* @param $params the parameters that are being used by the query
|
|
||||||
* @return returns the id of the last inserted element.
|
|
||||||
*/
|
|
||||||
public function executeReturnId($tb_name,$data){
|
|
||||||
$field_values =':'. implode(',:', array_keys($data));
|
|
||||||
$field_options = implode(',', array_keys($data));
|
|
||||||
try{
|
|
||||||
$sth = $this->PDO->prepare("INSERT INTO $tb_name ($field_options) VALUE ($field_values)");
|
|
||||||
foreach ($data as $key => $value )
|
|
||||||
{
|
|
||||||
$sth->bindValue(":$key", $value);
|
|
||||||
}
|
|
||||||
$this->PDO->beginTransaction();
|
|
||||||
//execution
|
|
||||||
$sth->execute();
|
|
||||||
$lastId =$this->PDO->lastInsertId();
|
|
||||||
$this->PDO->commit();
|
|
||||||
}catch (Exception $e)
|
|
||||||
{
|
|
||||||
//for rolling back the changes during transaction
|
|
||||||
$this->PDO->rollBack();
|
|
||||||
throw new Exception("error in inseting");
|
|
||||||
}
|
|
||||||
return $lastId;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
private $PDO;
|
||||||
|
/**
|
||||||
|
* *< The PDO object, instantiated by the constructor
|
||||||
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* The constructor.
|
||||||
|
* Instantiates the PDO object attribute by connecting to the arguments matching database(the db info is stored in the $cfg global var)
|
||||||
*
|
*
|
||||||
|
* @param $db String, the name of the databases entry in the $cfg global var.
|
||||||
|
*/
|
||||||
|
function __construct( $db, $dbn = null )
|
||||||
|
{
|
||||||
|
if ( $db != "install" ) {
|
||||||
|
|
||||||
|
global $cfg;
|
||||||
|
$dsn = "mysql:";
|
||||||
|
$dsn .= "host=" . $cfg['db'][$db]['host'] . ";";
|
||||||
|
$dsn .= "dbname=" . $cfg['db'][$db]['name'] . ";";
|
||||||
|
$dsn .= "port=" . $cfg['db'][$db]['port'] . ";";
|
||||||
|
|
||||||
|
$opt = array(
|
||||||
|
PDO :: ATTR_ERRMODE => PDO :: ERRMODE_EXCEPTION,
|
||||||
|
PDO :: ATTR_DEFAULT_FETCH_MODE => PDO :: FETCH_ASSOC
|
||||||
|
);
|
||||||
|
$this -> PDO = new PDO( $dsn, $cfg['db'][$db]['user'], $cfg['db'][$db]['pass'], $opt );
|
||||||
|
} else {
|
||||||
|
global $cfg;
|
||||||
|
$dsn = "mysql:";
|
||||||
|
$dsn .= "host=" . $cfg['db'][$dbn]['host'] . ";";
|
||||||
|
$dsn .= "port=" . $cfg['db'][$dbn]['port'] . ";";
|
||||||
|
|
||||||
|
$opt = array(
|
||||||
|
PDO :: ATTR_ERRMODE => PDO :: ERRMODE_EXCEPTION,
|
||||||
|
PDO :: ATTR_DEFAULT_FETCH_MODE => PDO :: FETCH_ASSOC
|
||||||
|
);
|
||||||
|
$this -> PDO = new PDO( $dsn, $_POST['Username'], $_POST['Password'], $opt );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* execute a query that doesn't have any parameters
|
||||||
|
*
|
||||||
|
* @param $query the mysql query
|
||||||
|
* @return returns a PDOStatement object
|
||||||
|
*/
|
||||||
|
public function executeWithoutParams( $query ) {
|
||||||
|
$statement = $this -> PDO -> prepare( $query );
|
||||||
|
$statement -> execute();
|
||||||
|
return $statement;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* execute a query that has parameters
|
||||||
|
*
|
||||||
|
* @param $query the mysql query
|
||||||
|
* @param $params the parameters that are being used by the query
|
||||||
|
* @return returns a PDOStatement object
|
||||||
|
*/
|
||||||
|
public function execute( $query, $params ) {
|
||||||
|
$statement = $this -> PDO -> prepare( $query );
|
||||||
|
$statement -> execute( $params );
|
||||||
|
return $statement;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* execute a query (an insertion query) that has parameters and return the id of it's insertion
|
||||||
|
*
|
||||||
|
* @param $query the mysql query
|
||||||
|
* @param $params the parameters that are being used by the query
|
||||||
|
* @return returns the id of the last inserted element.
|
||||||
|
*/
|
||||||
|
public function executeReturnId( $tb_name, $data ) {
|
||||||
|
$field_values = ':' . implode( ',:', array_keys( $data ) );
|
||||||
|
$field_options = implode( ',', array_keys( $data ) );
|
||||||
|
try {
|
||||||
|
$sth = $this -> PDO -> prepare( "INSERT INTO $tb_name ($field_options) VALUE ($field_values)" );
|
||||||
|
foreach ( $data as $key => $value )
|
||||||
|
{
|
||||||
|
$sth -> bindValue( ":$key", $value );
|
||||||
|
}
|
||||||
|
$this -> PDO -> beginTransaction();
|
||||||
|
$sth -> execute();
|
||||||
|
$lastId = $this -> PDO -> lastInsertId();
|
||||||
|
$this -> PDO -> commit();
|
||||||
|
}
|
||||||
|
catch ( Exception $e )
|
||||||
|
{
|
||||||
|
// for rolling back the changes during transaction
|
||||||
|
$this -> PDO -> rollBack();
|
||||||
|
throw new Exception( "error in inseting" );
|
||||||
|
}
|
||||||
|
return $lastId;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
* Select function using prepared statement
|
* Select function using prepared statement
|
||||||
|
*
|
||||||
* @param string $tb_name Table Name to Select
|
* @param string $tb_name Table Name to Select
|
||||||
* @param array $data Associative array
|
* @param array $data Associative array
|
||||||
* @param string $where where to select
|
* @param string $where where to select
|
||||||
* @return statement object
|
* @return statement object
|
||||||
*/
|
*/
|
||||||
public function selectWithParameter($param, $tb_name, $data, $where)
|
public function selectWithParameter( $param, $tb_name, $data, $where )
|
||||||
{
|
{
|
||||||
try{
|
try {
|
||||||
$sth = $this->PDO->prepare("SELECT $param FROM $tb_name WHERE $where");
|
$sth = $this -> PDO -> prepare( "SELECT $param FROM $tb_name WHERE $where" );
|
||||||
$this->PDO->beginTransaction();
|
$this -> PDO -> beginTransaction();
|
||||||
$sth->execute($data);
|
$sth -> execute( $data );
|
||||||
$this->PDO->commit();
|
$this -> PDO -> commit();
|
||||||
}catch(Exception $e)
|
}
|
||||||
{
|
catch( Exception $e )
|
||||||
$this->PDO->rollBack();
|
{
|
||||||
throw new Exception("error selection");
|
$this -> PDO -> rollBack();
|
||||||
return false;
|
throw new Exception( "error selection" );
|
||||||
}
|
return false;
|
||||||
|
}
|
||||||
return $sth;
|
return $sth;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* Select function using prepared statement
|
* Select function using prepared statement
|
||||||
|
*
|
||||||
* @param string $tb_name Table Name to Select
|
* @param string $tb_name Table Name to Select
|
||||||
* @param array $data Associative array
|
* @param array $data Associative array
|
||||||
* @param string $where where to select
|
* @param string $where where to select
|
||||||
* @return statement object
|
* @return statement object
|
||||||
*/
|
*/
|
||||||
public function select($tb_name, $data ,$where)
|
public function select( $tb_name, $data , $where )
|
||||||
{
|
{
|
||||||
try{
|
try {
|
||||||
$sth = $this->PDO->prepare("SELECT * FROM $tb_name WHERE $where");
|
$sth = $this -> PDO -> prepare( "SELECT * FROM $tb_name WHERE $where" );
|
||||||
$this->PDO->beginTransaction();
|
$this -> PDO -> beginTransaction();
|
||||||
$sth->execute($data);
|
$sth -> execute( $data );
|
||||||
$this->PDO->commit();
|
$this -> PDO -> commit();
|
||||||
}catch(Exception $e)
|
}
|
||||||
{
|
catch( Exception $e )
|
||||||
$this->PDO->rollBack();
|
{
|
||||||
throw new Exception("error selection");
|
$this -> PDO -> rollBack();
|
||||||
return false;
|
throw new Exception( "error selection" );
|
||||||
}
|
return false;
|
||||||
|
}
|
||||||
return $sth;
|
return $sth;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* Update function with prepared statement
|
* Update function with prepared statement
|
||||||
|
*
|
||||||
* @param string $tb_name name of the table
|
* @param string $tb_name name of the table
|
||||||
* @param array $data associative array with values
|
* @param array $data associative array with values
|
||||||
* @param string $where where part
|
* @param string $where where part
|
||||||
* @throws Exception error in updating
|
* @throws Exception error in updating
|
||||||
*/
|
*/
|
||||||
public function update($tb_name, $data, $where)
|
public function update( $tb_name, $data, $where )
|
||||||
{
|
{
|
||||||
$field_option_values=null;
|
$field_option_values = null;
|
||||||
foreach ($data as $key => $value)
|
foreach ( $data as $key => $value )
|
||||||
{
|
{
|
||||||
$field_option_values.=",$key".'=:'.$value;
|
$field_option_values .= ",$key" . '=:' . $key;
|
||||||
}
|
}
|
||||||
$field_option_values = ltrim($field_option_values,',');
|
$field_option_values = ltrim( $field_option_values, ',' );
|
||||||
try {
|
try {
|
||||||
$sth = $this->PDO->prepare("UPDATE $tb_name SET $field_option_values WHERE $where ");
|
$sth = $this -> PDO -> prepare( "UPDATE $tb_name SET $field_option_values WHERE $where " );
|
||||||
|
|
||||||
|
foreach ( $data as $key => $value )
|
||||||
|
{
|
||||||
|
$sth -> bindValue( ":$key", $value );
|
||||||
|
}
|
||||||
|
$this -> PDO -> beginTransaction();
|
||||||
|
$sth -> execute();
|
||||||
|
$this -> PDO -> commit();
|
||||||
|
}
|
||||||
|
catch ( Exception $e )
|
||||||
|
{
|
||||||
|
$this -> PDO -> rollBack();
|
||||||
|
throw new Exception( 'error in updating' );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($data as $key => $value)
|
|
||||||
{
|
|
||||||
$sth->bindValue(":$key", $value);
|
|
||||||
}
|
|
||||||
$this->PDO->beginTransaction();
|
|
||||||
$sth->execute();
|
|
||||||
$this->PDO->commit();
|
|
||||||
}catch (Exception $e)
|
|
||||||
{
|
|
||||||
$this->PDO->rollBack();
|
|
||||||
throw new Exception('error in updating');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* insert function using prepared statements
|
* insert function using prepared statements
|
||||||
|
*
|
||||||
* @param string $tb_name Name of the table to insert in
|
* @param string $tb_name Name of the table to insert in
|
||||||
* @param array $data Associative array of data to insert
|
* @param array $data Associative array of data to insert
|
||||||
*/
|
*/
|
||||||
|
public function insert( $tb_name, $data )
|
||||||
|
{
|
||||||
|
$field_values = ':' . implode( ',:', array_keys( $data ) );
|
||||||
|
$field_options = implode( ',', array_keys( $data ) );
|
||||||
|
try {
|
||||||
|
$sth = $this -> PDO -> prepare( "INSERT INTO $tb_name ($field_options) VALUE ($field_values)" );
|
||||||
|
foreach ( $data as $key => $value )
|
||||||
|
{
|
||||||
|
|
||||||
public function insert($tb_name, $data)
|
$sth -> bindValue( ":$key", $value );
|
||||||
{
|
}
|
||||||
$field_values =':'. implode(',:', array_keys($data));
|
$this -> PDO -> beginTransaction();
|
||||||
$field_options = implode(',', array_keys($data));
|
// execution
|
||||||
try{
|
$sth -> execute();
|
||||||
$sth = $this->PDO->prepare("INSERT INTO $tb_name ($field_options) VALUE ($field_values)");
|
$this -> PDO -> commit();
|
||||||
foreach ($data as $key => $value )
|
|
||||||
{
|
|
||||||
$sth->bindValue(":$key", $value);
|
|
||||||
}
|
|
||||||
$this->PDO->beginTransaction();
|
|
||||||
//execution
|
|
||||||
$sth->execute();
|
|
||||||
$this->PDO->commit();
|
|
||||||
|
|
||||||
}catch (Exception $e)
|
}
|
||||||
{
|
catch ( Exception $e )
|
||||||
//for rolling back the changes during transaction
|
{
|
||||||
$this->PDO->rollBack();
|
// for rolling back the changes during transaction
|
||||||
throw new Exception("error in inseting");
|
$this -> PDO -> rollBack();
|
||||||
|
throw new Exception( "error in inseting" );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* Delete database entery using prepared statement
|
* Delete database entery using prepared statement
|
||||||
|
*
|
||||||
* @param string $tb_name
|
* @param string $tb_name
|
||||||
* @param string $where
|
* @param string $where
|
||||||
* @throws error in deleting
|
* @throws error in deleting
|
||||||
*/
|
*/
|
||||||
public function delete($tb_name, $where)
|
public function delete( $tb_name, $data, $where )
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$sth = $this->prepare("DELETE FROM $tb_name WHERE $where");
|
$sth = $this -> PDO -> prepare( "DELETE FROM $tb_name WHERE $where" );
|
||||||
$this->PDO->beginTransaction();
|
$this -> PDO -> beginTransaction();
|
||||||
$sth->execute();
|
$sth -> execute( $data );
|
||||||
$this->PDO->commit();
|
$this -> PDO -> commit();
|
||||||
}
|
}
|
||||||
catch (Exception $e)
|
catch ( Exception $e )
|
||||||
{
|
{
|
||||||
$this->rollBack();
|
$this -> PDO -> rollBack();
|
||||||
throw new Exception("error in deleting");
|
throw new Exception( "error in deleting" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -1,224 +1,241 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Helper class for more site specific functions.
|
* Helper class for more site specific functions.
|
||||||
* @author Daan Janssens, mentored by Matthew Lagoe
|
*
|
||||||
*
|
* @author Daan Janssens, mentored by Matthew Lagoe
|
||||||
*/
|
*/
|
||||||
class Helpers{
|
class Helpers {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* workhorse of the website, it loads the template and shows it or returns th html.
|
* workhorse of the website, it loads the template and shows it or returns th html.
|
||||||
* it uses smarty to load the $template, but before displaying the template it will pass the $vars to smarty. Also based on your language settings a matching
|
* it uses smarty to load the $template, but before displaying the template it will pass the $vars to smarty. Also based on your language settings a matching
|
||||||
* array of words & sentences for that page will be loaded. In case the $returnHTML parameter is set to true, it will return the html instead of displaying the template.
|
* array of words & sentences for that page will be loaded. In case the $returnHTML parameter is set to true, it will return the html instead of displaying the template.
|
||||||
* @param $template the name of the template(page) that we want to load.
|
*
|
||||||
* @param $vars an array of variables that should be loaded by smarty before displaying or returning the html.
|
* @param $template the name of the template(page) that we want to load.
|
||||||
* @param $returnHTML (default=false) if set to true, the html that should have been displayed, will be returned.
|
* @param $vars an array of variables that should be loaded by smarty before displaying or returning the html.
|
||||||
* @return in case $returnHTML=true, it returns the html of the template being loaded.
|
* @param $returnHTML (default=false) if set to true, the html that should have been displayed, will be returned.
|
||||||
*/
|
* @return in case $returnHTML=true, it returns the html of the template being loaded.
|
||||||
public static function loadTemplate( $template, $vars = array (), $returnHTML = false )
|
*/
|
||||||
{
|
public static function loadTemplate( $template, $vars = array (), $returnHTML = false )
|
||||||
global $AMS_LIB;
|
{
|
||||||
|
global $AMS_LIB;
|
||||||
global $SITEBASE;
|
global $SITEBASE;
|
||||||
global $AMS_TRANS;
|
global $AMS_TRANS;
|
||||||
global $INGAME_LAYOUT;
|
global $INGAME_LAYOUT;
|
||||||
//define('SMARTY_SPL_AUTOLOAD',1);
|
// define('SMARTY_SPL_AUTOLOAD',1);
|
||||||
require_once $AMS_LIB . '/smarty/libs/Smarty.class.php';
|
require_once $AMS_LIB . '/smarty/libs/Smarty.class.php';
|
||||||
spl_autoload_register('__autoload');
|
spl_autoload_register( '__autoload' );
|
||||||
|
|
||||||
$smarty = new Smarty;
|
$smarty = new Smarty;
|
||||||
$smarty->setCompileDir($SITEBASE.'/templates_c/');
|
$smarty -> setCompileDir( $SITEBASE . '/templates_c/' );
|
||||||
$smarty->setCacheDir($SITEBASE.'/cache/');
|
$smarty -> setCacheDir( $SITEBASE . '/cache/' );
|
||||||
$smarty -> setConfigDir($SITEBASE . '/configs/' );
|
$smarty -> setConfigDir( $SITEBASE . '/configs/' );
|
||||||
// turn smarty debugging on/off
|
// turn smarty debugging on/off
|
||||||
$smarty -> debugging = false;
|
$smarty -> debugging = false;
|
||||||
// caching must be disabled for multi-language support
|
// caching must be disabled for multi-language support
|
||||||
$smarty -> caching = false;
|
$smarty -> caching = false;
|
||||||
$smarty -> cache_lifetime = 5;
|
$smarty -> cache_lifetime = 5;
|
||||||
|
|
||||||
//needed by smarty.
|
// needed by smarty.
|
||||||
helpers :: create_folders ();
|
helpers :: create_folders ();
|
||||||
global $FORCE_INGAME;
|
global $FORCE_INGAME;
|
||||||
|
|
||||||
//if ingame, then use the ingame templates
|
// if ingame, then use the ingame templates
|
||||||
if ( helpers::check_if_game_client() or $FORCE_INGAME ){
|
if ( helpers :: check_if_game_client() or $FORCE_INGAME ) {
|
||||||
$smarty -> template_dir = $AMS_LIB . '/ingame_templates/';
|
$smarty -> template_dir = $AMS_LIB . '/ingame_templates/';
|
||||||
$smarty -> setConfigDir( $AMS_LIB . '/configs' );
|
$smarty -> setConfigDir( $AMS_LIB . '/configs' );
|
||||||
$variables = parse_ini_file( $AMS_LIB . '/configs/ingame_layout.ini', true );
|
$variables = parse_ini_file( $AMS_LIB . '/configs/ingame_layout.ini', true );
|
||||||
foreach ( $variables[$INGAME_LAYOUT] as $key => $value ){
|
foreach ( $variables[$INGAME_LAYOUT] as $key => $value ) {
|
||||||
$smarty -> assign( $key, $value );
|
$smarty -> assign( $key, $value );
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
$smarty -> template_dir = $SITEBASE . '/templates/';
|
$smarty -> template_dir = $SITEBASE . '/templates/';
|
||||||
$smarty -> setConfigDir( $SITEBASE . '/configs' );
|
$smarty -> setConfigDir( $SITEBASE . '/configs' );
|
||||||
}
|
|
||||||
|
|
||||||
foreach ( $vars as $key => $value ){
|
|
||||||
$smarty -> assign( $key, $value );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//load page specific variables that are language dependent
|
foreach ( $vars as $key => $value ) {
|
||||||
$variables = Helpers::handle_language();
|
$smarty -> assign( $key, $value );
|
||||||
foreach ( $variables[$template] as $key => $value ){
|
|
||||||
$smarty -> assign( $key, $value );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//smarty inheritance for loading the matching wrapper layout (with the matching menu bar)
|
// load page specific variables that are language dependent
|
||||||
if( isset($vars['permission']) && $vars['permission'] == 3 ){
|
$variables = Helpers :: handle_language();
|
||||||
$inherited = "extends:layout_admin.tpl|";
|
if ( $template != 'layout_plugin' )
|
||||||
}else if( isset($vars['permission']) && $vars['permission'] == 2){
|
{
|
||||||
$inherited = "extends:layout_mod.tpl|";
|
foreach ( $variables[$template] as $key => $value ) {
|
||||||
}else if( isset($vars['permission']) && $vars['permission'] == 1){
|
$smarty -> assign( $key, $value );
|
||||||
$inherited = "extends:layout_user.tpl|";
|
}
|
||||||
}else{
|
}
|
||||||
$inherited ="";
|
// load ams content variables that are language dependent
|
||||||
}
|
foreach ( $variables['ams_content'] as $key => $value ) {
|
||||||
|
$smarty -> assign( $key, $value );
|
||||||
|
}
|
||||||
|
|
||||||
//if $returnHTML is set to true, return the html by fetching the template else display the template.
|
// smarty inheritance for loading the matching wrapper layout (with the matching menu bar)
|
||||||
if($returnHTML == true){
|
if ( isset( $vars['permission'] ) && $vars['permission'] == 3 ) {
|
||||||
return $smarty ->fetch($inherited . $template . '.tpl' );
|
$inherited = "extends:layout_admin.tpl|";
|
||||||
}else{
|
} else if ( isset( $vars['permission'] ) && $vars['permission'] == 2 ) {
|
||||||
$smarty -> display( $inherited . $template . '.tpl' );
|
$inherited = "extends:layout_mod.tpl|";
|
||||||
}
|
} else if ( isset( $vars['permission'] ) && $vars['permission'] == 1 ) {
|
||||||
}
|
$inherited = "extends:layout_user.tpl|";
|
||||||
|
} else {
|
||||||
|
$inherited = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
// if $returnHTML is set to true, return the html by fetching the template else display the template.
|
||||||
|
if ( $returnHTML == true ) {
|
||||||
|
return $smarty -> fetch( $inherited . $template . '.tpl' );
|
||||||
|
} else {
|
||||||
|
$smarty -> display( $inherited . $template . '.tpl' );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* creates the folders that are needed for smarty.
|
* creates the folders that are needed for smarty.
|
||||||
* @todo for the drupal module it might be possible that drupal_mkdir needs to be used instead of mkdir, also this should be in the install.php instead.
|
*
|
||||||
*/
|
* @todo for the drupal module it might be possible that drupal_mkdir needs to be used instead of mkdir, also this should be in the install.php instead.
|
||||||
static public function create_folders(){
|
*/
|
||||||
global $AMS_LIB;
|
static public function create_folders() {
|
||||||
|
global $AMS_LIB;
|
||||||
global $SITEBASE;
|
global $SITEBASE;
|
||||||
$arr = array( $AMS_LIB . '/ingame_templates/',
|
$arr = array( $AMS_LIB . '/ingame_templates/',
|
||||||
$AMS_LIB . '/configs',
|
$AMS_LIB . '/configs',
|
||||||
//$AMS_LIB . '/cache',
|
// $AMS_LIB . '/cache',
|
||||||
$SITEBASE . '/cache/',
|
$SITEBASE . '/cache/',
|
||||||
$SITEBASE . '/templates/',
|
$SITEBASE . '/templates/',
|
||||||
$SITEBASE . '/templates_c/',
|
$SITEBASE . '/templates_c/',
|
||||||
$SITEBASE . '/configs'
|
$SITEBASE . '/configs'
|
||||||
);
|
);
|
||||||
foreach ( $arr as & $value ){
|
foreach ( $arr as &$value ) {
|
||||||
|
|
||||||
if ( !file_exists( $value ) ){
|
if ( !file_exists( $value ) ) {
|
||||||
print($value);
|
print( $value );
|
||||||
mkdir($value);
|
mkdir( $value );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* check if the http request is sent ingame or not.
|
* check if the http request is sent ingame or not.
|
||||||
|
*
|
||||||
* @return returns true in case it's sent ingame, else false is returned.
|
* @return returns true in case it's sent ingame, else false is returned.
|
||||||
*/
|
*/
|
||||||
static public function check_if_game_client()
|
static public function check_if_game_client()
|
||||||
{
|
{
|
||||||
// if HTTP_USER_AGENT is not set then its ryzom core
|
// if HTTP_USER_AGENT is not set then its ryzom core
|
||||||
global $FORCE_INGAME;
|
global $FORCE_INGAME;
|
||||||
if ( ( isset($_SERVER['HTTP_USER_AGENT']) && (strpos($_SERVER['HTTP_USER_AGENT'],"Ryzom") === 0)) || $FORCE_INGAME || ! isset($_SERVER['HTTP_USER_AGENT']) ){
|
if ( ( isset( $_SERVER['HTTP_USER_AGENT'] ) && ( strpos( $_SERVER['HTTP_USER_AGENT'], "Ryzom" ) === 0 ) ) || $FORCE_INGAME || ! isset( $_SERVER['HTTP_USER_AGENT'] ) ) {
|
||||||
return true;
|
return true;
|
||||||
}else{
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles the language specific aspect.
|
* Handles the language specific aspect.
|
||||||
* The language can be changed by setting the $_GET['Language'] & $_GET['setLang'] together. This will also change the language entry of the user in the db.
|
* The language can be changed by setting the $_GET['Language'] & $_GET['setLang'] together. This will also change the language entry of the user in the db.
|
||||||
* Cookies are also being used in case the user isn't logged in.
|
* Cookies are also being used in case the user isn't logged in.
|
||||||
|
*
|
||||||
* @return returns the parsed content of the language .ini file related to the users language setting.
|
* @return returns the parsed content of the language .ini file related to the users language setting.
|
||||||
*/
|
*/
|
||||||
static public function handle_language(){
|
static public function handle_language() {
|
||||||
global $DEFAULT_LANGUAGE;
|
global $DEFAULT_LANGUAGE;
|
||||||
global $AMS_TRANS;
|
global $AMS_TRANS;
|
||||||
|
|
||||||
//if user wants to change the language
|
// if user wants to change the language
|
||||||
if(isset($_GET['Language']) && isset($_GET['setLang'])){
|
if ( isset( $_GET['Language'] ) && isset( $_GET['setLang'] ) ) {
|
||||||
//The ingame client sometimes sends full words, derive those!
|
// The ingame client sometimes sends full words, derive those!
|
||||||
switch($_GET['Language']){
|
switch ( $_GET['Language'] ) {
|
||||||
|
|
||||||
case "English":
|
case "English":
|
||||||
$lang = "en";
|
$lang = "en";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "French":
|
case "French":
|
||||||
$lang = "fr";
|
$lang = "fr";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
$lang = $_GET['Language'];
|
$lang = $_GET['Language'];
|
||||||
}
|
}
|
||||||
//if the file exists en the setLang = true
|
// if the file exists en the setLang = true
|
||||||
if( file_exists( $AMS_TRANS . '/' . $lang . '.ini' ) && $_GET['setLang'] == "true"){
|
if ( file_exists( $AMS_TRANS . '/' . $lang . '.ini' ) && $_GET['setLang'] == "true" ) {
|
||||||
//set a cookie & session var and incase logged in write it to the db!
|
// set a cookie & session var and incase logged in write it to the db!
|
||||||
setcookie( 'Language', $lang , time() + 60*60*24*30 );
|
setcookie( 'Language', $lang , time() + 60 * 60 * 24 * 30 );
|
||||||
$_SESSION['Language'] = $lang;
|
$_SESSION['Language'] = $lang;
|
||||||
if(WebUsers::isLoggedIn()){
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
WebUsers::setLanguage($_SESSION['id'],$lang);
|
WebUsers :: setLanguage( $_SESSION['id'], $lang );
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
//if the session var is not set yet
|
// if the session var is not set yet
|
||||||
if(!isset($_SESSION['Language'])){
|
if ( !isset( $_SESSION['Language'] ) ) {
|
||||||
//check if a cookie already exists for it
|
// check if a cookie already exists for it
|
||||||
if ( isset( $_COOKIE['Language'] ) ) {
|
if ( isset( $_COOKIE['Language'] ) ) {
|
||||||
$_SESSION['Language'] = $_COOKIE['Language'];
|
$_SESSION['Language'] = $_COOKIE['Language'];
|
||||||
//else use the default language
|
// else use the default language
|
||||||
}else{
|
} else {
|
||||||
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_SESSION['Language'] == ""){
|
|
||||||
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
|
||||||
}
|
|
||||||
return parse_ini_file( $AMS_TRANS . '/' . $_SESSION['Language'] . '.ini', true );
|
|
||||||
|
|
||||||
|
if ( $_SESSION['Language'] == "" ) {
|
||||||
|
$_SESSION['Language'] = $DEFAULT_LANGUAGE;
|
||||||
}
|
}
|
||||||
|
return parse_ini_file( $AMS_TRANS . '/' . $_SESSION['Language'] . '.ini', true );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Time output function for handling the time display.
|
* Time output function for handling the time display.
|
||||||
* @return returns the time in the format specified in the $TIME_FORMAT global variable.
|
*
|
||||||
*/
|
* @return returns the time in the format specified in the $TIME_FORMAT global variable.
|
||||||
static public function outputTime($time, $str = 1){
|
*/
|
||||||
global $TIME_FORMAT;
|
static public function outputTime( $time, $str = 1 ) {
|
||||||
if($str){
|
global $TIME_FORMAT;
|
||||||
return date($TIME_FORMAT,strtotime($time));
|
if ( $str ) {
|
||||||
}else{
|
return date( $TIME_FORMAT, strtotime( $time ) );
|
||||||
return date($TIME_FORMAT,$time);
|
} else {
|
||||||
}
|
return date( $TIME_FORMAT, $time );
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Auto login function for ingame use.
|
|
||||||
* This function will allow users who access the website ingame, to log in without entering the username and password. It uses the COOKIE entry in the open_ring db.
|
|
||||||
* it checks if the cookie sent by the http request matches the one in the db. This cookie in the db is changed everytime the user relogs.
|
|
||||||
* @return returns "FALSE" if the cookies didn't match, else it returns an array with the user's id and name.
|
|
||||||
*/
|
|
||||||
static public function check_login_ingame(){
|
|
||||||
if ( helpers :: check_if_game_client () or $forcelibrender = false ){
|
|
||||||
$dbr = new DBLayer("ring");
|
|
||||||
if (isset($_GET['UserId']) && isset($_COOKIE['ryzomId'])){
|
|
||||||
$id = $_GET['UserId'];
|
|
||||||
$statement = $dbr->select("ring_users", array('id' => $id, 'cookie' => $_COOKIE['ryzomId']), "user_id=:id AND cookie =:cookie");
|
|
||||||
if ($statement->rowCount() ){
|
|
||||||
$entry = $statement->fetch();
|
|
||||||
//print_r($entry);
|
|
||||||
return array('id' => $entry['user_id'], 'name' => $entry['user_name']);
|
|
||||||
}else{
|
|
||||||
return "FALSE";
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
return "FALSE";
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
return "FALSE";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Auto login function for ingame use.
|
||||||
|
* This function will allow users who access the website ingame, to log in without entering the username and password. It uses the COOKIE entry in the open_ring db.
|
||||||
|
* it checks if the cookie sent by the http request matches the one in the db. This cookie in the db is changed everytime the user relogs.
|
||||||
|
*
|
||||||
|
* @return returns "FALSE" if the cookies didn't match, else it returns an array with the user's id and name.
|
||||||
|
*/
|
||||||
|
static public function check_login_ingame() {
|
||||||
|
if ( helpers :: check_if_game_client () or $forcelibrender = false ) {
|
||||||
|
$dbr = new DBLayer( "ring" );
|
||||||
|
if ( isset( $_GET['UserId'] ) && isset( $_COOKIE['ryzomId'] ) ) {
|
||||||
|
$id = $_GET['UserId'];
|
||||||
|
|
||||||
|
$statement = $dbr -> select( "ring_users", array( 'id' => $id, 'cookie' => $_COOKIE['ryzomId'] ), "user_id=:id AND cookie =:cookie" );
|
||||||
|
|
||||||
|
// $statement = $dbr->execute("SELECT * FROM ring_users WHERE user_id=:id AND cookie =:cookie", array('id' => $id, 'cookie' => $_COOKIE['ryzomId']));
|
||||||
|
|
||||||
|
if ( $statement -> rowCount() ) {
|
||||||
|
$entry = $statement -> fetch();
|
||||||
|
// print_r($entry);
|
||||||
|
return array( 'id' => $entry['user_id'], 'name' => $entry['user_name'] );
|
||||||
|
} else {
|
||||||
|
return "FALSE";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return "FALSE";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return "FALSE";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,123 +1,270 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* API for loading and interacting with plugins
|
||||||
* contains the getters and setters for plugins
|
* contains getters and setters
|
||||||
* @author shubham meena mentored by Matthew Lagoe
|
*
|
||||||
**/
|
* @author shubham meena mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
class Plugincache{
|
class Plugincache {
|
||||||
private $id;
|
private $id;
|
||||||
private $plugin_name;
|
private $plugin_name;
|
||||||
private $plugin_version;
|
private $plugin_type;
|
||||||
private $plugin_permission;
|
private $plugin_permission;
|
||||||
private $plugin_isactive;
|
private $plugin_status;
|
||||||
|
private $plugin_info = array();
|
||||||
|
private $update_info = array();
|
||||||
|
/**
|
||||||
|
* A constructor.
|
||||||
|
* Empty constructor
|
||||||
|
*/
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public function set( $values ) {
|
||||||
|
$this -> setId( $values['Id'] );
|
||||||
|
$this -> setPluginName( $values['Name'] );
|
||||||
|
$this -> setPluginType( $values['Type'] );
|
||||||
|
$this -> setPluginPermission( $values['Permission'] );
|
||||||
|
$this -> setPluginStatus( $values['Status'] );
|
||||||
|
$this -> setPluginInfo( json_decode( $values['Info'] ) );
|
||||||
|
@$this -> setUpdateInfo( json_decode( $values['UpdateInfo'] ) );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A constructor.
|
* loads the object's attributes.
|
||||||
* Empty constructor
|
*/
|
||||||
*/
|
|
||||||
|
|
||||||
public function __construct() {
|
public function load_With_SID() {
|
||||||
}
|
$dbl = new DBLayer( "lib" );
|
||||||
|
$statement = $dbl -> executeWithoutParams( "SELECT * FROM plugins" );
|
||||||
public function set($values) {
|
$row = $statement -> fetch();
|
||||||
$this->setId($values['PluginId']);
|
$this -> set( $row );
|
||||||
$this->setPluginName($values['PluginName']);
|
}
|
||||||
$this->setPluginVersion($values['PluginVersion']);
|
|
||||||
$this->setPluginPermission($values['PluginPermission']);
|
|
||||||
$this->setIsActive($values['IsActive']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* loads the object's attributes.
|
* get plugin id attribute of the object.
|
||||||
*/
|
*
|
||||||
public function load_With_SID( ) {
|
* @return integer id
|
||||||
$dbl = new DBLayer("lib");
|
*/
|
||||||
$statement = $dbl->executeWithoutParams("SELECT * FROM plugins");
|
public function getId() {
|
||||||
$row = $statement->fetch();
|
return $this -> Id;
|
||||||
$this->set($row);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* updates the entry.
|
* get plugin permission attribute of the object.
|
||||||
*/
|
*/
|
||||||
public function update(){
|
public function getPluginPermission() {
|
||||||
$dbl = new DBLayer("lib");
|
return $this -> plugin_permission;
|
||||||
$values = Array('t' => $this->getPluginPermission(), 'q' => $this->getPluginVersion(), 'd' => $this->getIsActive());
|
}
|
||||||
$dbl->update("plugins", $values, "PluginName= $this->getPluginName()");
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getId(){
|
|
||||||
return $this->Id;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get plugin permission attribute of the object.
|
* get plugin Type attribute of the object.
|
||||||
*/
|
*/
|
||||||
public function getPluginPermission(){
|
public function getPluginType() {
|
||||||
return $this->plugin_permission;
|
return $this -> plugin_version;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get plugin version attribute of the object.
|
* get plugin status attribute of the object.
|
||||||
*/
|
*/
|
||||||
public function getPluginVersion(){
|
public function getPluginStatus() {
|
||||||
return $this->plugin_version;
|
return $this -> plugin_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get plugin is active attribute of the object.
|
* get plugin name attribute of the object.
|
||||||
*/
|
*/
|
||||||
public function getIsActive(){
|
public function getPluginName() {
|
||||||
return $this->plugin_isactive;
|
return $this -> plugin_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get plugin name attribute of the object.
|
* get plugin info array attribute of the object.
|
||||||
*/
|
*/
|
||||||
public function getPluginName(){
|
public function getPluginInfo() {
|
||||||
return $this->plugin_name;
|
return $this -> plugin_info;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set plugin id attribute of the object.
|
* set plugin id attribute of the object.
|
||||||
* @param $s integer id
|
*
|
||||||
*/
|
* @param $s integer id
|
||||||
|
*/
|
||||||
public function setId($s){
|
public function setId( $s ) {
|
||||||
$this->Id = $s;
|
$this -> Id = $s;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set plugin permission attribute of the object.
|
* set plugin permission attribute of the object.
|
||||||
* @param $t type of the query, set permission
|
*
|
||||||
*/
|
* @param $t type of the query, set permission
|
||||||
public function setPluginPermission($t){
|
*/
|
||||||
$this->plugin_permission = $t;
|
public function setPluginPermission( $t ) {
|
||||||
}
|
$this -> plugin_permission = $t;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set plugin version attribute of the object.
|
* set plugin version attribute of the object.
|
||||||
* @param $q string to set plugin version
|
*
|
||||||
*/
|
* @param $q string to set plugin version
|
||||||
public function setPluginVersion($q){
|
*/
|
||||||
$this->plugin_version= $q;
|
public function setPluginType( $q ) {
|
||||||
}
|
$this -> plugin_version = $q;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set plugin is active attribute of the object.
|
* set plugin status attribute of the object.
|
||||||
* @param $d tinyint to set plugin is active or not .
|
*
|
||||||
*/
|
* @param $d status code type int
|
||||||
public function setIsActive($d){
|
*/
|
||||||
$this->plugin_isactive= $d;
|
public function setPluginStatus( $d ) {
|
||||||
}
|
$this -> plugin_status = $d;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set plugin name attribute of the object.
|
* set plugin name attribute of the object.
|
||||||
* @param $p_n string to set plugin name.
|
*
|
||||||
*/
|
* @param $p_n string to set plugin name.
|
||||||
public function setPluginName($p_n){
|
*/
|
||||||
$this->plugin_name= $p_n;
|
public function setPluginName( $p_n ) {
|
||||||
|
$this -> plugin_name = $p_n;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set plugin info attribute array of the object.
|
||||||
|
*
|
||||||
|
* @param $p_n array
|
||||||
|
*/
|
||||||
|
public function setPluginInfo( $p_n ) {
|
||||||
|
$this -> plugin_info = $p_n;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* functionalities for plugin updates
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set update info attribute array of the object.
|
||||||
|
*
|
||||||
|
* @param $p_n array
|
||||||
|
*/
|
||||||
|
public function setUpdateInfo( $p_n ) {
|
||||||
|
$this -> update_info = $p_n;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get plugin info array attribute of the object.
|
||||||
|
*/
|
||||||
|
public function getUpdateInfo() {
|
||||||
|
return $this -> update_info;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* some more plugin function that requires during plugin operations
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to remove a non empty directory
|
||||||
|
*
|
||||||
|
* @param $dir directory address
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public static function rrmdir( $dir ) {
|
||||||
|
if ( is_dir( $dir ) ) {
|
||||||
|
$objects = scandir( $dir );
|
||||||
|
foreach ( $objects as $object ) {
|
||||||
|
if ( $object != "." && $object != ".." ) {
|
||||||
|
if ( filetype( $dir . "/" . $object ) == "dir" ) rmdir( $dir . "/" . $object );
|
||||||
|
else unlink( $dir . "/" . $object );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
reset( $objects );
|
||||||
|
return rmdir( $dir );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to unzip the zipped files
|
||||||
|
*
|
||||||
|
* @param $target_path path to the target zipped file
|
||||||
|
* @param $destination path to the destination
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public static function zipExtraction( $target_path, $destination )
|
||||||
|
{
|
||||||
|
$zip = new ZipArchive();
|
||||||
|
$x = $zip -> open( $target_path );
|
||||||
|
if ( $x === true ) {
|
||||||
|
if ( $zip -> extractTo( $destination ) )
|
||||||
|
{
|
||||||
|
$zip -> close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$zip -> close();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns plugin information with respect to the id
|
||||||
|
*
|
||||||
|
* @param id $ plugin id
|
||||||
|
* @return field info for the plugin
|
||||||
|
*/
|
||||||
|
public static function pluginInfoUsingId( $id, $fieldName )
|
||||||
|
{
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$sth = $db -> selectWithParameter( $fieldName, 'plugins', array( 'id' => $id ), 'Id=:id' );
|
||||||
|
$row = $sth -> fetch();
|
||||||
|
return $row[$fieldName];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function provides list of active plugins
|
||||||
|
*
|
||||||
|
* @return $ac_plugins list of active plugins
|
||||||
|
*/
|
||||||
|
public static function activePlugins()
|
||||||
|
{
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$sth = $db -> selectWithParameter( 'Id', 'plugins', array( 'status' => 1 ), 'Status=:status' );
|
||||||
|
$row = $sth -> fetchAll();
|
||||||
|
return $row;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to load hooks for the active plugins
|
||||||
|
* and return the contents in the hooks in an array
|
||||||
|
*
|
||||||
|
* @return $content content available in hooks
|
||||||
|
*/
|
||||||
|
public static function loadHooks()
|
||||||
|
{
|
||||||
|
$content = array();
|
||||||
|
$ac_arr = Plugincache :: activePlugins();
|
||||||
|
foreach( $ac_arr as $key => $value )
|
||||||
|
{
|
||||||
|
$plugin_path = Plugincache :: pluginInfoUsingId( $value['Id'], 'FileName' );
|
||||||
|
$pluginName = Plugincache :: pluginInfoUsingId( $value['Id'], 'Name' );
|
||||||
|
|
||||||
|
// calling hooks in the $pluginName.php
|
||||||
|
include $plugin_path . '/' . strtolower( $pluginName ) . '.php';
|
||||||
|
$arr = get_defined_functions();
|
||||||
|
|
||||||
|
foreach( $arr['user'] as $key => $value )
|
||||||
|
{
|
||||||
|
if ( stristr( $value, strtolower( $pluginName ) ) == true )
|
||||||
|
{
|
||||||
|
$content['hook_info'][$pluginName] = call_user_func( $value );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
|
@ -5,6 +5,9 @@
|
||||||
login_info = "Please enter your MySQL Username and Password to install the database.<br>This is being loaded because the is_installed file is missing.<br>This process will take about 30 seconds."
|
login_info = "Please enter your MySQL Username and Password to install the database.<br>This is being loaded because the is_installed file is missing.<br>This process will take about 30 seconds."
|
||||||
login_here = "here"
|
login_here = "here"
|
||||||
|
|
||||||
|
[ams_content]
|
||||||
|
ams_title="Ryzom Account Mangement System"
|
||||||
|
|
||||||
[dashboard]
|
[dashboard]
|
||||||
home_title = "Introduction"
|
home_title = "Introduction"
|
||||||
home_info = "Welcome to the Ryzom Core - Account Management System"
|
home_info = "Welcome to the Ryzom Core - Account Management System"
|
||||||
|
@ -56,12 +59,39 @@ action = "Action"
|
||||||
[plugins]
|
[plugins]
|
||||||
plugin_title = "Plugin List"
|
plugin_title = "Plugin List"
|
||||||
plugin_info = "Here you can see the entire list of plugins . You can easily remove plugins ,activate them and add permissions"
|
plugin_info = "Here you can see the entire list of plugins . You can easily remove plugins ,activate them and add permissions"
|
||||||
plugins= "Plugins"
|
plugins = "Plugins"
|
||||||
plugin_id = "ID"
|
|
||||||
plugin_name = "Name"
|
plugin_name = "Name"
|
||||||
plugin_version= "Version"
|
plugin_version = "Version"
|
||||||
plugin_permission= "Owner/Access Permission"
|
plugin_description = "Description"
|
||||||
plugin_is_active= "On/Off"
|
plugin_type = "Type"
|
||||||
|
plugin_permission = "Access</br> Permission"
|
||||||
|
plugin_status = "Status"
|
||||||
|
ip_success = "Plugin added succesfuly."
|
||||||
|
plugin_actions = "Actions"
|
||||||
|
dp_success = "Plugin deleted successfuly"
|
||||||
|
dp_error = "Error in deleting plugin.Please try again later."
|
||||||
|
ac_success = "Plugin Activated successfuly."
|
||||||
|
ac_error = "Plugin facing some error in activating. Please try again later."
|
||||||
|
dc_success = "Plugin de-Activated successfuly."
|
||||||
|
dc_error = "Plugin facing some error in de-activating. Please try again later."
|
||||||
|
up_success = "Update added successfully. Go to Updates page for installing updates."
|
||||||
|
up_install_success = "Update installed successfully."
|
||||||
|
|
||||||
|
[install_plugin]
|
||||||
|
ip_title = "Install a new Plugin"
|
||||||
|
ip_message = "For example: name.zip from your local computer"
|
||||||
|
ip_support = "Upload the plugin archieve to install.</br>The following file extension is supported: zip."
|
||||||
|
ip_info_nfound = "Info file not found in the Plugin.Please recheck"
|
||||||
|
ip_file_nfnd="Please upload a plugin before clicking on install button"
|
||||||
|
|
||||||
|
[plugins_update]
|
||||||
|
up_title = "Updates for Plugins"
|
||||||
|
up_info = "Here you can see the entire list of available updates for plugins."
|
||||||
|
up_description = "Updates Info"
|
||||||
|
plugin_name = "Name"
|
||||||
|
plugin_version = "Version"
|
||||||
|
up_updated_version = "New Version"
|
||||||
|
up_actions = "Actions"
|
||||||
|
|
||||||
[show_ticket]
|
[show_ticket]
|
||||||
t_title = "Ticket"
|
t_title = "Ticket"
|
||||||
|
@ -136,8 +166,8 @@ go_home = "Go Home"
|
||||||
userlist_info = "welcome to the userlist"
|
userlist_info = "welcome to the userlist"
|
||||||
|
|
||||||
[login]
|
[login]
|
||||||
login_info = "Please login with your Username and Password."
|
login_info = "Please login with your Email/Username and Password."
|
||||||
login_error_message = "The username/password were not correct!"
|
login_error_message = "The Email/username/password were not correct!"
|
||||||
login_register_message ="<strong>Register</strong> If you don't have an account yet, create one"
|
login_register_message ="<strong>Register</strong> If you don't have an account yet, create one"
|
||||||
login_here = "here"
|
login_here = "here"
|
||||||
login_forgot_password_message = "In case you forgot your password, click"
|
login_forgot_password_message = "In case you forgot your password, click"
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This function is used in activating plugins.
|
||||||
|
*
|
||||||
|
* @author Shubham Meena, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
function activate_plugin() {
|
||||||
|
|
||||||
|
// if logged in
|
||||||
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
|
|
||||||
|
if ( isset( $_GET['id'] ) )
|
||||||
|
{
|
||||||
|
// id of plugin to delete
|
||||||
|
$id = filter_var( $_GET['id'], FILTER_SANITIZE_FULL_SPECIAL_CHARS );
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$result = $db -> update( "plugins", array( 'Status' => '1' ), "Id = $id" );
|
||||||
|
if ( $result )
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=3" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=4" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=4" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This function is used in deactivating plugins.
|
||||||
|
*
|
||||||
|
* @author Shubham Meena, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
function deactivate_plugin() {
|
||||||
|
|
||||||
|
// if logged in
|
||||||
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
|
|
||||||
|
|
||||||
|
if ( isset( $_GET['id'] ) )
|
||||||
|
{
|
||||||
|
// id of plugin to delete
|
||||||
|
$id = filter_var( $_GET['id'], FILTER_SANITIZE_FULL_SPECIAL_CHARS );
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$result = $db -> update( "plugins", array( 'Status' => '0' ), "Id = $id" );
|
||||||
|
if ( $result )
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=5" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=6" );
|
||||||
|
exit;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=6" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,68 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This function is used in deleting plugins.
|
||||||
|
*
|
||||||
|
* It removes the plugin from the codebase.
|
||||||
|
*
|
||||||
|
* @author Shubham Meena, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
function delete_plugin() {
|
||||||
|
|
||||||
|
// if logged in
|
||||||
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
|
|
||||||
|
if ( isset( $_GET['id'] ) )
|
||||||
|
{
|
||||||
|
// id of plugin to delete after filtering
|
||||||
|
$id = filter_var( $_GET['id'], FILTER_SANITIZE_FULL_SPECIAL_CHARS );
|
||||||
|
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$sth = $db -> selectWithParameter( "FileName", "plugins", array( 'id' => $id ), "Id=:id" );
|
||||||
|
$name = $sth -> fetch();
|
||||||
|
|
||||||
|
if ( is_dir( "$name[FileName]" ) )
|
||||||
|
{
|
||||||
|
// removing plugin directory from the code base
|
||||||
|
if ( rrmdir( "$name[FileName]" ) )
|
||||||
|
{
|
||||||
|
$db -> delete( 'plugins', array( 'id' => $id ), "Id=:id" );
|
||||||
|
|
||||||
|
header( "Location: index.php?page=plugins&result=2" );
|
||||||
|
exit;
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=0" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
header( "Location: index.php?page=plugins&result=0" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to remove a non empty directory
|
||||||
|
*
|
||||||
|
* @param $dir directory address
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
function rrmdir( $dir ) {
|
||||||
|
if ( is_dir( $dir ) ) {
|
||||||
|
$objects = scandir( $dir );
|
||||||
|
foreach ( $objects as $object ) {
|
||||||
|
if ( $object != "." && $object != ".." ) {
|
||||||
|
if ( filetype( $dir . "/" . $object ) == "dir" ) rmdir( $dir . "/" . $object );
|
||||||
|
else unlink( $dir . "/" . $object );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
reset( $objects );
|
||||||
|
return rmdir( $dir );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,306 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This function is used in installing plugins
|
||||||
|
* It performs validation check for the compressed plugin
|
||||||
|
* then extract in plugin folder to get the info
|
||||||
|
*
|
||||||
|
* @author Shubham Meena, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
function install_plugin() {
|
||||||
|
|
||||||
|
$result = array();
|
||||||
|
|
||||||
|
// if logged in
|
||||||
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
|
|
||||||
|
// path of temporary folder for storing files
|
||||||
|
$temp_path = "../../ams_lib/temp";
|
||||||
|
|
||||||
|
// create a temp directory if not exist
|
||||||
|
// temp folder where we first store all uploaded plugins before install
|
||||||
|
if ( !file_exists( "$temp_path" ) )
|
||||||
|
{
|
||||||
|
mkdir( $temp_path );
|
||||||
|
}
|
||||||
|
|
||||||
|
// checking the server if file is uploaded or not
|
||||||
|
if ( ( isset( $_FILES["file"] ) ) && ( $_FILES["file"]["size"] > 0 ) )
|
||||||
|
{
|
||||||
|
$fileName = $_FILES["file"]["name"]; //the files name takes from the HTML form
|
||||||
|
$fileTmpLoc = $_FILES["file"]["tmp_name"]; //file in the PHP tmp folder
|
||||||
|
$dir = trim( $_FILES["file"]["name"], ".zip" );
|
||||||
|
$target_path = "../../ams_lib/plugins/$dir"; //path in which the zip extraction is to be done
|
||||||
|
$destination = "../../ams_lib/plugins/";
|
||||||
|
|
||||||
|
// scanning plugin folder if plugin with same name is already exists or not
|
||||||
|
$x = checkForUpdate( $dir, $destination, $fileTmpLoc, $temp_path );
|
||||||
|
if ( $x == '1' )
|
||||||
|
{
|
||||||
|
echo "update found";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
else if ( $x == '2' )
|
||||||
|
{
|
||||||
|
echo "Plugin already exists with same name .";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
else if ( $x == '3' )
|
||||||
|
{
|
||||||
|
echo "Update info is not present in the update";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// checking for the command to install plugin is given or not
|
||||||
|
if ( !isset( $_POST['install_plugin'] ) )
|
||||||
|
{
|
||||||
|
if ( ( $_FILES["file"]["type"] == 'application/zip' ) )
|
||||||
|
{
|
||||||
|
if ( move_uploaded_file( $fileTmpLoc, $temp_path . "/" . $fileName ) ) {
|
||||||
|
echo "$fileName upload is complete.</br>" . "<button type='submit' class='btn btn-primary' style='margin-left:5px; margin-top:10px;' name='install_plugin'>Install Plugin</button></br>";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
echo "Error in uploading file.";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
echo "Please select a file with .zip extension to upload.";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
// calling function to unzip archives
|
||||||
|
if ( zipExtraction( $temp_path . "/" . $fileName , $destination ) )
|
||||||
|
{
|
||||||
|
if ( file_exists( $target_path . "/.info" ) )
|
||||||
|
{
|
||||||
|
$result = readPluginFile( ".info", $target_path );
|
||||||
|
|
||||||
|
// sending all info to the database
|
||||||
|
$install_result = array();
|
||||||
|
$install_result['FileName'] = $target_path;
|
||||||
|
$install_result['Name'] = $result['PluginName'];
|
||||||
|
$install_result['Type'] = $result['Type'];
|
||||||
|
if ( Ticket_User :: isMod( unserialize( $_SESSION['ticket_user'] ) ) )
|
||||||
|
{
|
||||||
|
$install_result['Permission'] = 'admin';
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$install_result['Permission'] = 'user';
|
||||||
|
}
|
||||||
|
|
||||||
|
$install_result['Info'] = json_encode( $result );
|
||||||
|
|
||||||
|
// connection with the database
|
||||||
|
$dbr = new DBLayer( "lib" );
|
||||||
|
$dbr -> insert( "plugins", $install_result );
|
||||||
|
|
||||||
|
// if everything is successfull redirecting to the plugin template
|
||||||
|
header( "Location: index.php?page=plugins&result=1" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// file .info not exists
|
||||||
|
rmdir( $target_path );
|
||||||
|
header( "Location: index.php?page=install_plugin&result=2" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// extraction failed
|
||||||
|
header( "Location: index.php?page=install_plugin&result=0" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
echo "Please Browse for a file before clicking the upload button";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to unzip the zipped files
|
||||||
|
*
|
||||||
|
* @param $target_path path to the target zipped file
|
||||||
|
* @param $destination path to the destination
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
function zipExtraction( $target_path, $destination )
|
||||||
|
{
|
||||||
|
$zip = new ZipArchive();
|
||||||
|
$x = $zip -> open( $target_path );
|
||||||
|
if ( $x === true ) {
|
||||||
|
if ( $zip -> extractTo( $destination ) )
|
||||||
|
{
|
||||||
|
$zip -> close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$zip -> close();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to read text files and extract
|
||||||
|
* the information into an array
|
||||||
|
*
|
||||||
|
* -----------------------------------------------------------
|
||||||
|
* format:
|
||||||
|
* -----------------------------------------------------------
|
||||||
|
* PluginName = Name of the plugin
|
||||||
|
* Version = version of the plugin
|
||||||
|
* Type = type of the plugin
|
||||||
|
* Description = Description of the plugin ,it's functionality
|
||||||
|
* -----------------------------------------------------------
|
||||||
|
*
|
||||||
|
* reads only files with name .info
|
||||||
|
*
|
||||||
|
* @param $fileName file to read
|
||||||
|
* @param $targetPath path to the folder containing .info file
|
||||||
|
* @return array containing above information in array(value => key)
|
||||||
|
*/
|
||||||
|
function readPluginFile( $fileName, $target_path )
|
||||||
|
{
|
||||||
|
$file_handle = fopen( $target_path . "/" . $fileName, "r" );
|
||||||
|
$result = array();
|
||||||
|
while ( !feof( $file_handle ) ) {
|
||||||
|
$line_of_text = fgets( $file_handle );
|
||||||
|
$parts = array_map( 'trim', explode( '=', $line_of_text, 2 ) );
|
||||||
|
@$result[$parts[0]] = $parts[1];
|
||||||
|
}
|
||||||
|
fclose( $file_handle );
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* function to check for updates or
|
||||||
|
* if the same plugin already exists
|
||||||
|
* also, if the update founds ,check for the update info in the .info file.
|
||||||
|
* Update is saved in the temp direcotry with pluginName_version.zip
|
||||||
|
*
|
||||||
|
* @param $fileName file which is uploaded in .zip extension
|
||||||
|
* @param $findPath where we have to look for the installed plugins
|
||||||
|
* @param $tempFile path for the temporary file
|
||||||
|
* @param $tempPath path where we have to store the update
|
||||||
|
* @return 2 if plugin already exists and update not found
|
||||||
|
* @return 3 if update info tag not found in .info file
|
||||||
|
*/
|
||||||
|
function checkForUpdate( $fileName, $findPath, $tempFile, $tempPath )
|
||||||
|
{
|
||||||
|
// check for plugin if exists
|
||||||
|
$file = scandir( $findPath );
|
||||||
|
foreach( $file as $key => $value )
|
||||||
|
{
|
||||||
|
if ( strcmp( $value, $fileName ) == 0 )
|
||||||
|
{
|
||||||
|
if ( !file_exists( $tempPath . "/test" ) )
|
||||||
|
{
|
||||||
|
mkdir( $tempPath . "/test" );
|
||||||
|
}
|
||||||
|
|
||||||
|
// extracting the update
|
||||||
|
if ( zipExtraction( $tempFile, $tempPath . "/test/" ) )
|
||||||
|
{
|
||||||
|
$result = readPluginFile( ".info", $tempPath . "/test/" . $fileName );
|
||||||
|
|
||||||
|
// check for the version for the plugin
|
||||||
|
$db = new DBLayer( "lib" );
|
||||||
|
$sth = $db -> select( "plugins", array( ':name' => $result['PluginName'] ), "Name = :name" );
|
||||||
|
$info = $sth -> fetch();
|
||||||
|
$info['Info'] = json_decode( $info['Info'] );
|
||||||
|
|
||||||
|
// the two versions from main plugin and the updated part
|
||||||
|
$new_version = explode( '.', $result['Version'] );
|
||||||
|
$pre_version = explode( '.', $info['Info'] -> Version );
|
||||||
|
|
||||||
|
// For all plugins we have used semantic versioning
|
||||||
|
// Format: X.Y.Z ,X->Major, Y->Minor, Z->Patch
|
||||||
|
// change in the X Y & Z values refer the type of change in the plugin.
|
||||||
|
// for initial development only Minor an Patch MUST be 0.
|
||||||
|
// if there is bug fix then there MUST be an increment in the Z value.
|
||||||
|
// if there is change in the functionality or addition of new functionality
|
||||||
|
// then there MUST be an increment in the Y value.
|
||||||
|
// When there is increment in the X value , Y and Z MUST be 0.
|
||||||
|
// comparing if there is some change
|
||||||
|
if ( !array_intersect( $new_version , $pre_version ) )
|
||||||
|
{
|
||||||
|
// removing the uploaded file
|
||||||
|
Plugincache :: rrmdir( $tempPath . "/test/" . $fileName );
|
||||||
|
return '2';
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check for update info if exists
|
||||||
|
if ( !array_key_exists( 'UpdateInfo', $result ) )
|
||||||
|
{
|
||||||
|
return '3'; //update info tag not found
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// check if update already exists
|
||||||
|
if ( pluginUpdateExists( $info['Id'], $tempPath . "/" . trim( $fileName, ".zip" ) . "_" . $result['Version'] . ".zip" ) )
|
||||||
|
{
|
||||||
|
echo "Update already exists";
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// removing the preivous update
|
||||||
|
$dbr = new DBLayer( "lib" );
|
||||||
|
$dbr -> delete( "updates", array( 'id' => $info['Id'] ), "PluginId=:id" );
|
||||||
|
// storing update in the temp directory
|
||||||
|
// format of update save
|
||||||
|
if ( move_uploaded_file( $tempFile, $tempPath . "/" . trim( $fileName, ".zip" ) . "_" . $result['Version'] . ".zip" ) ) {
|
||||||
|
// setting update information in the database
|
||||||
|
$update['PluginId'] = $info['Id'];
|
||||||
|
$update['UpdatePath'] = $tempPath . "/" . trim( $fileName, ".zip" ) . "_" . $result['Version'] . ".zip";
|
||||||
|
$update['UpdateInfo'] = json_encode( $result );
|
||||||
|
$dbr -> insert( "updates", $update );
|
||||||
|
header( "Location: index.php?page=plugins&result=7" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to check for the update of a plugin already exists
|
||||||
|
*
|
||||||
|
* @param $pluginId id of the plugin for which update is available
|
||||||
|
* @param $updatePath path of the new update
|
||||||
|
* @return boolean if update for a plugin already exists or
|
||||||
|
* if update of same version is uploading
|
||||||
|
*/
|
||||||
|
function PluginUpdateExists( $pluginId, $updatePath )
|
||||||
|
{
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$sth = $db -> selectWithParameter( "UpdatePath", "updates", array( 'pluginid' => $pluginId ), "PluginId=:pluginid" );
|
||||||
|
$row = $sth -> fetch();
|
||||||
|
if ( $updatePath == $row['UpdatePath'] )
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
rmdir( $row['UpdatePath'] );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This function is used in installing updates for plugins.
|
||||||
|
*
|
||||||
|
* @author Shubham Meena, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
function update_plugin() {
|
||||||
|
|
||||||
|
// if logged in
|
||||||
|
if ( WebUsers :: isLoggedIn() ) {
|
||||||
|
|
||||||
|
if ( isset( $_GET['id'] ) )
|
||||||
|
{
|
||||||
|
// id of plugin to delete
|
||||||
|
$id = filter_var( $_GET['id'], FILTER_SANITIZE_FULL_SPECIAL_CHARS );
|
||||||
|
$db = new DBLayer( 'lib' );
|
||||||
|
$sth = $db -> executeWithoutParams( "SELECT * FROM plugins INNER JOIN updates ON plugins.Id=updates.PluginId Where plugins.Id=$id" );
|
||||||
|
$row = $sth -> fetch();
|
||||||
|
|
||||||
|
// replacing update in the database
|
||||||
|
Plugincache :: rrmdir( $row['FileName'] );
|
||||||
|
Plugincache :: zipExtraction( $row['UpdatePath'], rtrim( $row['FileName'], strtolower( $row['Name'] ) ) );
|
||||||
|
|
||||||
|
$db -> update( "plugins", array( 'Info' => $row['UpdateInfo'] ), "Id=$row[Id]" );
|
||||||
|
|
||||||
|
// deleting the previous update
|
||||||
|
$db -> delete( "updates", array( 'id' => $row['s.no'] ), "s.no=:id" );
|
||||||
|
|
||||||
|
header( "Location: index.php?page=plugins&result=8" );
|
||||||
|
exit;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,45 +1,39 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* File with function plugins to get
|
* function plugins to get
|
||||||
* plugins from the Database using pagination object
|
* plugins from the Database using pagination object
|
||||||
* @author shubham meena mentored by Mathew Lagoe
|
*
|
||||||
|
* @author shubham meena mentored by Matthew Lagoe
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function plugins()
|
function plugins()
|
||||||
{
|
{
|
||||||
if(Ticket_User::isMod(unserialize($_SESSION['ticket_user']))){
|
if ( Ticket_User :: isMod( unserialize( $_SESSION['ticket_user'] ) ) ) {
|
||||||
|
|
||||||
/**require("../../ams_lib/plugins/plugin.handler.php");
|
$pagination = new Pagination( "SELECT * FROM plugins", "lib", 5, "Plugincache" );
|
||||||
|
$pageResult['plug'] = Gui_Elements :: make_table( $pagination -> getElements(), Array( "getId", "getPluginName", "getPluginType", "getPluginPermission", "getPluginStatus", "getPluginInfo" ), Array( "id", "plugin_name", "plugin_type", "plugin_permission", "plugin_status", "plugin_info" ) );
|
||||||
|
$pageResult['links'] = $pagination -> getLinks( 5 );
|
||||||
|
$pageResult['lastPage'] = $pagination -> getLast();
|
||||||
|
$pageResult['currentPage'] = $pagination -> getCurrent();
|
||||||
|
|
||||||
$plugin=new plugin();
|
global $INGAME_WEBPATH;
|
||||||
$plugin->init();
|
$pageResult['ingame_webpath'] = $INGAME_WEBPATH;
|
||||||
print_r(plugin::$plugins);**/
|
|
||||||
|
|
||||||
$pagination = new Pagination("SELECT * FROM plugins","lib",5,"Plugincache");
|
// check if shard is online
|
||||||
$pageResult['plug']= Gui_Elements::make_table($pagination->getElements() , Array ("getId","getPluginName","getPluginVersion","getPluginPermission","getIsActive"), Array("id","plugin_name","plugin_version","plugin_permission","plugin_isactive"));
|
try {
|
||||||
$pageResult['links'] = $pagination->getLinks(5);
|
$dbs = new DBLayer( "shard" );
|
||||||
$pageResult['lastPage'] = $pagination->getLast();
|
$pageResult['shard'] = "online";
|
||||||
$pageResult['currentPage'] = $pagination->getCurrent();
|
}
|
||||||
|
catch( PDOException $e ) {
|
||||||
global $INGAME_WEBPATH;
|
|
||||||
$pageResult['ingame_webpath'] = $INGAME_WEBPATH;
|
|
||||||
|
|
||||||
//check if shard is online
|
|
||||||
try{
|
|
||||||
$dbs = new DBLayer("shard");
|
|
||||||
$pageResult['shard'] = "online";
|
|
||||||
}catch(PDOException $e){
|
|
||||||
$pageResult['shard'] = "offline";
|
$pageResult['shard'] = "offline";
|
||||||
}
|
}
|
||||||
return( $pageResult);
|
return( $pageResult );
|
||||||
}else{
|
} else {
|
||||||
//ERROR: No access!
|
// ERROR: No access!
|
||||||
$_SESSION['error_code'] = "403";
|
$_SESSION['error_code'] = "403";
|
||||||
header("Location: index.php?page=error");
|
header( "Location: index.php?page=error" );
|
||||||
exit;
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* function plugins_update to get
|
||||||
|
* plugins updates from the Database using pagination object
|
||||||
|
*
|
||||||
|
* @author shubham meena mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
|
||||||
|
function plugins_update()
|
||||||
|
{
|
||||||
|
if ( Ticket_User :: isMod( unserialize( $_SESSION['ticket_user'] ) ) ) {
|
||||||
|
$pagination = new Pagination( "SELECT * FROM plugins INNER JOIN updates ON plugins.Id=updates.PluginId", "lib", 5, "Plugincache" );
|
||||||
|
$pageResult['plug'] = Gui_Elements :: make_table( $pagination -> getElements(), Array( "getId", "getPluginName", "getPluginInfo", "getUpdateInfo" ), Array( "id", "plugin_name", "plugin_info", "update_info" ) );
|
||||||
|
$pageResult['links'] = $pagination -> getLinks( 5 );
|
||||||
|
$pageResult['lastPage'] = $pagination -> getLast();
|
||||||
|
$pageResult['currentPage'] = $pagination -> getCurrent();
|
||||||
|
|
||||||
|
global $INGAME_WEBPATH;
|
||||||
|
$pageResult['ingame_webpath'] = $INGAME_WEBPATH;
|
||||||
|
|
||||||
|
// check if shard is online
|
||||||
|
try {
|
||||||
|
$dbs = new DBLayer( "shard" );
|
||||||
|
$pageResult['shard'] = "online";
|
||||||
|
}
|
||||||
|
catch( PDOException $e ) {
|
||||||
|
$pageResult['shard'] = "offline";
|
||||||
|
}
|
||||||
|
return( $pageResult );
|
||||||
|
} else {
|
||||||
|
// ERROR: No access!
|
||||||
|
$_SESSION['error_code'] = "403";
|
||||||
|
header( "Location: index.php?page=error" );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,126 +1,134 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Core that runs the entire system.
|
* Core that runs the entire system.
|
||||||
* The index.php page handles:
|
* The index.php page handles:
|
||||||
* -# checks what page to load
|
* -# checks what page to load
|
||||||
* -# if a $_POST['function'] is set try to execute that function in the matching php file located in the func folder.
|
* -# if a $_POST['function'] is set try to execute that function in the matching php file located in the func folder.
|
||||||
* -# else load the inc's folder matching function related to the page
|
* -# else load the inc's folder matching function related to the page
|
||||||
* -# set the permission and other smarty related settings
|
* -# set the permission and other smarty related settings
|
||||||
* -# call the helper function to load the page.
|
* -# call the helper function to load the page.
|
||||||
* @author Daan Janssens, mentored by Matthew Lagoe
|
*
|
||||||
*/
|
* @author Daan Janssens, mentored by Matthew Lagoe
|
||||||
|
*/
|
||||||
|
|
||||||
//load required pages and turn error reporting on/off
|
// load required pages and turn error reporting on/off
|
||||||
error_reporting(E_ALL);
|
error_reporting( E_ALL );
|
||||||
ini_set('display_errors', 'on');
|
ini_set( 'display_errors', 'on' );
|
||||||
require_once( '../../ams_lib/libinclude.php' );
|
if ( !file_exists( '../is_installed' ) ) {
|
||||||
if (!file_exists('../is_installed')) {
|
// if is_installed doesnt exist run setup
|
||||||
//if is_installed doesnt exist run setup
|
|
||||||
require( 'installer/libsetup.php' );
|
require( 'installer/libsetup.php' );
|
||||||
} elseif (isset($_POST["function"]) && $_POST["function"] == "do_install") {
|
} elseif ( isset( $_POST["function"] ) && $_POST["function"] == "do_install" ) {
|
||||||
echo "Can't run setup while file '../is_installed' exists, please remove that file if you wish to run the install";
|
echo "Can't run setup while file '../is_installed' exists, please remove that file if you wish to run the install";
|
||||||
exit;
|
exit;
|
||||||
} else {
|
} else {
|
||||||
//if config exists then include it
|
// if config exists then include it
|
||||||
require( '../config.php' );
|
require( '../config.php' );
|
||||||
}
|
}
|
||||||
|
require_once( $AMS_LIB . '/libinclude.php' );
|
||||||
session_start();
|
session_start();
|
||||||
|
|
||||||
//Running Cron?
|
// Running Cron
|
||||||
if ( isset( $_GET["cron"]) ){
|
if ( isset( $_GET["cron"] ) ) {
|
||||||
if ($_GET["cron"] == "true"){
|
if ( $_GET["cron"] == "true" ) {
|
||||||
Sync::syncdata(false);
|
Sync :: syncdata( false );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Always try to sync on page load, ie "lazy" cron
|
// Always try to sync on page load, ie "lazy" cron
|
||||||
Sync::syncdata(false);
|
Sync :: syncdata( false );
|
||||||
|
|
||||||
//Decide what page to load
|
// Decide what page to load
|
||||||
if ( ! isset( $_GET["page"]) ){
|
if ( ! isset( $_GET["page"] ) ) {
|
||||||
if(isset($_SESSION['user'])){
|
|
||||||
if(Ticket_User::isMod(unserialize($_SESSION['ticket_user']))){
|
|
||||||
$page = 'dashboard';
|
|
||||||
}else{
|
|
||||||
$page = 'show_user';
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
//default page
|
|
||||||
$page = 'login';
|
|
||||||
}
|
|
||||||
}else{
|
|
||||||
if(isset($_SESSION['user'])){
|
|
||||||
$page = $_GET["page"];
|
|
||||||
}else{
|
|
||||||
switch($_GET["page"]){
|
|
||||||
case 'register':
|
|
||||||
$page = 'register';
|
|
||||||
break;
|
|
||||||
case 'forgot_password':
|
|
||||||
$page = 'forgot_password';
|
|
||||||
break;
|
|
||||||
case 'reset_password':
|
|
||||||
$page = 'reset_password';
|
|
||||||
break;
|
|
||||||
case 'error':
|
|
||||||
$page = 'error';
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
$page = 'login';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//check if ingame & page= register
|
if ( isset( $_SESSION['user'] ) ) {
|
||||||
//this is needed because the ingame register can't send a hidden $_POST["function"]
|
if ( Ticket_User :: isMod( unserialize( $_SESSION['ticket_user'] ) ) ) {
|
||||||
if ( Helpers::check_if_game_client() && ($page == "register")){
|
$page = 'dashboard';
|
||||||
require( "func/add_user.php" );
|
} else {
|
||||||
|
$page = 'show_user';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// default page
|
||||||
|
$page = 'login';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if ( isset( $_SESSION['user'] ) ) {
|
||||||
|
$page = $_GET["page"];
|
||||||
|
} else {
|
||||||
|
switch ( $_GET["page"] ) {
|
||||||
|
case 'register':
|
||||||
|
$page = 'register';
|
||||||
|
break;
|
||||||
|
case 'forgot_password':
|
||||||
|
$page = 'forgot_password';
|
||||||
|
break;
|
||||||
|
case 'reset_password':
|
||||||
|
$page = 'reset_password';
|
||||||
|
break;
|
||||||
|
case 'error':
|
||||||
|
$page = 'error';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$page = 'login';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// check if ingame & page= register
|
||||||
|
// this is needed because the ingame register can't send a hidden $_POST["function"]
|
||||||
|
if ( Helpers :: check_if_game_client() && ( $page == "register" ) ) {
|
||||||
|
require( "func/add_user.php" );
|
||||||
$return = add_user();
|
$return = add_user();
|
||||||
}
|
}
|
||||||
|
|
||||||
//perform an action in case one is specified
|
// perform an action in case one is specified
|
||||||
//else check if a php page is included in the inc folder, else just set page to the get param
|
// else check if a php page is included in the inc folder, else just set page to the get param
|
||||||
if ( isset( $_POST["function"] ) ){
|
if ( isset( $_POST["function"] ) ) {
|
||||||
require( "func/" . $_POST["function"] . ".php" );
|
require( "func/" . $_POST["function"] . ".php" );
|
||||||
$return = $_POST["function"]();
|
$return = $_POST["function"]();
|
||||||
}else{
|
} else if ( isset( $_GET["action"] ) ) {
|
||||||
$filename = 'inc/' . $page . '.php';
|
require( "func/" . $_GET["action"] . ".php" );
|
||||||
if(is_file($filename)){
|
$return = $_GET["action"]();
|
||||||
require_once($filename);
|
} else {
|
||||||
$return = $page();
|
$filename = 'inc/' . $page . '.php';
|
||||||
|
if ( is_file( $filename ) ) {
|
||||||
|
require_once( $filename );
|
||||||
|
$return = $page();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// add username to the return array in case logged in.
|
||||||
|
if ( isset( $_SESSION['user'] ) ) {
|
||||||
|
$return['username'] = $_SESSION['user'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set permission
|
||||||
|
if ( isset( $_SESSION['ticket_user'] ) ) {
|
||||||
|
$return['permission'] = unserialize( $_SESSION['ticket_user'] ) -> getPermission();
|
||||||
|
} else {
|
||||||
|
// default permission
|
||||||
|
$return['permission'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// hide sidebar + topbar in case of login/register
|
||||||
|
if ( $page == 'login' || $page == 'register' || $page == 'logout' || $page == 'forgot_password' || $page == 'reset_password' ) {
|
||||||
|
$return['no_visible_elements'] = 'TRUE';
|
||||||
|
} else {
|
||||||
|
$return['no_visible_elements'] = 'FALSE';
|
||||||
|
}
|
||||||
|
|
||||||
|
// handle error page
|
||||||
|
if ( $page == 'error' ) {
|
||||||
|
$return['permission'] = 0;
|
||||||
|
$return['no_visible_elements'] = 'FALSE';
|
||||||
|
}
|
||||||
|
|
||||||
|
// call to load hooks for the active plugins
|
||||||
|
$hook_content = Plugincache :: loadHooks();
|
||||||
|
foreach( $hook_content as $key => $value )
|
||||||
|
{
|
||||||
|
$return[$key] = $value;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//add username to the return array in case logged in.
|
// load the template with the variables in the $return array
|
||||||
if(isset($_SESSION['user'])){
|
|
||||||
$return['username'] = $_SESSION['user'];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//Set permission
|
|
||||||
if(isset($_SESSION['ticket_user'])){
|
|
||||||
$return['permission'] = unserialize($_SESSION['ticket_user'])->getPermission();
|
|
||||||
}else{
|
|
||||||
//default permission
|
|
||||||
$return['permission'] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//hide sidebar + topbar in case of login/register
|
|
||||||
if($page == 'login' || $page == 'register' || $page == 'logout' || $page == 'forgot_password' || $page == 'reset_password'){
|
|
||||||
$return['no_visible_elements'] = 'TRUE';
|
|
||||||
}else{
|
|
||||||
$return['no_visible_elements'] = 'FALSE';
|
|
||||||
}
|
|
||||||
|
|
||||||
//handle error page
|
|
||||||
if($page == 'error'){
|
|
||||||
$return['permission'] = 0;
|
|
||||||
$return['no_visible_elements'] = 'FALSE';
|
|
||||||
}
|
|
||||||
|
|
||||||
//load the template with the variables in the $return array
|
|
||||||
helpers :: loadTemplate( $page , $return );
|
helpers :: loadTemplate( $page , $return );
|
||||||
|
|
|
@ -160,14 +160,38 @@
|
||||||
DROP TABLE IF EXISTS `" . $cfg['db']['lib']['name'] ."`.`plugins` ;
|
DROP TABLE IF EXISTS `" . $cfg['db']['lib']['name'] ."`.`plugins` ;
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS `" . $cfg['db']['lib']['name'] ."`.`plugins` (
|
CREATE TABLE IF NOT EXISTS `" . $cfg['db']['lib']['name'] ."`.`plugins` (
|
||||||
`PluginId` INT(10) NOT NULL AUTO_INCREMENT,
|
`Id` INT(10) NOT NULL AUTO_INCREMENT,
|
||||||
`PluginName` VARCHAR(11) NOT NULL,
|
`FileName VARCHAR(255) NOT NULL,
|
||||||
`PluginPermission` VARCHAR(5) NOT NULL,
|
`Name` VARCHAR(11) NOT NULL,
|
||||||
`PluginVersion` INT(11) NOT NULL,
|
`Type` VARCHAR(12) NOT NULL,
|
||||||
`IsActive` TINYINT(1) NOT NULL,
|
`Owner` VARCHAR(25) NOT NULL,
|
||||||
PRIMARY KEY (`PluginId`) )
|
`Permission` VARCHAR(5) NOT NULL,
|
||||||
|
`Status` INT(11) NOT NULL DEFAULT 0,
|
||||||
|
`Weight` INT(11) NOT NULL DEFAULT 0,
|
||||||
|
`Info` TEXT NULL DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`Id`) )
|
||||||
ENGINE = InnoDB;
|
ENGINE = InnoDB;
|
||||||
|
|
||||||
|
-- -----------------------------------------------------
|
||||||
|
-- Table `" . $cfg['db']['lib']['name'] ."`.`updates`
|
||||||
|
-- -----------------------------------------------------
|
||||||
|
DROP TABLE IF EXISTS `" . $cfg['db']['lib']['name'] ."`.`updates` ;
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `" . $cfg['db']['lib']['name'] ."`.`updates` (
|
||||||
|
`s.no` int(10) NOT NULL AUTO_INCREMENT,
|
||||||
|
`PluginId` int(10) DEFAULT NULL,
|
||||||
|
`UpdatePath` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
|
||||||
|
`UpdateInfo` text COLLATE utf8_unicode_ci,
|
||||||
|
PRIMARY KEY (`s.no`),
|
||||||
|
KEY `PluginId` (`PluginId`))
|
||||||
|
ENGINE=InnoDB;
|
||||||
|
|
||||||
|
-- -----------------------------------------
|
||||||
|
-- Constraints for table `updates`
|
||||||
|
-- -----------------------------------------
|
||||||
|
ALTER TABLE `" . $cfg['db']['lib']['name'] ."`.`updates`
|
||||||
|
ADD CONSTRAINT `updates_ibfk_1` FOREIGN KEY (`PluginId`) REFERENCES `plugins` (`Id`);
|
||||||
|
|
||||||
|
|
||||||
-- -----------------------------------------------------
|
-- -----------------------------------------------------
|
||||||
-- Table `" . $cfg['db']['lib']['name'] ."`.`ticket`
|
-- Table `" . $cfg['db']['lib']['name'] ."`.`ticket`
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
{block name=content}
|
||||||
|
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="box span12">
|
||||||
|
<div class="box-header well">
|
||||||
|
<h2><i class="icon-info-sign"></i>{$ip_title}</h2>
|
||||||
|
<div class="box-icon">
|
||||||
|
<a href="#" class="btn btn-round" onclick="javascript:show_help('intro');return false;"><i class="icon-info-sign"></i></a>
|
||||||
|
<a href="#" class="btn btn-setting btn-round"><i class="icon-cog"></i></a>
|
||||||
|
<a href="#" class="btn btn-minimize btn-round"><i class="icon-chevron-up"></i></a>
|
||||||
|
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="box-content">
|
||||||
|
<center>
|
||||||
|
<p>{$ip_support}</p>
|
||||||
|
<div class="alert alert-error">
|
||||||
|
<form enctype="multipart/form-data" method="post" action="index.php?page=plugin&action=install_plugin" id="upload_plugin" >
|
||||||
|
<label for="file">Filename:</label>
|
||||||
|
<input type="file" name="file" id="file"></br>
|
||||||
|
<progress id="progressBar" value="0" max="100" style="width:300px;"></progress></br>
|
||||||
|
<input type="button" value="Upload" onclick="uploadPlugin()"></br>
|
||||||
|
<h3 id="status"></h3>
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "0"}<p>{$ip_file_nfnd}</p>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "2"}<p>{$ip_info_nfound}</p>{/if}
|
||||||
|
</div>
|
||||||
|
{$ip_message}
|
||||||
|
</center>
|
||||||
|
<div class="clearfix"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div><!--/span-->
|
||||||
|
|
||||||
|
</div><!--/row-->
|
||||||
|
{/block}
|
|
@ -192,6 +192,50 @@
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<!-- script for file uploading-->
|
||||||
|
<script>
|
||||||
|
function _(e1)
|
||||||
|
{
|
||||||
|
return document.getElementById(e1);
|
||||||
|
}
|
||||||
|
|
||||||
|
function uploadPlugin()
|
||||||
|
{
|
||||||
|
var fileObject = _("file").files[0];
|
||||||
|
var formdata = new FormData();
|
||||||
|
formdata.append("file",fileObject);
|
||||||
|
var ajax = new XMLHttpRequest();
|
||||||
|
ajax.upload.addEventListener("progress", progressHandler, false);
|
||||||
|
ajax.addEventListener("load", completeHandler, false);
|
||||||
|
ajax.addEventListener("error", errorHandler, false);
|
||||||
|
ajax.addEventListener("abort", abortHandler, false);
|
||||||
|
ajax.open("POST", "index.php?page=plugin&action=install_plugin");
|
||||||
|
ajax.send(formdata);
|
||||||
|
}
|
||||||
|
|
||||||
|
function progressHandler(event)
|
||||||
|
{
|
||||||
|
var percent = (event.loaded/event.total)*100;
|
||||||
|
_("progressBar").value = Math.round(percent);
|
||||||
|
}
|
||||||
|
|
||||||
|
function completeHandler(event)
|
||||||
|
{
|
||||||
|
_("status").innerHTML = event.target.responseText;
|
||||||
|
_("progressBar").value = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
function errorHandler(event)
|
||||||
|
{
|
||||||
|
_("status").innerHTML = "upload Failed";
|
||||||
|
}
|
||||||
|
|
||||||
|
function abortHandler(event)
|
||||||
|
{
|
||||||
|
_("status").innerHTML = "upload Aborted";
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
<!-- jQuery -->
|
<!-- jQuery -->
|
||||||
<script src="js/jquery-1.7.2.min.js"></script>
|
<script src="js/jquery-1.7.2.min.js"></script>
|
||||||
<!-- jQuery UI -->
|
<!-- jQuery UI -->
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=show_queue&get=todo"><i class="icon-th-list"></i><span class="hidden-tablet"> Queues</span></a></li>
|
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=show_queue&get=todo"><i class="icon-th-list"></i><span class="hidden-tablet"> Queues</span></a></li>
|
||||||
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=sgroup_list"><i class="icon-briefcase"></i><span class="hidden-tablet"> Support Groups</span></a></li>
|
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=sgroup_list"><i class="icon-briefcase"></i><span class="hidden-tablet"> Support Groups</span></a></li>
|
||||||
<li class="nav-header hidden-tablet">Actions</li>
|
<li class="nav-header hidden-tablet">Actions</li>
|
||||||
|
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=plugins"><i class="icon-th-list"></i><span class="hidden-tablet"> Plugins</span></a></li>
|
||||||
|
{if isset($hook_info)} {foreach from=$hook_info item=element}<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=layout_plugin&&name={$element.menu_display}"><i class="icon-th-list"></i><span class="hidden-tablet"> {$element.menu_display}</span></a></li>{/foreach}{/if}
|
||||||
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=syncing"><i class="icon-th-list"></i><span class="hidden-tablet"> Syncing</span></a></li>
|
<li style="margin-left: -2px;"><a class="ajax-link" href="index.php?page=syncing"><i class="icon-th-list"></i><span class="hidden-tablet"> Syncing</span></a></li>
|
||||||
<li style="margin-left: -2px;"><a href="?page=logout"><i class="icon-off"></i><span class="hidden-tablet"> Logout </span></a></li>
|
<li style="margin-left: -2px;"><a href="?page=logout"><i class="icon-off"></i><span class="hidden-tablet"> Logout </span></a></li>
|
||||||
{/block}
|
{/block}
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
{block name=content}
|
||||||
|
<div class="row-fluid">
|
||||||
|
{if isset($hook_info)}
|
||||||
|
{foreach from=$hook_info item=element}
|
||||||
|
{if $element.menu_display eq $smarty.get.name}
|
||||||
|
{include file=$element.template_path}
|
||||||
|
{/if}
|
||||||
|
{/foreach}
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
{/block}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
{block name=content}
|
{block name=content}
|
||||||
<div class="row-fluid">
|
<div class="row-fluid">
|
||||||
<div class="box span12">
|
<div class="box span12">
|
||||||
|
@ -10,27 +9,45 @@
|
||||||
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
|
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "1"}<div class="alert alert-error"><p>{$ip_success}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "0"}<div class="alert alert-error"><p>{$dp_error}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "2"}<div class="alert alert-error"><p>{$dp_success}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "3"}<div class="alert alert-error"><p>{$ac_success}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "4"}<div class="alert alert-error"><p>{$ac_error}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "5"}<div class="alert alert-error"><p>{$dc_success}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "6"}<div class="alert alert-error"><p>{$dc_error}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "7"}<div class="alert alert-error"><p>{$up_success}</p></div>{/if}
|
||||||
|
{if isset($smarty.get.result) and $smarty.get.result eq "8"}<div class="alert alert-error"><p>{$up_install_success}</p></div>{/if}
|
||||||
<div class="box-content">
|
<div class="box-content">
|
||||||
<center><p>{$plugin_info}</p></center>
|
<center><p>{$plugin_info}</p></center>
|
||||||
|
<center>
|
||||||
|
<a href="index.php?page=install_plugin"><button class="btn btn-primary btn-large dropdown-toggle">Install New Plugin</button></a>
|
||||||
|
<a href="index.php?page=plugins_update"><button class="btn btn-primary btn-large dropdown-toggle">Check for updates</button></a>
|
||||||
|
</center>
|
||||||
<table class="table table-striped table-bordered">
|
<table class="table table-striped table-bordered">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>{$plugin_id}</th>
|
<th>{$plugin_status}</th>
|
||||||
<th>{$plugin_permission}</th>
|
<th width="100">{$plugin_name}</th>
|
||||||
<th>{$plugin_name}</th>
|
|
||||||
<th>{$plugin_version}</th>
|
<th>{$plugin_version}</th>
|
||||||
<th>{$plugin_is_active}</th>
|
<th width="350">{$plugin_description}</th>
|
||||||
|
<th width="80">{$plugin_type}</th>
|
||||||
|
<th>{$plugin_permission}</th>
|
||||||
|
<th>{$plugin_actions}</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{foreach from=$plug item=element}
|
{foreach from=$plug item=element}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{$element.id}</td>
|
<td><input type="checkbox" name ="{$element.id}"{if ($element.plugin_status) eq "1"}checked{/if}/></td>
|
||||||
<td class="center">{$element.plugin_permission}</td>
|
|
||||||
<td class="center">{$element.plugin_name}</td>
|
<td class="center">{$element.plugin_name}</td>
|
||||||
<td class="center">{$element.plugin_version}</td>
|
<td class="center">{$element.plugin_info->Version}</td>
|
||||||
<td class="center">{$element.plugin_isactive}</td>
|
<td class="center">{$element.plugin_info->Description}</td>
|
||||||
|
<td class="center">{$element.plugin_type}</td>
|
||||||
|
<td class="center">{$element.plugin_permission}</td>
|
||||||
|
<td><a href="index.php?page=plugins&action=delete_plugin&id={$element.id}"><button class="btn btn-primary btn-large">Delete</button></a>
|
||||||
|
{if ($element.plugin_status) eq "0"}<a href="index.php?page=plugins&action=activate_plugin&id={$element.id}"><button class="btn btn-primary btn-large dropdown-toggle">Activate</button></a>{/if}
|
||||||
|
{if ($element.plugin_status) eq "1"}<a href="index.php?page=plugins&action=deactivate_plugin&id={$element.id}"><button class="btn btn-primary btn-large dropdown-toggle">Deactivate</button></a>{/if}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{/foreach}
|
{/foreach}
|
||||||
|
|
||||||
|
@ -48,42 +65,5 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div><!--/span-->
|
</div><!--/span-->
|
||||||
<div class="box span3">
|
|
||||||
<div class="box-header well" data-original-title="">
|
|
||||||
<h2><i class="icon-th"></i>Actions</h2>
|
|
||||||
<div class="box-icon">
|
|
||||||
<a href="#" class="btn btn-minimize btn-round"><i class="icon-chevron-up"></i></a>
|
|
||||||
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="box-content">
|
|
||||||
<div class="row-fluid">
|
|
||||||
<div class="btn-group">
|
|
||||||
<button class="btn btn-primary btn-large dropdown-toggle" data-toggle="dropdown">Actions<span class="caret"></span></button>
|
|
||||||
<ul class="dropdown-menu">
|
|
||||||
<li class="divider"></li>
|
|
||||||
<li><a href="">Edit Plugins</a></li>
|
|
||||||
<li><a href="">Add Plugin</a></li>
|
|
||||||
<li class="divider"></li>
|
|
||||||
{if isset($isAdmin) and $isAdmin eq 'TRUE' and $target_id neq 1}
|
|
||||||
{if $userPermission eq 1}
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=2">Make Moderator</a></li>
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=3">Make Admin</a></li>
|
|
||||||
{else if $userPermission eq 2 }
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=1">Demote to User</a></li>
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=3">Make Admin</a></li>
|
|
||||||
{else if $userPermission eq 3 }
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=1">Demote to User</a></li>
|
|
||||||
<li><a href="index.php?page=change_permission&user_id={$target_id}&value=2">Demote to Moderator</a></li>
|
|
||||||
{/if}
|
|
||||||
<li class="divider"></li>
|
|
||||||
{/if}
|
|
||||||
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div><!--/span-->
|
|
||||||
|
|
||||||
</div><!--/row-->
|
</div><!--/row-->
|
||||||
{/block}
|
{/block}
|
|
@ -0,0 +1,50 @@
|
||||||
|
{block name=content}
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="box span12">
|
||||||
|
<div class="box-header well" data-original-title>
|
||||||
|
<h2><i class="icon-user"></i> {$up_title}</h2>
|
||||||
|
<div class="box-icon">
|
||||||
|
<a href="#" class="btn btn-setting btn-round"><i class="icon-cog"></i></a>
|
||||||
|
<a href="#" class="btn btn-minimize btn-round"><i class="icon-chevron-up"></i></a>
|
||||||
|
<a href="#" class="btn btn-close btn-round"><i class="icon-remove"></i></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="box-content">
|
||||||
|
<center><p>{$up_info}</p></center>
|
||||||
|
<table class="table table-striped table-bordered">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th width="100">{$plugin_name}</th>
|
||||||
|
<th>{$plugin_version}</th>
|
||||||
|
<th>{$up_updated_version}</th>
|
||||||
|
<th width="500">{$up_description}</th>
|
||||||
|
<th>{$up_actions}</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{foreach from=$plug item=element}
|
||||||
|
<tr>
|
||||||
|
<td class="center">{$element.plugin_name}</td>
|
||||||
|
<td class="center">{$element.plugin_info->Version}</td>
|
||||||
|
<td class="center">{$element.update_info->Version}</td>
|
||||||
|
<td class="center">{$element.update_info->UpdateInfo}</td>
|
||||||
|
<td><a href="index.php?page=plugins&action=update_plugins&id={$element.id}"><button class="btn btn-primary btn-large">Update</button></a>
|
||||||
|
</tr>
|
||||||
|
{/foreach}
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<div style="width: 300px; margin:0px auto;">
|
||||||
|
<ul class="pagination">
|
||||||
|
<li><a href="index.php?page=plugins&pagenum=1">«</a></li>
|
||||||
|
{foreach from=$links item=link}
|
||||||
|
<li {if $link == $currentPage}class="active"{/if}><a href="index.php?page=plugins&pagenum={$link}">{$link}</a></li>
|
||||||
|
{/foreach}
|
||||||
|
<li><a href="index.php?page=plugins&pagenum={$lastPage}">»</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div><!--/span-->
|
||||||
|
</div><!--/row-->
|
||||||
|
{/block}
|
Loading…
Reference in a new issue