/** * Initialize testing environment * * @return void */ public static function init() { if (is_file(__DIR__ . '/config/.env')) { Dotenv::load(['filepath' => __DIR__ . '/config/.env', 'toEnv' => true]); } // Define application environment if (!isset($_ENV['WELLCART_APPLICATION_ENV'])) { $_ENV['WELLCART_APPLICATION_ENV'] = getenv('WELLCART_APPLICATION_ENV') ?: 'testing'; } // Load the user-defined test configuration file, if it exists; otherwise, load if (is_readable(__DIR__ . '/config/application.config.php')) { $testConfig = __DIR__ . '/config/application.config.php'; } else { $testConfig = __DIR__ . '/config/application.config.php.dist'; } static::initAutoloader(); defined('WELLCART_ROOT') || define('WELLCART_ROOT', getenv('WELLCART_ROOT') ? getenv('WELLCART_ROOT') : str_replace('\\', '/', __DIR__) . '/'); defined('WELLCART_BIN_PATH') || define('WELLCART_BIN_PATH', getenv('WELLCART_BIN_PATH') ? getenv('WELLCART_BIN_PATH') : static::findParentPath('bin')); defined('WELLCART_PUBLIC_PATH') || define('WELLCART_PUBLIC_PATH', static::findParentPath('public')); // Define application context if (!is_file(WELLCART_ROOT . 'config/autoload/installed.php')) { $_ENV['WELLCART_APPLICATION_CONTEXT'] = Application::CONTEXT_SETUP; } elseif (empty($_ENV['WELLCART_APPLICATION_CONTEXT'])) { $_ENV['WELLCART_APPLICATION_CONTEXT'] = Application::CONTEXT_GLOBAL; } /** * Setup initial PHP environment */ PHPEnvironment::initialize(); $app = Application::init(Config::application(include $testConfig)); application($app); }
public static function handleOnAfterInit() { // only allow GET requests if ($_SERVER['REQUEST_METHOD'] != 'GET' || defined('USE_FLASH') && (flash_get('success') != NULL || flash_get('error') != NULL)) { return; } $etagEnabled = ConfigOptions::getValue('three_o_four_etag_enabled'); $cacheEnabled = ConfigOptions::getValue('three_o_four_response_cache_enabled'); $engineEnabled = $etagEnabled || $cacheEnabled; if (!$engineEnabled) { return; } $request = self::_getRequest(); $request->three_o_four_emit_etag = $etagEnabled; if ($cacheEnabled && isset(self::$_routeMap[$request->matched_route])) { $cacheOpts = self::$_routeMap[$request->matched_route]; //$request->three_o_four_cache_response = self::_isCacheableRequest($request); $request->three_o_four_cache_response = true; $request->three_o_four_cache_opts = $cacheOpts; if (($cacheData = self::_getFromCache($request)) !== NULL) { // if the user has no view permissions, continue request as usual to output the standard 403 if (self::_checkPermissions($cacheData, $request)) { self::_sendResponse($cacheData['content'], $cacheData['contentLength'], $cacheData['etag'], $cacheData['headers']); exit; } } } $application = application(); $application->events_manager->listen('on_shutdown', 'onShutdown', THREE_O_FOUR_MODULE); ob_start(); $request->three_o_four_buffering_started = true; }
/** * Call application shutdown function on shutdown * * @param void * @return null */ function angie_shutdown() { $application =& application(); if (instance_of($application, 'AngieApplication')) { $application->shutdown(); } // if }
/** * Constructor * * @param Request $request * @return ApplicationController */ function __construct($request) { parent::__construct($request); // Set detault layout for application pages $this->setLayout(array('module' => SYSTEM_MODULE, 'layout' => 'wireframe')); // Get Smarty instance... We need it $this->smarty =& Smarty::instance(); // Load and init owner company $this->owner_company = get_owner_company(); if (instance_of($this->owner_company, 'Company')) { cache_set('owner_company', $this->owner_company); } else { $this->httpError(HTTP_ERR_NOT_FOUND, 'Owner company is not defined'); } // if $this->application =& application(); $this->authentication =& Authentication::instance(); $this->logged_user =& $this->authentication->provider->getUser(); $this->wireframe =& Wireframe::instance(); $this->wireframe->page_company = $this->owner_company; $this->theme_name = instance_of($this->logged_user, 'User') ? UserConfigOptions::getValue('theme', $this->logged_user) : ConfigOptions::getValue('theme'); $this->smarty->assign(array('root_url' => ROOT_URL, 'assets_url' => ASSETS_URL)); // Maintenance mode if (ConfigOptions::getValue('maintenance_enabled')) { if (instance_of($this->logged_user, 'User') && $this->logged_user->isAdministrator()) { $this->wireframe->addPageMessage(lang('System is in maintenance mode and can be used by administrators only. <a href=":url">Click here</a> to turn off maintenance mode', array('url' => assemble_url('admin_settings_maintenance'))), 'warning'); } else { $additional_error_info = ConfigOptions::getValue('maintenance_message'); if ($additional_error_info) { $additional_error_info .= "\n\n"; } // if $additional_error_info .= lang('When system is in maintenance mode, administrators can log in and access the system') . ": " . assemble_url('login'); $this->smarty->assign('additional_error_info', $additional_error_info); if ($this->restrict_access_in_maintenance_mode) { $this->httpError(503); } // if } // if } // if // Check permissions if ($this->login_required && !instance_of($this->logged_user, 'User')) { // If async don't redirect to loging, just server proper HTTP code if ($this->request->isAsyncCall()) { $this->httpError(HTTP_ERR_UNAUTHORIZED, null, true, true); // Not async? Redirect to login with extracted route data... } else { $params = array(); if ($request->matched_route != 'login') { $params['re_route'] = $request->matched_route; foreach ($this->request->url_params as $k => $v) { if ($k == 'module' || $k == 'controller' || $k == 'action') { continue; } // if $params["re_{$k}"] = $v; } // foreach } // if $this->redirectTo($this->login_route, $params); } // if } // if if (instance_of($this->logged_user, 'User') && !$this->logged_user->getSystemPermission('system_access')) { $this->authentication->provider->logUserOut(); $this->httpError(HTTP_ERR_FORBIDDEN); } // if $loaded_modules = $this->application->getModules(); $assets_query_string = 'v=' . $this->application->version . '&modules='; foreach ($loaded_modules as $loaded_module) { $assets_query_string .= $loaded_module->getName() . ','; } // foreach $this->smarty->assign(array('api_status' => API_STATUS, 'application' => $this->application, 'owner_company' => $this->owner_company, 'authentication' => $this->authentication, 'logged_user' => $this->logged_user, 'request' => $this->request, 'theme_name' => $this->theme_name, 'request_time' => $this->request_time, 'loaded_modules' => $this->application->getModules(), 'captcha_url' => ROOT_URL . '/captcha.php?id=' . md5(time()), 'assets_query_string' => $assets_query_string, 'js_disabled_url' => assemble_url('js_disabled'))); $this->smarty->assign_by_ref('wireframe', $this->wireframe); js_assign(array('homepage_url' => ROOT_URL, 'assets_url' => ASSETS_URL, 'indicator_url' => get_image_url('indicator.gif'), 'big_indicator_url' => get_image_url('indicator_big.gif'), 'ok_indicator_url' => get_image_url('ok_indicator.gif'), 'warning_indicator_url' => get_image_url('warning_indicator.gif'), 'error_indicator_url' => get_image_url('error_indicator.gif'), 'pending_indicator_url' => get_image_url('pending_indicator.gif'), 'url_base' => URL_BASE, 'keep_alive_interval' => KEEP_ALIVE_INTERVAL, 'refresh_session_url' => assemble_url('refresh_session'), 'jump_to_project_url' => assemble_url('jump_to_project_widget'), 'quick_add_url' => assemble_url('quick_add'), 'path_info_through_query_string' => PATH_INFO_THROUGH_QUERY_STRING, 'image_picker_url' => assemble_url('image_picker'), 'copyright_removed' => LICENSE_COPYRIGHT_REMOVED, 'custom_tabs_manager' => assemble_url('custom_tabs_manager'), 'add_milestone_url' => assemble_url('project_milestones_add', array('project_id' => '--PROJECT_ID--')), 'add_checklist_url' => assemble_url('project_checklists_add', array('project_id' => '--PROJECT_ID--')), 'add_discussion_url' => assemble_url('project_discussions_add', array('project_id' => '--PROJECT_ID--')), 'add_file_url' => assemble_url('project_files_upload', array('project_id' => '--PROJECT_ID--')), 'add_page_url' => assemble_url('project_pages_add', array('project_id' => '--PROJECT_ID--')), 'add_ticket_url' => assemble_url('project_tickets_add', array('project_id' => '--PROJECT_ID--')), 'add_timerecord_url' => assemble_url('project_time_add', array('project_id' => '--PROJECT_ID--')), 'attachment_rename_url' => assemble_url('attachment_rename', array('project_id' => '--PROJECT_ID--', 'attachment_id' => '--ATTACHMENT_ID--')), 'attachment_copy_to_url' => assemble_url('attachment_copy_to', array('project_id' => '--PROJECT_ID--', 'attachment_id' => '--ATTACHMENT_ID--')), 'attachment_move_to_url' => assemble_url('attachment_move_to', array('project_id' => '--PROJECT_ID--', 'attachment_id' => '--ATTACHMENT_ID--')), 'image_uploader_url' => assemble_url('image_uploader'), 'render_comments_url' => assemble_url('render_comments'), 'move_task_url' => assemble_url('project_task_move', array('project_id' => '--PROJECT_ID--', 'task_id' => '--TASK_ID--')), 'get_collection_url' => assemble_url('collection'), 'quick_task_reminder_url' => assemble_url('project_task_quickreminder', array('project_id' => '--PROJECT_ID--', 'task_id' => '--TASK_ID--')), 'convert_to_ticket_url' => assemble_url('project_object_convert_to_ticket', array('project_id' => '--PROJECT_ID--', 'object_id' => '--OBJECT_ID--')), 'convert_to_milestone_url' => assemble_url('project_object_convert_to_milestone', array('project_id' => '--PROJECT_ID--', 'object_id' => '--OBJECT_ID--')), 'convert_to_page_url' => assemble_url('project_object_convert_to_page', array('project_id' => '--PROJECT_ID--', 'object_id' => '--OBJECT_ID--')), 'snooze_task_url' => assemble_url('project_task_snooze', array('project_id' => '--PROJECT_ID--', 'task_id' => '--TASK_ID--')))); if ($this->logged_user) { $link = mysql_connect(DB_HOST, DB_USER, DB_PASS); mysql_select_db(DB_NAME); if (!empty($_SESSION['pg_ttl'])) { mysql_query("update healingcrystals_user_visited_pages set title='" . mysql_real_escape_string($_SESSION['pg_ttl']) . "' where user_id='" . $this->logged_user->getId() . "' and access_time='" . date('Y-m-d H:i:s', $_SESSION['temp_time']) . "'"); } $current_url = (empty($_SERVER['HTTPS']) ? 'http://' : 'https://') . $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI']; $pos = strpos($_SERVER['QUERY_STRING'], '%2F'); if ($pos !== false) { $max_pages_count_per_user = 50; //require_once SMARTY_PATH . '/plugins/function.page_title.php'; //$current_page_title = smarty_function_page_title(array('default' => 'Projects')); //$current_page_title = PageConstruction::getPageTitle(); $_SESSION['temp_time'] = time(); mysql_query("insert into healingcrystals_user_visited_pages (user_id, page_url, title, access_time) values ('" . $this->logged_user->getId() . "', '" . $current_url . "', '', '" . date('Y-m-d H:i:s', $_SESSION['temp_time']) . "')"); //mysql_query("insert into healingcrystals_user_visited_pages (user_id, page_url, title, access_time) values ('" . $this->logged_user->getId() . "', '" . $current_url . "', '', now())"); $query = "select count(*) as count from healingcrystals_user_visited_pages where user_id='" . $this->logged_user->getId() . "'"; $result = mysql_query($query); $info = mysql_fetch_assoc($result); $current_count = $info['count']; if ($current_count > $max_pages_count_per_user) { $querries = array(); $query = "select * from healingcrystals_user_visited_pages where user_id='" . $this->logged_user->getId() . "' order by access_time limit 0, " . ($current_count - $max_pages_count_per_user); $result = mysql_query($query); while ($info = mysql_fetch_assoc($result)) { $querries[] = "delete from healingcrystals_user_visited_pages where user_id='" . $this->logged_user->getId() . "' and page_url='" . $info['page_url'] . "' and access_time='" . $info['access_time'] . "'"; } } foreach ($querries as $query) { mysql_query($query); } } $_SESSION['pg_ttl'] = ''; mysql_close($link); } }
<?php define('PUBLIC_PATH', dirname(__FILE__)); $config_file = realpath(PUBLIC_PATH . '/../config/config.php'); if (is_file($config_file)) { require_once $config_file; ini_set("default_charset", "UTF-8"); ini_set("error_reporting", ""); require ROOT . '/angie.php'; require ANGIE_PATH . '/init.php'; $application =& application(); $application->prepare(array('initialize_resources' => true, 'connect_to_database' => true, 'initialize_smarty' => true, 'init_modules' => true, 'authenticate' => true, 'init_locale' => true, 'load_hooks' => true)); //array $application->init(); include_once WEBDAV_MODULE_PATH . '/models/authenticate.php'; $not_installed_modules = Modules::findNotInstalled(); foreach ($not_installed_modules as $module) { if ($module->name == 'webdav') { header("HTTP/1.1 503 Service Unavailable"); die('Module is not installed'); } } if (!ConfigOptions::getValue('webdav_enabled')) { header("HTTP/1.1 503 Service Unavailable"); die('Module has been disabled by administrator'); } //if // Activate if your PHP is CGI mode $phpcgi = 0; $realm = 'activeCollab webdav area'; $user = AuthenticationBasicHTTP($realm);
/** * do daily backup * * @param null * @return null */ function backup_handle_on_daily() { set_time_limit(0); $start_time = time(); if (!ConfigOptions::getValue('backup_enabled')) { return true; } // if // check if backup path exists and if it's writable recursive_mkdir(BACKUP_PATH, 0777, WORK_PATH); if (!is_dir(BACKUP_PATH) || !folder_is_writable(BACKUP_PATH)) { backup_module_log_error('Backup path (' . BACKUP_PATH . ') does not exists or it is not writable', BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if $htaccess = BACKUP_PATH . '/.htaccess'; if (!is_file($htaccess)) { file_put_contents($htaccess, 'Deny from all'); } $folder_name = "backup " . date('Y-m-d H-i') . " GMT"; $backup_dir = BACKUP_PATH . '/' . $folder_name; // check if backup already exists if (is_dir($backup_dir)) { backup_module_log_error("Backup already exists ({$folder_name})", BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if // try to create backup directory if (!recursive_mkdir($backup_dir, 0777, WORK_PATH)) { backup_module_log_error("Could not create backup folder ({$backup_dir})", BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if chmod($backup_dir, 0777); // backup database (all tables that starts with TABLE_PREFIX) $tables = db_list_tables(TABLE_PREFIX); if (is_foreachable($tables)) { $result = db_dump_tables($tables, $backup_dir . '/database.sql'); if (is_error($result)) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error($result->getMessage(), BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if } else { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error("Database specified in config.php file does not have exportable tables. Check your config settings", BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // backup uploads $errors = array(); $result = backup_module_copy_dir(UPLOAD_PATH, $backup_dir . '/upload', true, $errors); if (!$result) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error($errors, BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if // backup project icons $errors = array(); $result = backup_module_copy_dir(PUBLIC_PATH . '/projects_icons', $backup_dir . '/projects_icons', true, $errors); if (!$result) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error($errors, BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if // backup avatars $errors = array(); $result = backup_module_copy_dir(PUBLIC_PATH . '/avatars', $backup_dir . '/avatars', true, $errors); if (!$result) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error($errors, BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if // backup logos $errors = array(); $result = backup_module_copy_dir(PUBLIC_PATH . '/logos', $backup_dir . '/logos', true, $errors); if (!$result) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error($errors, BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if $app =& application(); $checksum = backup_module_calculate_checksum($folder_name); $backup_note = "<?php \n/* \n"; $backup_note .= 'Backup is created with activeCollab v' . $app->version . ' on ' . date(DATETIME_MYSQL, $start_time) . "\n\n"; $backup_note .= "To restore system using this backup, visit this page: \n" . ROOT_URL . '/restore.php?backup=' . urlencode($folder_name) . '&checksum=' . $checksum; $backup_note .= "\n*/\n?>"; if (!file_put_contents($backup_dir . '/restore_instructions.php', $backup_note)) { safe_delete_dir($backup_dir, BACKUP_PATH); backup_module_log_error("Could not create restore instructions for backup.", BACKUP_MODULE_SEND_ERROR_EMAIL); return false; } // if // remove old backups $how_many_backups = ConfigOptions::getValue('backup_how_many_backups'); $how_many_backups = (int) $how_many_backups <= 0 ? 5 : $how_many_backups; $folders_in_backup_directory = backup_module_get_backups(BACKUP_PATH); if (count($folders_in_backup_directory) > $how_many_backups) { $old_backups = array_splice($folders_in_backup_directory, -(count($folders_in_backup_directory) - $how_many_backups)); foreach ($old_backups as $old_backup) { safe_delete_dir($old_backup['path'], BACKUP_PATH); } // foreach } // if log_message('Daily backup created', LOG_LEVEL_INFO, 'backup'); }
function redirect($loc = false, $code = false) { application()->redirect($loc, $code); }
public function testConvenienceFunction() { $r1 = application(); $this->assertTrue($r1 instanceof vicious\Application); $r2 = vicious\Application::instance(); $this->assertEquals($r1, $r2); }