mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-21 13:29:01 +01:00
allow api as app like home for everyone, and implement calling of namespaced class-names from EGroupware namespace in index.php and json.php
This commit is contained in:
parent
d8514e47b9
commit
3453021a6d
26
index.php
26
index.php
@ -34,10 +34,20 @@ if(isset($_GET['hasupdates']) && $_GET['hasupdates'] == 'yes')
|
||||
/*
|
||||
This is the menuaction driver for the multi-layered design
|
||||
*/
|
||||
if(isset($_GET['menuaction']) && preg_match('/^[A-Za-z0-9_]+\.[A-Za-z0-9_]+\.[A-Za-z0-9_]+$/',$_GET['menuaction']))
|
||||
if(isset($_GET['menuaction']) && preg_match('/^[A-Za-z0-9_]+\.[A-Za-z0-9_\\\\]+\.[A-Za-z0-9_]+$/',$_GET['menuaction']))
|
||||
{
|
||||
list($app,$class,$method) = explode('.',$_GET['menuaction']);
|
||||
if(! $app || ! $class || ! $method)
|
||||
|
||||
// check if autoloadable class belongs to given app
|
||||
if (substr($class, 0, 11) == 'EGroupware\\')
|
||||
{
|
||||
list(,$app_from_class) = explode('\\', strtolower($class));
|
||||
}
|
||||
elseif(strpos($class, '_') !== false)
|
||||
{
|
||||
list($app_from_class) = explode('_', $class);
|
||||
}
|
||||
if(!$app || !$class || !$method || isset($app_from_class) && $app_from_class != $app)
|
||||
{
|
||||
$invalid_data = True;
|
||||
}
|
||||
@ -62,9 +72,6 @@ $GLOBALS['egw_info'] = array(
|
||||
)
|
||||
);
|
||||
include('./header.inc.php');
|
||||
// check if users are supposed to change their password every x sdays, then check if password is of old age or the devil-admin reset the users password
|
||||
// and forced the user to change his password on next login.
|
||||
auth::check_password_age($app,$class,$method);
|
||||
|
||||
// user changed timezone
|
||||
if (isset($_GET['tz']))
|
||||
@ -130,7 +137,14 @@ else
|
||||
$app = 'phpgwapi';
|
||||
}
|
||||
|
||||
$obj = CreateObject($app.'.'.$class);
|
||||
if (class_exists($class))
|
||||
{
|
||||
$obj = new $class;
|
||||
}
|
||||
else
|
||||
{
|
||||
$obj = CreateObject($app.'.'.$class);
|
||||
}
|
||||
if((is_array($obj->public_functions) && $obj->public_functions[$method]) && !$invalid_data)
|
||||
{
|
||||
$obj->$method();
|
||||
|
10
json.php
10
json.php
@ -71,7 +71,15 @@ if (isset($_GET['menuaction']))
|
||||
if (strpos($_GET['menuaction'],'::') !== false && strpos($_GET['menuaction'],'.') === false) // static method name app_something::method
|
||||
{
|
||||
@list($className,$functionName,$handler) = explode('::',$_GET['menuaction']);
|
||||
list($appName) = explode('_',$className);
|
||||
|
||||
if (substr($className, 0, 11) == 'EGroupware\\')
|
||||
{
|
||||
list(,$appName) = explode('\\', strtolower($className));
|
||||
}
|
||||
else
|
||||
{
|
||||
list($appName) = explode('_',$className);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -350,7 +350,7 @@ class egw extends egw_minimal
|
||||
{
|
||||
$this->currentapp = $GLOBALS['egw_info']['flags']['currentapp']; // some apps change it later
|
||||
|
||||
if ($GLOBALS['egw_info']['flags']['currentapp'] != 'home') // give everyone implicit home rights
|
||||
if (!in_array($GLOBALS['egw_info']['flags']['currentapp'], array('api', 'home'))) // give everyone implicit home rights
|
||||
{
|
||||
// This will need to use ACL in the future
|
||||
if (!$GLOBALS['egw_info']['user']['apps'][$currentapp = $GLOBALS['egw_info']['flags']['currentapp']] ||
|
||||
|
@ -985,7 +985,7 @@ function get_var($variable,$method='any',$default_value='')
|
||||
* @param $p1,$p2,... class parameters (all optional)
|
||||
* @return object reference to an object
|
||||
*/
|
||||
function &CreateObject($class)
|
||||
function CreateObject($class)
|
||||
{
|
||||
list($appname,$classname) = explode('.',$class);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user