Overview

Namespaces

  • Composer
    • Autoload
  • Geekwright
    • RegDom
  • League
    • OAuth2
      • Client
        • Provider
  • None
  • Xmf
    • Database
    • Jwt
    • Key
    • Module
      • Helper

Classes

  • ArtObject
  • ArtObjectHandler
  • BloggerApi
  • CGIF
  • CGIFCOLORTABLE
  • CGIFFILEHEADER
  • CGIFIMAGE
  • CGIFIMAGEHEADER
  • CGIFLZW
  • Composer\Autoload\ClassLoader
  • Composer\Autoload\ComposerStaticInit274e5fff219a4f27a346e611b0580d6a
  • ComposerAutoloaderInit274e5fff219a4f27a346e611b0580d6a
  • Config_File
  • Cookie
  • Criteria
  • CriteriaCompo
  • CriteriaElement
  • Database
  • Db_manager
  • ErrorHandler
  • FormDhtmlTextArea
  • FormTextArea
  • Geekwright\RegDom\PublicSuffixList
  • Geekwright\RegDom\RegisteredDomain
  • HTMLPurifier
  • League\OAuth2\Client\Provider\Google
  • MetaWeblogApi
  • ModuleAdmin
  • MovableTypeApi
  • MyTextSanitizer
  • MyTextSanitizerExtended
  • MyTextSanitizerExtension
  • MytsCensor
  • MytsFlash
  • MytsIframe
  • MytsImage
  • MytsLi
  • MytsMms
  • MytsMp3
  • MytsRtsp
  • MytsSoundcloud
  • MytsSyntaxhighlight
  • MytsTextfilter
  • MytsUl
  • MytsWiki
  • MytsWmp
  • MytsYoutube
  • PathStuffController
  • PHPMailer
  • PHPMailerOAuth
  • PHPMailerOAuthGoogle
  • phpthumb
  • phpthumb_bmp
  • phpthumb_filters
  • phpthumb_functions
  • phpthumb_ico
  • phpUnsharpMask
  • PmCorePreload
  • PmMessage
  • PmMessageHandler
  • PmSystemPreload
  • POP3
  • ProfileCategory
  • ProfileCategoryHandler
  • ProfileCorePreload
  • ProfileField
  • ProfileFieldHandler
  • ProfileProfile
  • ProfileProfileHandler
  • ProfileRegstep
  • ProfileRegstepHandler
  • ProfileVisibility
  • ProfileVisibilityHandler
  • Protector
  • Protector_bruteforce_overrun_message
  • Protector_crawler_overrun_message
  • Protector_f5attack_overrun_message
  • Protector_postcommon_post_deny_by_httpbl
  • Protector_postcommon_post_deny_by_rbl
  • Protector_postcommon_post_htmlpurify4everyone
  • Protector_postcommon_post_htmlpurify4guest
  • Protector_postcommon_post_language_match
  • Protector_postcommon_post_need_multibyte
  • Protector_postcommon_post_register_moratorium
  • Protector_postcommon_post_stopforumspam
  • Protector_postcommon_register_insert_js_check
  • Protector_postcommon_register_stopforumspam
  • Protector_precommon_badip_errorlog
  • Protector_precommon_badip_message
  • Protector_precommon_badip_redirection
  • Protector_precommon_bwlimit_errorlog
  • Protector_precommon_bwlimit_message
  • Protector_prepurge_exit_message
  • Protector_spamcheck_overrun_message
  • ProtectorCorePreload
  • ProtectorFilterAbstract
  • ProtectorFilterHandler
  • ProtectorMySQLDatabase
  • ProtectorRegistry
  • ReCaptchaResponse
  • RpcArrayHandler
  • RpcBase64Handler
  • RpcBooleanHandler
  • RpcDateTimeHandler
  • RpcDoubleHandler
  • RpcIntHandler
  • RpcMemberHandler
  • RpcMethodNameHandler
  • RpcNameHandler
  • RpcStringHandler
  • RpcStructHandler
  • RpcValueHandler
  • RssAuthorHandler
  • RssCategoryHandler
  • RssChannelHandler
  • RssCommentsHandler
  • RssCopyrightHandler
  • RssDescriptionHandler
  • RssDocsHandler
  • RssGeneratorHandler
  • RssGuidHandler
  • RssHeightHandler
  • RssImageHandler
  • RssItemHandler
  • RssLanguageHandler
  • RssLastBuildDateHandler
  • RssLinkHandler
  • RssManagingEditorHandler
  • RssNameHandler
  • RssPubDateHandler
  • RssSourceHandler
  • RssTextInputHandler
  • RssTitleHandler
  • RssTtlHandler
  • RssUrlHandler
  • RssWebMasterHandler
  • RssWidthHandler
  • SaxParser
  • Smarty
  • Smarty_Compiler
  • SMTP
  • Snoopy
  • SqlUtility
  • SystemAvatar
  • SystemAvatarHandler
  • SystemBanner
  • SystemBannerclient
  • SystemBannerclientHandler
  • SystemBannerFinish
  • SystemBannerfinishHandler
  • SystemBannerHandler
  • SystemBlock
  • SystemBlockHandler
  • SystemBlockLinkModule
  • SystemBlockLinkModuleHandler
  • SystemBreadcrumb
  • SystemCorePreload
  • SystemFineAvatarUploadHandler
  • SystemFineImUploadHandler
  • SystemFineUploadHandler
  • SystemGroup
  • SystemGroupHandler
  • SystemMaintenance
  • SystemMenuHandler
  • SystemSmilies
  • SystemsmiliesHandler
  • SystemUserrank
  • SystemuserrankHandler
  • SystemUsers
  • SystemUsersHandler
  • Tar
  • ThemeSetAuthorHandler
  • ThemeSetDateCreatedHandler
  • ThemeSetDescriptionHandler
  • ThemeSetEmailHandler
  • ThemeSetFileTypeHandler
  • ThemeSetGeneratorHandler
  • ThemeSetImageHandler
  • ThemeSetLinkHandler
  • ThemeSetModuleHandler
  • ThemeSetNameHandler
  • ThemeSetTagHandler
  • ThemeSetTemplateHandler
  • TinyMCE
  • Xmf\Assert
  • Xmf\Database\Migrate
  • Xmf\Database\TableLoad
  • Xmf\Database\Tables
  • Xmf\Debug
  • Xmf\FilterInput
  • Xmf\Highlighter
  • Xmf\IPAddress
  • Xmf\Jwt\JsonWebToken
  • Xmf\Jwt\KeyFactory
  • Xmf\Jwt\TokenFactory
  • Xmf\Jwt\TokenReader
  • Xmf\Key\ArrayStorage
  • Xmf\Key\Basic
  • Xmf\Key\FileStorage
  • Xmf\Key\KeyAbstract
  • Xmf\Language
  • Xmf\Metagen
  • Xmf\Module\Admin
  • Xmf\Module\Helper
  • Xmf\Module\Helper\AbstractHelper
  • Xmf\Module\Helper\Cache
  • Xmf\Module\Helper\GenericHelper
  • Xmf\Module\Helper\Permission
  • Xmf\Module\Helper\Session
  • Xmf\Random
  • Xmf\Request
  • Xmf\StopWords
  • Xmf\Yaml
  • XmlTagHandler
  • XoopsApi
  • xoopsart
  • XoopsAuth
  • XoopsAuthAds
  • XoopsAuthFactory
  • XoopsAuthLdap
  • XoopsAuthProvisionning
  • XoopsAuthXoops
  • XoopsAvatar
  • XoopsAvatarHandler
  • XoopsBlock
  • XoopsBlockHandler
  • XoopsBlockInstance
  • XoopsBlockInstanceHandler
  • XoopsCache
  • XoopsCacheApc
  • XoopsCacheEngine
  • XoopsCacheFile
  • XoopsCacheMemcache
  • XoopsCacheModel
  • XoopsCacheModelHandler
  • XoopsCacheModelObject
  • XoopsCacheXcache
  • XoopsCaptcha
  • XoopsCaptchaImage
  • XoopsCaptchaImageHandler
  • XoopsCaptchaMethod
  • XoopsCaptchaRecaptcha
  • XoopsCaptchaRecaptcha2
  • XoopsCaptchaText
  • XoopsComment
  • XoopsCommentHandler
  • XoopsCommentRenderer
  • XoopsComments
  • XoopsConfigCategory
  • XoopsConfigCategoryHandler
  • XoopsConfigHandler
  • XoopsConfigItem
  • XoopsConfigItemHandler
  • XoopsConfigOption
  • XoopsConfigOptionHandler
  • XoopsDatabase
  • XoopsDatabaseFactory
  • XoopsDownloader
  • XoopsEditor
  • XoopsEditorHandler
  • XoopsErrorHandler
  • XoopsFile
  • XoopsFileHandler
  • XoopsFilterInput
  • XoopsFolderHandler
  • XoopsForm
  • XoopsFormButton
  • XoopsFormButtonTray
  • XoopsFormCaptcha
  • XoopsFormCheckBox
  • XoopsFormColorPicker
  • XoopsFormDateTime
  • XoopsFormDhtmlTextArea
  • XoopsFormEditor
  • XoopsFormElement
  • XoopsFormElementTray
  • XoopsFormFile
  • XoopsFormHidden
  • XoopsFormHiddenToken
  • XoopsFormLabel
  • XoopsFormPassword
  • XoopsFormRadio
  • XoopsFormRadioYN
  • XoopsFormRenderer
  • XoopsFormRendererBootstrap3
  • XoopsFormRendererLegacy
  • XoopsFormSelect
  • XoopsFormSelectCheckGroup
  • XoopsFormSelectCountry
  • XoopsFormSelectEditor
  • XoopsFormSelectGroup
  • XoopsFormSelectLang
  • XoopsFormSelectMatchOption
  • XoopsFormSelectTheme
  • XoopsFormSelectTimezone
  • XoopsFormSelectUser
  • XoopsFormText
  • XoopsFormTextArea
  • XoopsFormTextDateSelect
  • XoopsFormTinymce
  • XoopsGroup
  • XoopsGroupFormCheckBox
  • XoopsGroupHandler
  • XoopsGroupPerm
  • XoopsGroupPermForm
  • XoopsGroupPermHandler
  • XoopsGTicket
  • XoopsGuestUser
  • XoopsGuiDefault
  • XoopsGuiThadmin
  • XoopsGuiTransition
  • XoopsGuiZetadigme
  • XoopsHandlerRegistry
  • XoopsImage
  • XoopsImagecategory
  • XoopsImagecategoryHandler
  • XoopsImageHandler
  • XoopsImageSet
  • XoopsImagesetHandler
  • XoopsImagesetimg
  • XoopsImagesetimgHandler
  • XoopsInstallWizard
  • XoopsLists
  • XoopsLoad
  • XoopsLocal
  • XoopsLocalAbstract
  • XoopsLocalWrapper
  • XoopsLogger
  • XoopsMailer
  • XoopsMailerLocal
  • XoopsMediaUploader
  • XoopsMemberHandler
  • XoopsMembership
  • XoopsMembershipHandler
  • XoopsModelAbstract
  • XoopsModelFactory
  • XoopsModelJoint
  • XoopsModelRead
  • XoopsModelStats
  • XoopsModelSync
  • XoopsModelWrite
  • XoopsModule
  • XoopsModuleHandler
  • XoopsMultiMailer
  • XoopsMySQLDatabase
  • XoopsMySQLDatabaseProxy
  • XoopsMySQLDatabaseSafe
  • XoopsNotification
  • XoopsNotificationHandler
  • XoopsObject
  • XoopsObjectHandler
  • XoopsObjectTree
  • XoopsOnlineHandler
  • XoopsPageNav
  • XoopsPersistableObjectHandler
  • XoopsPreload
  • XoopsPreloadItem
  • XoopsPrivmessage
  • XoopsPrivmessageHandler
  • XoopsRank
  • XoopsRankHandler
  • XoopsRequest
  • XoopsSecurity
  • XoopsSessionHandler
  • XoopsSimpleForm
  • XoopsStory
  • XoopsSystemCpanel
  • XoopsSystemGui
  • XoopsTableForm
  • XoopsTarDownloader
  • XoopsThemeForm
  • XoopsThemeSetParser
  • XoopsTopic
  • XoopsTpl
  • XoopsTplfile
  • XoopsTplfileHandler
  • XoopsTplset
  • XoopsTplsetHandler
  • XoopsTree
  • XoopsUser
  • XoopsUserHandler
  • XoopsUserUtility
  • XoopsUtility
  • XoopsXmlRpcApi
  • XoopsXmlRpcArray
  • XoopsXmlRpcBase64
  • XoopsXmlRpcBoolean
  • XoopsXmlRpcDatetime
  • XoopsXmlRpcDocument
  • XoopsXmlRpcDouble
  • XoopsXmlRpcFault
  • XoopsXmlRpcInt
  • XoopsXmlRpcParser
  • XoopsXmlRpcRequest
  • XoopsXmlRpcResponse
  • XoopsXmlRpcString
  • XoopsXmlRpcStruct
  • XoopsXmlRpcTag
  • XoopsXmlRss2Parser
  • XoopsZipDownloader
  • xos_kernel_Xoops2
  • xos_logos_PageBuilder
  • xos_opal_AdminThemeFactory
  • xos_opal_Theme
  • xos_opal_ThemeFactory
  • XoUser
  • XoUserHandler
  • Zipfile

