getRequestTime(); * * @see https://www.drupal.org/node/2785211 */ define('REQUEST_TIME', (int) $_SERVER['REQUEST_TIME']); /** * Regular expression to match PHP function names. * * @see http://php.net/manual/language.functions.php */ const DRUPAL_PHP_FUNCTION_PATTERN = '[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*'; /** * $config_directories key for active directory. * * @see config_get_config_directory() * * @deprecated in Drupal 8.0.x and will be removed before 9.0.0. Drupal core no * longer creates an active directory. * * @see https://www.drupal.org/node/2501187 */ const CONFIG_ACTIVE_DIRECTORY = 'active'; /** * $config_directories key for sync directory. * * @see config_get_config_directory() */ const CONFIG_SYNC_DIRECTORY = 'sync'; /** * $config_directories key for staging directory. * * @see config_get_config_directory() * @see CONFIG_SYNC_DIRECTORY * * @deprecated in Drupal 8.0.x and will be removed before 9.0.0. The staging * directory was renamed to sync. * * @see https://www.drupal.org/node/2574957 */ const CONFIG_STAGING_DIRECTORY = 'staging'; /** * Defines the root directory of the Drupal installation. * * This strips two levels of directories off the current directory. */ define('DRUPAL_ROOT', dirname(dirname(__DIR__))); /** * Returns the path of a configuration directory. * * Configuration directories are configured using $config_directories in * settings.php. * * @param string $type * The type of config directory to return. Drupal core provides the * CONFIG_SYNC_DIRECTORY constant to access the sync directory. * * @return string * The configuration directory path. * * @throws \Exception */ function config_get_config_directory($type) { global $config_directories; // @todo Remove fallback in Drupal 9. https://www.drupal.org/node/2574943 if ($type == CONFIG_SYNC_DIRECTORY && !isset($config_directories[CONFIG_SYNC_DIRECTORY]) && isset($config_directories[CONFIG_STAGING_DIRECTORY])) { $type = CONFIG_STAGING_DIRECTORY; } if (!empty($config_directories[$type])) { return $config_directories[$type]; } // @todo https://www.drupal.org/node/2696103 Throw a more specific exception. throw new \Exception("The configuration directory type '$type' does not exist"); } /** * Returns and optionally sets the filename for a system resource. * * The filename, whether provided, cached, or retrieved from the database, is * only returned if the file exists. * * This function plays a key role in allowing Drupal's resources (modules * and themes) to be located in different places depending on a site's * configuration. For example, a module 'foo' may legally be located * in any of these three places: * * core/modules/foo/foo.info.yml * modules/foo/foo.info.yml * sites/example.com/modules/foo/foo.info.yml * * Calling drupal_get_filename('module', 'foo') will give you one of * the above, depending on where the module is located. * * @param $type * The type of the item; one of 'core', 'profile', 'module', 'theme', or * 'theme_engine'. * @param $name * The name of the item for which the filename is requested. Ignored for * $type 'core'. * @param $filename * The filename of the item if it is to be set explicitly rather * than by consulting the database. * * @return string * The filename of the requested item or NULL if the item is not found. */ function drupal_get_filename($type, $name, $filename = NULL) { // The location of files will not change during the request, so do not use // drupal_static(). static $files = []; // Type 'core' only exists to simplify application-level logic; it always maps // to the /core directory, whereas $name is ignored. It is only requested via // drupal_get_path(). /core/core.info.yml does not exist, but is required // since drupal_get_path() returns the dirname() of the returned pathname. if ($type === 'core') { return 'core/core.info.yml'; } // Profiles are converted into modules in system_rebuild_module_data(). // @todo Remove false-exposure of profiles as modules. if ($type == 'profile') { $type = 'module'; } if (!isset($files[$type])) { $files[$type] = []; } if (isset($filename)) { $files[$type][$name] = $filename; } elseif (!isset($files[$type][$name])) { // If the pathname of the requested extension is not known, try to retrieve // the list of extension pathnames from various providers, checking faster // providers first. // Retrieve the current module list (derived from the service container). if ($type == 'module' && \Drupal::hasService('module_handler')) { foreach (\Drupal::moduleHandler()->getModuleList() as $module_name => $module) { $files[$type][$module_name] = $module->getPathname(); } } // If still unknown, retrieve the file list prepared in state by // system_rebuild_module_data() and // \Drupal\Core\Extension\ThemeHandlerInterface::rebuildThemeData(). if (!isset($files[$type][$name]) && \Drupal::hasService('state')) { $files[$type] += \Drupal::state()->get('system.' . $type . '.files', []); } // If still unknown, create a user-level error message. if (!isset($files[$type][$name])) { trigger_error(SafeMarkup::format('The following @type is missing from the file system: @name', ['@type' => $type, '@name' => $name]), E_USER_WARNING); } } if (isset($files[$type][$name])) { return $files[$type][$name]; } } /** * Returns the path to a system item (module, theme, etc.). * * @param $type * The type of the item; one of 'core', 'profile', 'module', 'theme', or * 'theme_engine'. * @param $name * The name of the item for which the path is requested. Ignored for * $type 'core'. * * @return string * The path to the requested item or an empty string if the item is not found. */ function drupal_get_path($type, $name) { return dirname(drupal_get_filename($type, $name)); } /** * Translates a string to the current language or to a given language. * * In order for strings to be localized, make them available in one of the ways * supported by the @link i18n Localization API. @endlink When possible, use * the \Drupal\Core\StringTranslation\StringTranslationTrait $this->t(). * Otherwise create a new \Drupal\Core\StringTranslation\TranslatableMarkup * object directly. * * See \Drupal\Core\StringTranslation\TranslatableMarkup::__construct() for * important security information and usage guidelines. * * @param string $string * A string containing the English text to translate. * @param array $args * (optional) An associative array of replacements to make after translation. * Based on the first character of the key, the value is escaped and/or * themed. See * \Drupal\Component\Render\FormattableMarkup::placeholderFormat() for * details. * @param array $options * (optional) An associative array of additional options, with the following * elements: * - 'langcode' (defaults to the current language): A language code, to * translate to a language other than what is used to display the page. * - 'context' (defaults to the empty context): The context the source string * belongs to. See the @link i18n Internationalization topic @endlink for * more information about string contexts. * * @return \Drupal\Core\StringTranslation\TranslatableMarkup * An object that, when cast to a string, returns the translated string. * * @see \Drupal\Component\Render\FormattableMarkup::placeholderFormat() * @see \Drupal\Core\StringTranslation\StringTranslationTrait::t() * @see \Drupal\Core\StringTranslation\TranslatableMarkup::__construct() * * @ingroup sanitization */ function t($string, array $args = [], array $options = []) { return new TranslatableMarkup($string, $args, $options); } /** * Formats a string for HTML display by replacing variable placeholders. * * @see \Drupal\Component\Render\FormattableMarkup::placeholderFormat() * @see \Drupal\Component\Render\FormattableMarkup * @see t() * @ingroup sanitization * * @deprecated in Drupal 8.0.0, will be removed before Drupal 9.0.0. * Use \Drupal\Component\Render\FormattableMarkup. * * @see https://www.drupal.org/node/2302363 */ function format_string($string, array $args) { return SafeMarkup::format($string, $args); } /** * Checks whether a string is valid UTF-8. * * All functions designed to filter input should use drupal_validate_utf8 * to ensure they operate on valid UTF-8 strings to prevent bypass of the * filter. * * When text containing an invalid UTF-8 lead byte (0xC0 - 0xFF) is presented * as UTF-8 to Internet Explorer 6, the program may misinterpret subsequent * bytes. When these subsequent bytes are HTML control characters such as * quotes or angle brackets, parts of the text that were deemed safe by filters * end up in locations that are potentially unsafe; An onerror attribute that * is outside of a tag, and thus deemed safe by a filter, can be interpreted * by the browser as if it were inside the tag. * * The function does not return FALSE for strings containing character codes * above U+10FFFF, even though these are prohibited by RFC 3629. * * @param $text * The text to check. * * @return bool * TRUE if the text is valid UTF-8, FALSE if not. * * @see \Drupal\Component\Utility\Unicode::validateUtf8() * * @deprecated in Drupal 8.0.0, will be removed before Drupal 9.0.0. * Use \Drupal\Component\Utility\Unicode::validateUtf8(). * * @see https://www.drupal.org/node/1992584 */ function drupal_validate_utf8($text) { return Unicode::validateUtf8($text); } /** * Logs an exception. * * This is a wrapper logging function which automatically decodes an exception. * * @param $type * The category to which this message belongs. * @param $exception * The exception that is going to be logged. * @param $message * The message to store in the log. If empty, a text that contains all useful * information about the passed-in exception is used. * @param $variables * Array of variables to replace in the message on display or * NULL if message is already translated or not possible to * translate. * @param $severity * The severity of the message, as per RFC 3164. * @param $link * A link to associate with the message. * * @see \Drupal\Core\Utility\Error::decodeException() */ function watchdog_exception($type, Exception $exception, $message = NULL, $variables = [], $severity = RfcLogLevel::ERROR, $link = NULL) { // Use a default value if $message is not set. if (empty($message)) { $message = '%type: @message in %function (line %line of %file).'; } if ($link) { $variables['link'] = $link; } $variables += Error::decodeException($exception); \Drupal::logger($type)->log($severity, $message, $variables); } /** * Sets a message to display to the user. * * Messages are stored in a session variable and displayed in the page template * via the $messages theme variable. * * Example usage: * @code * drupal_set_message(t('An error occurred and processing did not complete.'), 'error'); * @endcode * * @param string|\Drupal\Component\Render\MarkupInterface $message * (optional) The translated message to be displayed to the user. For * consistency with other messages, it should begin with a capital letter and * end with a period. * @param string $type * (optional) The message's type. Defaults to 'status'. These values are * supported: * - 'status' * - 'warning' * - 'error' * @param bool $repeat * (optional) If this is FALSE and the message is already set, then the * message won't be repeated. Defaults to FALSE. * * @return array|null * A multidimensional array with keys corresponding to the set message types. * The indexed array values of each contain the set messages for that type, * and each message is an associative array with the following format: * - safe: Boolean indicating whether the message string has been marked as * safe. Non-safe strings will be escaped automatically. * - message: The message string. * So, the following is an example of the full return array structure: * @code * array( * 'status' => array( * array( * 'safe' => TRUE, * 'message' => 'A safe markup string.', * ), * array( * 'safe' => FALSE, * 'message' => "$arbitrary_user_input to escape.", * ), * ), * ); * @endcode * If there are no messages set, the function returns NULL. * * @see drupal_get_messages() * @see status-messages.html.twig * @see https://www.drupal.org/node/2774931 * * @deprecated in Drupal 8.5.0 and will be removed before Drupal 9.0.0. * Use \Drupal\Core\Messenger\MessengerInterface::addMessage() instead. */ function drupal_set_message($message = NULL, $type = 'status', $repeat = FALSE) { @trigger_error('drupal_set_message() is deprecated in Drupal 8.5.0 and will be removed before Drupal 9.0.0. Use \Drupal\Core\Messenger\MessengerInterface::addMessage() instead. See https://www.drupal.org/node/2774931', E_USER_DEPRECATED); $messenger = \Drupal::messenger(); if (isset($message)) { $messenger->addMessage($message, $type, $repeat); } return $messenger->all(); } /** * Returns all messages that have been set with drupal_set_message(). * * @param string $type * (optional) Limit the messages returned by type. Defaults to NULL, meaning * all types. These values are supported: * - NULL * - 'status' * - 'warning' * - 'error' * @param bool $clear_queue * (optional) If this is TRUE, the queue will be cleared of messages of the * type specified in the $type parameter. Otherwise the queue will be left * intact. Defaults to TRUE. * * @return array * An associative, nested array of messages grouped by message type, with * the top-level keys as the message type. The messages returned are * limited to the type specified in the $type parameter, if any. If there * are no messages of the specified type, an empty array is returned. See * drupal_set_message() for the array structure of individual messages. * * @see drupal_set_message() * @see status-messages.html.twig * @see https://www.drupal.org/node/2774931 * * @deprecated in Drupal 8.5.0 and will be removed before Drupal 9.0.0. * Use \Drupal\Core\Messenger\MessengerInterface::all() or * \Drupal\Core\Messenger\MessengerInterface::messagesByType() instead. */ function drupal_get_messages($type = NULL, $clear_queue = TRUE) { @trigger_error('drupal_get_message() is deprecated in Drupal 8.5.0 and will be removed before Drupal 9.0.0. Use \Drupal\Core\Messenger\MessengerInterface::all() or \Drupal\Core\Messenger\MessengerInterface::messagesByType() instead. See https://www.drupal.org/node/2774931', E_USER_DEPRECATED); $messenger = \Drupal::messenger(); if ($messages = $messenger->all()) { if ($type) { if ($clear_queue) { $messenger->deleteByType($type); } if (isset($messages[$type])) { return [$type => $messages[$type]]; } } else { if ($clear_queue) { $messenger->deleteAll(); } return $messages; } } return []; } /** * Returns the time zone of the current user. * * @return string * The name of the current user's timezone or the name of the default timezone. */ function drupal_get_user_timezone() { $user = \Drupal::currentUser(); $config = \Drupal::config('system.date'); if ($user && $config->get('timezone.user.configurable') && $user->isAuthenticated() && $user->getTimezone()) { return $user->getTimezone(); } else { // Ignore PHP strict notice if time zone has not yet been set in the php.ini // configuration. $config_data_default_timezone = $config->get('timezone.default'); return !empty($config_data_default_timezone) ? $config_data_default_timezone : @date_default_timezone_get(); } } /** * Provides custom PHP error handling. * * @param $error_level * The level of the error raised. * @param $message * The error message. * @param $filename * The filename that the error was raised in. * @param $line * The line number the error was raised at. * @param $context * An array that points to the active symbol table at the point the error * occurred. */ function _drupal_error_handler($error_level, $message, $filename, $line, $context) { require_once __DIR__ . '/errors.inc'; _drupal_error_handler_real($error_level, $message, $filename, $line, $context); } /** * Provides custom PHP exception handling. * * Uncaught exceptions are those not enclosed in a try/catch block. They are * always fatal: the execution of the script will stop as soon as the exception * handler exits. * * @param \Exception|\Throwable $exception * The exception object that was thrown. */ function _drupal_exception_handler($exception) { require_once __DIR__ . '/errors.inc'; try { // Log the message to the watchdog and return an error page to the user. _drupal_log_error(Error::decodeException($exception), TRUE); } // PHP 7 introduces Throwable, which covers both Error and // Exception throwables. catch (\Throwable $error) { _drupal_exception_handler_additional($exception, $error); } // In order to be compatible with PHP 5 we also catch regular Exceptions. catch (\Exception $exception2) { _drupal_exception_handler_additional($exception, $exception2); } } /** * Displays any additional errors caught while handling an exception. * * @param \Exception|\Throwable $exception * The first exception object that was thrown. * @param \Exception|\Throwable $exception2 * The second exception object that was thrown. */ function _drupal_exception_handler_additional($exception, $exception2) { // Another uncaught exception was thrown while handling the first one. // If we are displaying errors, then do so with no possibility of a further // uncaught exception being thrown. if (error_displayable()) { print '
' . Error::renderExceptionSafe($exception) . '
'; print '' . Error::renderExceptionSafe($exception2) . '
' . Error::renderExceptionSafe($exception) . '