| GNU Affero General Public License or the licensing of CiviCRM, |
| see the CiviCRM license FAQ at http://civicrm.org/licensing |
+--------------------------------------------------------------------+
-*/
+ */
/**
*
* @return string
* HTML. For non-HTML content, invoke() may call print() and exit().
*
- * @static
*/
public static function invoke($args) {
try {
*/
public static function _invoke($args) {
if ($args[0] !== 'civicrm') {
- return;
+ return NULL;
+ }
+ // CRM-15901: Turn off PHP errors display for all ajax calls
+ if (CRM_Utils_Array::value(1, $args) == 'ajax' || CRM_Utils_Array::value('snippet', $_REQUEST)) {
+ ini_set('display_errors', 0);
}
if (!defined('CIVICRM_SYMFONY_PATH')) {
self::hackStandalone($args);
$item = self::getItem($args);
return self::runItem($item);
- } else {
+ }
+ else {
// Symfony-based invocation path
require_once CIVICRM_SYMFONY_PATH . '/app/bootstrap.php.cache';
require_once CIVICRM_SYMFONY_PATH . '/app/AppKernel.php';
- $kernel = new AppKernel('dev', true);
+ $kernel = new AppKernel('dev', TRUE);
$kernel->loadClassCache();
$response = $kernel->handle(Symfony\Component\HttpFoundation\Request::createFromGlobals());
if (preg_match(':^text/html:', $response->headers->get('Content-Type'))) {
// let the CMS handle the trappings
return $response->getContent();
- } else {
+ }
+ else {
$response->send();
exit();
}
}
}
+
/**
* Hackish support /civicrm/menu/rebuild
*
* @void
*/
static public function hackMenuRebuild($args) {
- if (array('civicrm','menu','rebuild') == $args || array('civicrm', 'clearcache') == $args) {
+ if (array('civicrm', 'menu', 'rebuild') == $args || array('civicrm', 'clearcache') == $args) {
// ensure that the user has a good privilege level
if (CRM_Core_Permission::check('administer CiviCRM')) {
self::rebuildMenuAndCaches();
}
/**
- * Perform general setup
+ * Perform general setup.
*
* @param array $args
* List of path parts.
if (is_array($args)) {
// get the menu items
$path = implode('/', $args);
- } else {
+ }
+ else {
$path = $args;
}
$item = CRM_Core_Menu::get($path);
if ($item) {
// CRM-7656 - make sure we send a clean sanitized path to create printer friendly url
$printerFriendly = CRM_Utils_System::makeURL(
- 'snippet', FALSE, FALSE,
- CRM_Utils_Array::value('path', $item)
- ) . '2';
+ 'snippet', FALSE, FALSE,
+ CRM_Utils_Array::value('path', $item)
+ ) . '2';
$template->assign('printerFriendly', $printerFriendly);
if (!array_key_exists('page_callback', $item)) {
// check that we are permissioned to access this page
if (!CRM_Core_Permission::checkMenuItem($item)) {
CRM_Utils_System::permissionDenied();
- return;
+ return NULL;
}
// check if ssl is set
}
$result = NULL;
- if (is_array($item['page_callback'])) {
- require_once (str_replace('_', DIRECTORY_SEPARATOR, $item['page_callback'][0]) . '.php');
- $result = call_user_func($item['page_callback']);
+ // WISHLIST: Refactor this. Instead of pattern-matching on page_callback, lookup
+ // page_callback via Civi\Core\Resolver and check the implemented interfaces. This
+ // would require rethinking the default constructor.
+ if (is_array($item['page_callback']) || strpos($item['page_callback'], ':')) {
+ $result = call_user_func(Civi\Core\Resolver::singleton()->get($item['page_callback']));
}
elseif (strstr($item['page_callback'], '_Form')) {
$wrapper = new CRM_Utils_Wrapper();
}
else {
$newArgs = explode('/', $_GET[$config->userFrameworkURLVar]);
- require_once (str_replace('_', DIRECTORY_SEPARATOR, $item['page_callback']) . '.php');
$mode = 'null';
if (isset($pageArgs['mode'])) {
$mode = $pageArgs['mode'];
unset($pageArgs['mode']);
}
$title = CRM_Utils_Array::value('title', $item);
- if (strstr($item['page_callback'], '_Page')) {
- $object = new $item['page_callback'] ($title, $mode );
+ if (strstr($item['page_callback'], '_Page') || strstr($item['page_callback'], '\\Page\\')) {
+ $object = new $item['page_callback']($title, $mode);
$object->urlPath = explode('/', $_GET[$config->userFrameworkURLVar]);
}
- elseif (strstr($item['page_callback'], '_Controller')) {
+ elseif (strstr($item['page_callback'], '_Controller') || strstr($item['page_callback'], '\\Controller\\')) {
$addSequence = 'false';
if (isset($pageArgs['addSequence'])) {
$addSequence = $pageArgs['addSequence'];
$addSequence = $addSequence ? 'true' : 'false';
unset($pageArgs['addSequence']);
}
- $object = new $item['page_callback'] ($title, true, $mode, null, $addSequence );
+ $object = new $item['page_callback']($title, TRUE, $mode, NULL, $addSequence);
}
else {
CRM_Core_Error::fatal();
}
/**
- * This function contains the default action
+ * This function contains the default action.
*
* @param $action
*
* @param $contact_type
* @param $contact_sub_type
*
- * @static
*/
public static function form($action, $contact_type, $contact_sub_type) {
CRM_Utils_System::setUserContext(array('civicrm/contact/search/basic', 'civicrm/contact/view'));
}
/**
- * Show the message about CiviCRM versions
+ * Show the message about CiviCRM versions.
*
* @param CRM_Core_Smarty $template
*/
CRM_Core_DAO_AllCoreTables::reinitializeCache(TRUE);
CRM_Core_ManagedEntities::singleton(TRUE)->reconcile();
}
+
}