Interfaces

  • Xmf\Key\StorageInterface
  • XoopsFormRendererInterface

Exceptions

  • phpmailerException

Functions

  • __autoload
  • _recaptcha_aes_encrypt
  • _recaptcha_aes_pad
  • _recaptcha_http_post
  • _recaptcha_mailhide_email_parts
  • _recaptcha_mailhide_urlbase64
  • _recaptcha_qsencode
  • _smarty_regex_replace_check
  • _smarty_sort_length
  • admin_refcheck
  • b_system_comments_edit
  • b_system_comments_show
  • b_system_info_edit
  • b_system_info_show
  • b_system_login_show
  • b_system_main_show
  • b_system_newmembers_edit
  • b_system_newmembers_show
  • b_system_notification_show
  • b_system_online_show
  • b_system_search_show
  • b_system_themes_edit
  • b_system_themes_show
  • b_system_topposters_edit
  • b_system_topposters_show
  • b_system_user_show
  • b_system_waiting_show
  • bannerstats
  • change_banner_url_by_client
  • checkEmail
  • clickbanner
  • clientlogin
  • closeTable
  • closeThread
  • CloseWaitBox
  • Composer\Autoload\includeFile
  • composerRequire274e5fff219a4f27a346e611b0580d6a
  • createConfigform
  • createThemeform
  • doConditionalGet
  • emailStats
  • exit404BadReq
  • fatalPhpErrorHandler
  • file_get_contents
  • file_put_contents
  • findSharp
  • form_user
  • formatTimestamp
  • formatURL
  • gd_info
  • genPathCheckHtml
  • get_request_method
  • get_writeoks_from_protector
  • getcss
  • getDbCharsets
  • getDbCollations
  • getDirList
  • getMailer
  • getTheme
  • gif_getSize
  • gif_loadFile
  • gif_loadFileToGDimageResource
  • gif_outputAsBmp
  • gif_outputAsJpeg
  • gif_outputAsPng
  • HTMLPurifier
  • imagealphablending
  • imageBrowser
  • imageCreateCorners
  • imageFilenameCheck
  • imagesavealpha
  • install_acceptUser
  • install_finalize
  • is_executable
  • kses
  • langDropdown
  • load_functions
  • load_object
  • load_objectHandler
  • loadModuleAdminMenu
  • make_cblock
  • make_data
  • make_groups
  • make_sidebar
  • mod_clearCacheFile
  • mod_clearConfg
  • mod_clearConfig
  • mod_clearFile
  • mod_clearSmartyCache
  • mod_constant
  • mod_createCacheFile
  • mod_createCacheFile_byGroup
  • mod_createFile
  • mod_DB_prefix
  • mod_fetchConfg
  • mod_fetchConfig
  • mod_generateCacheId
  • mod_generateCacheId_byGroup
  • mod_getDirname
  • mod_getIP
  • mod_getMysqlVersion
  • mod_getUnameFromId
  • mod_getUnameFromIds
  • mod_isModuleAction
  • mod_loadCacheFile
  • mod_loadCacheFile_byGroup
  • mod_loadConfg
  • mod_loadConfig
  • mod_loadFile
  • mod_loadFunctions
  • mod_loadRenderer
  • mod_message
  • modify_chmod
  • myTextForm
  • notificationCategoryInfo
  • notificationCommentCategoryInfo
  • notificationEnabled
  • notificationEventEnabled
  • notificationEventInfo
  • notificationEvents
  • notificationGenerateConfig
  • notificationSubscribableCategoryInfo
  • openTable
  • openThread
  • OpenWaitBox
  • PHPMailerAutoload
  • phpThumbURL
  • preg_quote
  • profile_getFieldForm
  • profile_getRegisterForm
  • profile_getStepForm
  • profile_getUserForm
  • profile_install_addCategory
  • profile_install_addField
  • profile_install_addStep
  • profile_install_initializeProfiles
  • profile_install_setPermissions
  • protector_message_append_oninstall
  • protector_message_append_onuninstall
  • protector_message_append_onupdate
  • protector_notify_base
  • protector_oninstall_base
  • protector_onuninstall_base
  • protector_onupdate_base
  • protector_postcommon
  • protector_prepare
  • recaptcha_check_answer
  • recaptcha_get_html
  • recaptcha_get_signup_url
  • recaptcha_mailhide_html
  • recaptcha_mailhide_url
  • redirect_header
  • RedirectToCachedFile
  • SendSaveAsFileHeaderIfNeeded
  • showbanner
  • showThread
  • smarty_block_textformat
  • smarty_compiler_assign
  • smarty_compiler_foreachq
  • smarty_compiler_includeq
  • smarty_compiler_xoAdminIcons
  • smarty_compiler_xoAdminNav
  • smarty_compiler_xoAppUrl
  • smarty_compiler_xoImgUrl
  • smarty_compiler_xoModuleIcons16
  • smarty_compiler_xoModuleIcons32
  • smarty_compiler_xoModuleIconsBookmarks
  • smarty_core_assemble_plugin_filepath
  • smarty_core_assign_smarty_interface
  • smarty_core_create_dir_structure
  • smarty_core_display_debug_console
  • smarty_core_get_include_path
  • smarty_core_get_microtime
  • smarty_core_get_php_resource
  • smarty_core_is_secure
  • smarty_core_is_trusted
  • smarty_core_load_plugins
  • smarty_core_load_resource_plugin
  • smarty_core_process_cached_inserts
  • smarty_core_process_compiled_include
  • smarty_core_read_cache_file
  • smarty_core_rm_auto
  • smarty_core_rmdir
  • smarty_core_run_insert_handler
  • smarty_core_smarty_include_php
  • smarty_core_write_cache_file
  • smarty_core_write_compiled_include
  • smarty_core_write_compiled_resource
  • smarty_core_write_file
  • smarty_function_assign_debug_info
  • smarty_function_block
  • smarty_function_config_load
  • smarty_function_counter
  • smarty_function_cycle
  • smarty_function_debug
  • smarty_function_escape_special_chars
  • smarty_function_eval
  • smarty_function_fetch
  • smarty_function_html_checkboxes
  • smarty_function_html_checkboxes_output
  • smarty_function_html_image
  • smarty_function_html_options
  • smarty_function_html_options_optgroup
  • smarty_function_html_options_optoutput
  • smarty_function_html_radios
  • smarty_function_html_radios_output
  • smarty_function_html_select_date
  • smarty_function_html_select_time
  • smarty_function_html_table
  • smarty_function_html_table_cycle
  • smarty_function_mailto
  • smarty_function_math
  • smarty_function_popup
  • smarty_function_popup_init
  • smarty_function_securityToken
  • smarty_function_xoInboxCount
  • smarty_function_xoMemberInfo
  • smarty_function_xoops_link
  • smarty_function_xoPageNav
  • smarty_make_timestamp
  • smarty_modifier_capitalize
  • smarty_modifier_capitalize_ucfirst
  • smarty_modifier_cat
  • smarty_modifier_count_characters
  • smarty_modifier_count_paragraphs
  • smarty_modifier_count_sentences
  • smarty_modifier_count_words
  • smarty_modifier_date_format
  • smarty_modifier_debug_print_var
  • smarty_modifier_default
  • smarty_modifier_escape
  • smarty_modifier_indent
  • smarty_modifier_lower
  • smarty_modifier_nl2br
  • smarty_modifier_regex_replace
  • smarty_modifier_replace
  • smarty_modifier_spacify
  • smarty_modifier_string_format
  • smarty_modifier_strip
  • smarty_modifier_strip_tags
  • smarty_modifier_truncate
  • smarty_modifier_upper
  • smarty_modifier_wordwrap
  • smarty_outputfilter_trimwhitespace
  • smarty_outputfilter_trimwhitespace_replace
  • smarty_resource_db_secure
  • smarty_resource_db_source
  • smarty_resource_db_timestamp
  • smarty_resource_db_tplinfo
  • smarty_resource_db_trusted
  • synchronize
  • system_AdminIcons
  • system_adminVersion
  • system_CleanVars
  • system_loadLanguage
  • system_loadTemplate
  • themecenterposts
  • update_system_v211
  • userCheck
  • userTimeToServerTime
  • validateDbCharset
  • writeLicenseKey
  • xoBuildLicenceKey
  • xoDiag
  • xoDiagBoolSetting
  • xoDiagIfWritable
  • xoFormBlockCollation
  • xoFormField
  • xoFormFieldCharset
  • xoFormFieldCollation
  • xoFormSelect
  • xoops_aw_decode
  • xoops_aw_encode
  • xoops_bin2hex
  • xoops_comment_count
  • xoops_comment_delete
  • xoops_confirm
  • xoops_convert_decode
  • xoops_convert_encode
  • xoops_convert_encoding
  • xoops_cp_footer
  • xoops_cp_header
  • xoops_error
  • xoops_footer
  • xoops_getActiveModules
  • xoops_getbanner
  • xoops_getBaseDomain
  • xoops_getConfigOption
  • xoops_getcss
  • xoops_getenv
  • xoops_getHandler
  • xoops_getLinkedUnameFromId
  • xoops_getMailer
  • xoops_getModuleHandler
  • xoops_getModuleOption
  • xoops_getOption
  • xoops_getrank
  • xoops_getUrlDomain
  • xoops_getUserTimestamp
  • xoops_groupperm_deletebymoditem
  • xoops_header
  • xoops_hex2bin
  • xoops_isActiveModule
  • xoops_ishexstr
  • xoops_load
  • xoops_load_lang_file
  • xoops_loadLanguage
  • xoops_local
  • xoops_makepass
  • xoops_message
  • xoops_module_activate
  • xoops_module_change
  • xoops_module_deactivate
  • xoops_module_delayed_clean_cache
  • xoops_module_get_admin_menu
  • xoops_module_gettemplate
  • xoops_module_install
  • xoops_module_install_pm
  • xoops_module_install_profile
  • xoops_module_log_header
  • xoops_module_uninstall
  • xoops_module_update
  • xoops_module_update_pm
  • xoops_module_update_profile
  • xoops_module_update_system
  • xoops_module_write_admin_menu
  • xoops_notification_deletebyitem
  • xoops_notification_deletebymodule
  • xoops_notification_deletebyuser
  • xoops_refcheck
  • xoops_result
  • xoops_setActiveModules
  • xoops_setConfigOption
  • xoops_substr
  • xoops_template_clear_module_cache
  • xoops_template_touch
  • xoops_trim
  • xoops_utf8_encode
  • xoops_write_index_file
  • xoopsCodeTarea
  • xoopseditor_get_rootpath
  • XoopsErrorHandler_HandleError
  • xoopsfwrite
  • xoopsSmilies
  • xoPassField
  • xoPhpVersion
  • xoPutLicenseKey
  • xoStripeKey
  • Overview
  • Namespace
  • Class
  • Tree
  1: <?php
  2: /**
  3:  * Xoops Logger handlers - component main class file
  4:  *
  5:  * You may not change or alter any portion of this comment or credits
  6:  * of supporting developers from this source code or any supporting source code
  7:  * which is considered copyrighted (c) material of the original comment or credit authors.
  8:  * This program is distributed in the hope that it will be useful,
  9:  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 10:  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 11:  *
 12:  * @copyright       (c) 2000-2016 XOOPS Project (www.xoops.org)
 13:  * @license             GNU GPL 2 (http://www.gnu.org/licenses/gpl-2.0.html)
 14:  * @package             kernel
 15:  * @subpackage          logger
 16:  * @since               2.3.0
 17:  * @author              Kazumi Ono  <onokazu@xoops.org>
 18:  * @author              Skalpa Keo <skalpa@xoops.org>
 19:  * @author              Taiwen Jiang <phppp@users.sourceforge.net>
 20:  *
 21:  * @todo                Not well written, just keep as it is. Refactored in 3.0
 22:  */
 23: defined('XOOPS_ROOT_PATH') || exit('Restricted access');
 24: 
 25: /**
 26:  * Collects information for a page request
 27:  *
 28:  * Records information about database queries, blocks, and execution time
 29:  * and can display it as HTML. It also catches php runtime errors.
 30:  *
 31:  * @package kernel
 32:  */
 33: class XoopsLogger
 34: {
 35:     /**
 36:      * *#@+
 37:      *
 38:      * @var array
 39:      */
 40:     public $queries    = array();
 41:     public $blocks     = array();
 42:     public $extra      = array();
 43:     public $logstart   = array();
 44:     public $logend     = array();
 45:     public $errors     = array();
 46:     public $deprecated = array();
 47:     /**
 48:      * *#@-
 49:      */
 50: 
 51:     public $usePopup  = false;
 52:     public $activated = true;
 53: 
 54:     /**
 55:      * *@access protected
 56:      */
 57:     public $renderingEnabled = false;
 58: 
 59:     /**
 60:      * XoopsLogger::__construct()
 61:      */
 62:     public function __construct()
 63:     {
 64:     }
 65: 
 66:     /**
 67:      * XoopsLogger::XoopsLogger()
 68:      */
 69:     public function XoopsLogger()
 70:     {
 71:     }
 72: 
 73:     /**
 74:      * Deprecated, use getInstance() instead
 75:      */
 76:     public function instance()
 77:     {
 78:         return XoopsLogger::getInstance();
 79:     }
 80: 
 81:     /**
 82:      * Get a reference to the only instance of this class
 83:      *
 84:      * @return object XoopsLogger  reference to the only instance
 85:      */
 86:     public static function getInstance()
 87:     {
 88:         static $instance;
 89:         if (!isset($instance)) {
 90:             $instance = new XoopsLogger();
 91:             // Always catch errors, for security reasons
 92:             set_error_handler('XoopsErrorHandler_HandleError');
 93:             // grab any uncaught exception
 94:             set_exception_handler(array($instance, 'handleException'));
 95:         }
 96: 
 97:         return $instance;
 98:     }
 99: 
100:     /**
101:      * Enable logger output rendering
102:      * When output rendering is enabled, the logger will insert its output within the page content.
103:      * If the string <!--{xo-logger-output}--> is found in the page content, the logger output will
104:      * replace it, otherwise it will be inserted after all the page output.
105:      */
106:     public function enableRendering()
107:     {
108:         if (!$this->renderingEnabled) {
109:             ob_start(array(&$this, 'render'));
110:             $this->renderingEnabled = true;
111:         }
112:     }
113: 
114:     /**
115:      * Returns the current microtime in seconds.
116:      *
117:      * @return float
118:      */
119:     public function microtime()
120:     {
121:         $now = explode(' ', microtime());
122: 
123:         return (float)$now[0] + (float)$now[1];
124:     }
125: 
126:     /**
127:      * Start a timer
128:      *
129:      * @param string $name name of the timer
130:      */
131:     public function startTime($name = 'XOOPS')
132:     {
133:         if ($this->activated) {
134:             $this->logstart[$name] = $this->microtime();
135:         }
136:     }
137: 
138:     /**
139:      * Stop a timer
140:      *
141:      * @param string $name name of the timer
142:      */
143:     public function stopTime($name = 'XOOPS')
144:     {
145:         if ($this->activated) {
146:             $this->logend[$name] = $this->microtime();
147:         }
148:     }
149: 
150:     /**
151:      * Log a database query
152:      *
153:      * @param string $sql   SQL string
154:      * @param string $error error message (if any)
155:      * @param int    $errno error number (if any)
156:      * @param null   $query_time
157:      */
158:     public function addQuery($sql, $error = null, $errno = null, $query_time = null)
159:     {
160:         if ($this->activated) {
161:             $this->queries[] = array('sql' => $sql, 'error' => $error, 'errno' => $errno, 'query_time' => $query_time);
162:         }
163:     }
164: 
165:     /**
166:      * Log display of a block
167:      *
168:      * @param string $name      name of the block
169:      * @param bool   $cached    was the block cached?
170:      * @param int    $cachetime cachetime of the block
171:      */
172:     public function addBlock($name, $cached = false, $cachetime = 0)
173:     {
174:         if ($this->activated) {
175:             $this->blocks[] = array('name' => $name, 'cached' => $cached, 'cachetime' => $cachetime);
176:         }
177:     }
178: 
179:     /**
180:      * Log extra information
181:      *
182:      * @param string $name name for the entry
183:      * @param int    $msg  text message for the entry
184:      */
185:     public function addExtra($name, $msg)
186:     {
187:         if ($this->activated) {
188:             $this->extra[] = array('name' => $name, 'msg' => $msg);
189:         }
190:     }
191: 
192:     /**
193:      * Log messages for deprecated functions
194:      *
195:      * @deprecated
196:      *
197:      * @param int $msg text message for the entry
198:      *
199:      */
200:     public function addDeprecated($msg)
201:     {
202:         if ($this->activated) {
203:             $this->deprecated[] = $msg;
204:         }
205:     }
206: 
207:     /**
208:      * Error handling callback (called by the zend engine)
209:      *
210:      * @param integer $errno
211:      * @param string  $errstr
212:      * @param string  $errfile
213:      * @param string  $errline
214:      */
215:     public function handleError($errno, $errstr, $errfile, $errline)
216:     {
217:         if ($this->activated && ($errno & error_reporting())) {
218:             // NOTE: we only store relative pathnames
219:             $this->errors[] = compact('errno', 'errstr', 'errfile', 'errline');
220:         }
221:         if ($errno == E_USER_ERROR) {
222:             $trace = true;
223:             if (substr($errstr, 0, '8') === 'notrace:') {
224:                 $trace  = false;
225:                 $errstr = substr($errstr, 8);
226:             }
227:             echo sprintf(_XOOPS_FATAL_MESSAGE, $errstr);
228:             if ($trace && function_exists('debug_backtrace')) {
229:                 echo "<div style='color:#f0f0f0;background-color:#f0f0f0;'>" . _XOOPS_FATAL_BACKTRACE . ':<br>';
230:                 $trace = debug_backtrace();
231:                 array_shift($trace);
232:                 foreach ($trace as $step) {
233:                     if (isset($step['file'])) {
234:                         echo $this->sanitizePath($step['file']);
235:                         echo ' (' . $step['line'] . ")\n<br>";
236:                     }
237:                 }
238:                 echo '</div>';
239:             }
240:             exit();
241:         }
242:     }
243: 
244:     /**
245:      * Exception handling callback.
246:      *
247:      * @param \Exception|\Throwable $e uncaught Exception or Error
248:      *
249:      * @return void
250:      */
251:     public function handleException($e)
252:     {
253:         if ($this->isThrowable($e)) {
254:             $msg = get_class($e) . ': ' . $e->getMessage();
255:             $this->handleError(E_USER_ERROR, $msg, $e->getFile(), $e->getLine());
256:         }
257:     }
258: 
259:     /**
260:      * Determine if an object implements Throwable (or is an Exception that would under PHP 7.)
261:      *
262:      * @param mixed $e Expected to be an object related to Exception or Throwable
263:      *
264:      * @return bool true if related to Throwable or Exception, otherwise false
265:      */
266:     protected function isThrowable($e)
267:     {
268:         $type = interface_exists('\Throwable', false) ? '\Throwable' : '\Exception';
269:         return $e instanceof $type;
270:     }
271: 
272:     /**
273:      *
274:      * @access protected
275:      *
276:      * @param string $path
277:      *
278:      * @return mixed|string
279:      */
280:     public function sanitizePath($path)
281:     {
282:         $path = str_replace(array('\\', XOOPS_ROOT_PATH, str_replace('\\', '/', realpath(XOOPS_ROOT_PATH))), array('/', '', ''), $path);
283: 
284:         return $path;
285:     }
286: 
287:     /**
288:      * Output buffering callback inserting logger dump in page output
289:      * @param $output
290:      * @return string
291:      */
292:     public function render($output)
293:     {
294:         global $xoopsUser;
295:         if (!$this->activated) {
296:             return $output;
297:         }
298: 
299:         $log                    = $this->dump($this->usePopup ? 'popup' : '');
300:         $this->renderingEnabled = $this->activated = false;
301:         $pattern                = '<!--{xo-logger-output}-->';
302:         $pos                    = strpos($output, $pattern);
303:         if ($pos !== false) {
304:             return substr($output, 0, $pos) . $log . substr($output, $pos + strlen($pattern));
305:         } else {
306:             return $output . $log;
307:         }
308:     }
309: 
310:     /**
311:      * *#@+
312:      *
313:      * @protected
314:      * @param string $mode
315:      * @return
316:      */
317:     public function dump($mode = '')
318:     {
319:         include XOOPS_ROOT_PATH . '/class/logger/render.php';
320: 
321:         return $ret;
322:     }
323: 
324:     /**
325:      * get the current execution time of a timer
326:      *
327:      * @param  string $name  name of the counter
328:      * @param  bool   $unset removes counter from global log
329:      * @return float  current execution time of the counter
330:      */
331:     public function dumpTime($name = 'XOOPS', $unset = false)
332:     {
333:         if (!$this->activated) {
334:             return null;
335:         }
336: 
337:         if (!isset($this->logstart[$name])) {
338:             return 0;
339:         }
340:         $stop  = isset($this->logend[$name]) ? $this->logend[$name] : $this->microtime();
341:         $start = $this->logstart[$name];
342: 
343:         if ($unset) {
344:             unset($this->logstart[$name]);
345:         }
346: 
347:         return $stop - $start;
348:     }
349: 
350:     /**
351:      * XoopsLogger::triggerError()
352:      *
353:      * @deprecated
354:      * @param  int     $errkey
355:      * @param  string  $errStr
356:      * @param  string  $errFile
357:      * @param  string  $errLine
358:      * @param  integer $errNo
359:      * @return void
360:      */
361:     public function triggerError($errkey = 0, $errStr = '', $errFile = '', $errLine = '', $errNo = 0)
362:     {
363:         $GLOBALS['xoopsLogger']->addDeprecated('\'$xoopsLogger->triggerError();\' is deprecated since XOOPS 2.5.4');
364: 
365:         if (!empty($errStr)) {
366:             $errStr = sprintf($errStr, $errkey);
367:         }
368:         $errFile = $this->sanitizePath($errFile);
369:         $this->handleError($errNo, $errStr, $errFile, $errLine);
370:     }
371: 
372:     /**
373:      * *#@+
374:      *
375:      * @deprecated
376:      */
377:     public function dumpAll()
378:     {
379:         $GLOBALS['xoopsLogger']->addDeprecated('\'$xoopsLogger->dumpAll();\' is deprecated since XOOPS 2.5.4, please use \'$xoopsLogger->dump(\'\');\' instead.');
380: 
381:         return $this->dump('');
382:     }
383: 
384:     /**
385:      * dnmp Blocks @deprecated
386:      *
387:      * @return dump
388:      */
389:     public function dumpBlocks()
390:     {
391:         $GLOBALS['xoopsLogger']->addDeprecated('\'$xoopsLogger->dumpBlocks();\' is deprecated since XOOPS 2.5.4, please use \'$xoopsLogger->dump(\'blocks\');\' instead.');
392: 
393:         return $this->dump('blocks');
394:     }
395: 
396:     /**
397:      * dumpExtra @deprecated
398:      *
399:      * @return dimp
400:      */
401:     public function dumpExtra()
402:     {
403:         $GLOBALS['xoopsLogger']->addDeprecated('\'$xoopsLogger->dumpExtra();\' is deprecated since XOOPS 2.5.4, please use \'$xoopsLogger->dump(\'extra\');\' instead.');
404: 
405:         return $this->dump('extra');
406:     }
407: 
408:     /**
409:      * dump Queries @deprecated
410:      *
411:      * @return unknown
412:      */
413:     public function dumpQueries()
414:     {
415:         $GLOBALS['xoopsLogger']->addDeprecated('\'$xoopsLogger->dumpQueries();\' is deprecated since XOOPS 2.5.4, please use \'$xoopsLogger->dump(\'queries\');\' instead.');
416: 
417:         return $this->dump('queries');
418:     }
419:     /**
420:      * *#@-
421:      */
422: }
423: 
424: /**
425:  * PHP Error handler
426:  *
427:  * NB: You're not supposed to call this function directly, if you don't understand why, then
428:  * you'd better spend some time reading your PHP manual before you hurt somebody
429:  *
430:  * @internal : Using a function and not calling the handler method directly because of old PHP versions
431:  * set_error_handler() have problems with the array( obj,methodname ) syntax
432:  * @param       $errNo
433:  * @param       $errStr
434:  * @param       $errFile
435:  * @param       $errLine
436:  * @param  null $errContext
437:  * @return bool
438:  */
439: function XoopsErrorHandler_HandleError($errNo, $errStr, $errFile, $errLine, $errContext = null)
440: {
441:     /*
442:     // We don't want every error to come through this will help speed things up'
443:     if ($errNo == '2048') {
444:         return true;
445:     }
446:     // XOOPS should always be STRICT compliant thus the above lines makes no sense and will be removed! -- Added by Taiwen Jiang
447:     */
448:     $logger = XoopsLogger::getInstance();
449:     $logger->handleError($errNo, $errStr, $errFile, $errLine, $errContext);
450:     return null;
451: }
452: 
API documentation generated by ApiGen