Overview

Namespaces

  • None
  • Xmf
    • Database
    • Module
      • Helper
    • Template
  • Xoops
    • Auth
    • Core
      • Cache
      • Database
        • Logging
        • Schema
      • Exception
      • Handler
        • Scheme
      • Kernel
        • Dtype
        • Handlers
        • Model
      • Lists
      • Locale
        • Punic
      • Service
        • Contract
      • Session
      • Text
        • Sanitizer
          • Extensions
      • Theme
        • Plugins
    • Form
    • Html
    • Locale
    • Module
      • Helper
      • Plugin

Classes

  • ArtObject
  • ArtObjectHandler
  • Avatars
  • AvatarsAvatar
  • AvatarsAvatar_userForm
  • AvatarsAvatarForm
  • AvatarsAvatarHandler
  • AvatarsLocale
  • AvatarsLocaleEn_US
  • AvatarsPreload
  • AvatarsProvider
  • AvatarsUserlink
  • AvatarsUserlinkHandler
  • AwesomeButton
  • BannerRender
  • Banners
  • BannersBanner
  • BannersBannerclient
  • BannersBannerclientForm
  • BannersBannerclientHandler
  • BannersBannerForm
  • BannersBannerHandler
  • BannersPreload
  • BloggerApi
  • CodexMenusPlugin
  • CodexSearchPlugin
  • CodexSystemPlugin
  • CodexUserconfigsPlugin
  • Comments
  • CommentsComment
  • CommentsCommentForm
  • CommentsCommentHandler
  • CommentsCommentRenderer
  • CommentsPreload
  • CommentsSystemPlugin
  • CommentsUserconfigsPlugin
  • Cookie
  • CountryFlagProvider
  • Criteria
  • CriteriaCompo
  • CriteriaElement
  • DebugbarLogger
  • DebugbarPreload
  • DebugbarUserconfigsPlugin
  • DefaultThemeLocale
  • DefaultThemeLocaleEn_US
  • FormDhtmlTextArea
  • FormTextArea
  • GravatarsPreload
  • GravatarsProvider
  • htmLawed
  • HtmlToPdfProvider
  • imageLib
  • Images
  • ImagesCategory
  • ImagesCategory_imagemanagerForm
  • ImagesCategoryForm
  • ImagesCategoryHandler
  • ImagesCategoryselectForm
  • ImagesImage
  • ImagesImage_Body
  • ImagesImage_imagemanagerForm
  • ImagesImagebody
  • ImagesImagebodyHandler
  • ImagesImageForm
  • ImagesImageHandler
  • ImagesPreload
  • JUpload
  • LegacyLogger
  • LoggerPreload
  • LoggerUserconfigsPlugin
  • Maintenance
  • MaintenanceMaintenanceForm
  • Menus
  • MenusBuilder
  • MenusConstantDecorator
  • MenusDecorator
  • MenusDecoratorAbstract
  • MenusDefaultDecorator
  • MenusDynamicDecorator
  • MenusMenu
  • MenusMenuHandler
  • MenusMenus
  • MenusMenus_menuForm
  • MenusMenus_menusForm
  • MenusMenusHandler
  • MenusPreload
  • MenusSmartyDecorator
  • MetaWeblogApi
  • MonologLogger
  • MonologPreload
  • MonologUserconfigsPlugin
  • MovableTypeApi
  • MyTextSanitizer
  • MyTextSanitizerExtended
  • Notifications
  • NotificationsNotification
  • NotificationsNotificationHandler
  • NotificationsPreload
  • NotificationsSystemPlugin
  • Page
  • PageCommentsPlugin
  • PageGroupPermHandler
  • PageLocale
  • PageLocaleEn_US
  • PageNotificationsPlugin
  • PagePage_content
  • PagePage_contentForm
  • PagePage_contentHandler
  • PagePage_rating
  • PagePage_ratingHandler
  • PagePage_related
  • PagePage_related_link
  • PagePage_related_linkHandler
  • PagePage_relatedForm
  • PagePage_relatedHandler
  • PagePreload
  • PageSearchPlugin
  • PageSystemPlugin
  • PdfPreload
  • PmMessage
  • PmMessageHandler
  • PmPreload
  • ProfileCategory
  • ProfileCategoryForm
  • ProfileCategoryHandler
  • ProfileCorePreload
  • ProfileField
  • ProfileFieldForm
  • ProfileFieldHandler
  • ProfileMenusPlugin
  • ProfileProfile
  • ProfileProfileHandler
  • ProfileRegstep
  • ProfileRegstepForm
  • 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_need_multibyte
  • protector_postcommon_post_register_moratorium
  • protector_postcommon_register_insert_js_check
  • 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
  • ProtectorCenterForm
  • ProtectorCorePreload
  • ProtectorFilterAbstract
  • ProtectorFilterHandler
  • ProtectorMySQLDatabase
  • Publisher
  • PublisherBlockForm
  • PublisherCategory
  • PublisherCategoryForm
  • PublisherCategoryHandler
  • PublisherCommentsPlugin
  • PublisherFile
  • PublisherFileForm
  • PublisherFileHandler
  • PublisherFormDateTime
  • PublisherGroupPermHandler
  • PublisherItem
  • PublisherItemForm
  • PublisherItemHandler
  • PublisherMenusPlugin
  • PublisherMetagen
  • PublisherMimetype
  • PublisherMimetypeHandler
  • PublisherNotificationsPlugin
  • PublisherPermissionHandler
  • PublisherPreload
  • PublisherRating
  • PublisherRatingHandler
  • PublisherSearchPlugin
  • PublisherSystemPlugin
  • PublisherUtils
  • QrcodePreload
  • QrcodeProvider
  • 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
  • Search
  • SearchPreload
  • SearchSearchForm
  • Smarty_Resource_Admin
  • Smarty_Resource_Block
  • Smarty_Resource_Db
  • Smarty_Resource_Module
  • Smilies
  • SmiliesPreload
  • SmiliesProvider
  • SmiliesSmiley
  • SmiliesSmileyHandler
  • SmiliesSmiliesForm
  • Snoopy
  • SqlUtility
  • System
  • SystemBlockForm
  • SystemBreadcrumb
  • SystemExtension
  • SystemGroupForm
  • SystemLocale
  • SystemLocaleEn_US
  • SystemMenuHandler
  • SystemModule
  • SystemPreferencesForm
  • SystemPreload
  • SystemUserForm
  • tar
  • ThemeSetAuthorHandler
  • ThemeSetDateCreatedHandler
  • ThemeSetDescriptionHandler
  • ThemeSetEmailHandler
  • ThemeSetFileTypeHandler
  • ThemeSetGeneratorHandler
  • ThemeSetImageHandler
  • ThemeSetLinkHandler
  • ThemeSetModuleHandler
  • ThemeSetNameHandler
  • ThemeSetTagHandler
  • ThemeSetTemplateHandler
  • Thumbs
  • ThumbsPreload
  • ThumbsProvider
  • TinyMCE
  • Userconfigs
  • UserconfigsConfigHandler
  • UserconfigsConfigsForm
  • UserconfigsItem
  • UserconfigsItemHandler
  • UserconfigsMenusPlugin
  • UserconfigsModulesForm
  • UserconfigsOption
  • UserconfigsOptionHandler
  • UserconfigsPreload
  • UserconfigsSystemPlugin
  • UserrankPreload
  • UserRankProvider
  • UserrankRank
  • UserrankRankHandler
  • UserrankRanksForm
  • Xcaptcha
  • XcaptchaCaptchaForm
  • XcaptchaImage
  • XcaptchaImageForm
  • XcaptchaRecaptcha
  • XcaptchaRecaptchaForm
  • XcaptchaText
  • XcaptchaTextForm
  • Xlanguage
  • XlanguageLanguage
  • XlanguageLanguageForm
  • XlanguagePreload
  • XlanguageTinymceForm
  • XlanguageXlanguageHandler
  • Xmf\Database\TableLoad
  • Xmf\Database\Tables
  • Xmf\Debug
  • Xmf\FilterInput
  • Xmf\Highlighter
  • Xmf\Language
  • Xmf\Loader
  • Xmf\Metagen
  • Xmf\Module\Admin
  • Xmf\Module\Cache
  • Xmf\Module\Helper
  • Xmf\Module\Helper\AbstractHelper
  • Xmf\Module\Helper\GenericHelper
  • Xmf\Module\Permission
  • Xmf\Module\Session
  • Xmf\Request
  • Xmf\Template\AbstractTemplate
  • Xmf\Template\Breadcrumb
  • Xmf\Template\Buttonbox
  • Xmf\Template\Feed
  • Xmf\Template\PrintContent
  • Xmf\Utilities
  • Xmf\Yaml
  • XmfPreload
  • XmlTagHandler
  • Xoops
  • Xoops\Auth\Ads
  • Xoops\Auth\AuthAbstract
  • Xoops\Auth\Factory
  • Xoops\Auth\Ldap
  • Xoops\Auth\Provisioning
  • Xoops\Auth\Xoops
  • Xoops\Cache
  • Xoops\Core\Assets
  • Xoops\Core\Cache\Access
  • Xoops\Core\Cache\CacheManager
  • Xoops\Core\Cache\DriverList
  • Xoops\Core\Cache\Legacy
  • Xoops\Core\ComposerUtility
  • Xoops\Core\Database\Connection
  • Xoops\Core\Database\Factory
  • Xoops\Core\Database\Logging\XoopsDebugStack
  • Xoops\Core\Database\QueryBuilder
  • Xoops\Core\Database\Schema\ExportVisitor
  • Xoops\Core\Database\Schema\ImportSchema
  • Xoops\Core\Database\Schema\PrefixStripper
  • Xoops\Core\Database\Schema\RemovePrefixes
  • Xoops\Core\Events
  • Xoops\Core\FilterInput
  • Xoops\Core\FixedGroups
  • Xoops\Core\Handler\Factory
  • Xoops\Core\Handler\FactorySpec
  • Xoops\Core\Handler\Scheme\FQN
  • Xoops\Core\Handler\Scheme\Kernel
  • Xoops\Core\Handler\Scheme\LegacyModule
  • Xoops\Core\HttpRequest
  • Xoops\Core\Kernel\Criteria
  • Xoops\Core\Kernel\CriteriaCompo
  • Xoops\Core\Kernel\CriteriaElement
  • Xoops\Core\Kernel\Dtype
  • Xoops\Core\Kernel\Dtype\DtypeAbstract
  • Xoops\Core\Kernel\Dtype\DtypeArray
  • Xoops\Core\Kernel\Dtype\DtypeDateTime
  • Xoops\Core\Kernel\Dtype\DtypeDecimal
  • Xoops\Core\Kernel\Dtype\DtypeEmail
  • Xoops\Core\Kernel\Dtype\DtypeEnumeration
  • Xoops\Core\Kernel\Dtype\DtypeFloat
  • Xoops\Core\Kernel\Dtype\DtypeInt
  • Xoops\Core\Kernel\Dtype\DtypeJson
  • Xoops\Core\Kernel\Dtype\DtypeMoney
  • Xoops\Core\Kernel\Dtype\DtypeOther
  • Xoops\Core\Kernel\Dtype\DtypeSimpleTime
  • Xoops\Core\Kernel\Dtype\DtypeSource
  • Xoops\Core\Kernel\Dtype\DtypeTextArea
  • Xoops\Core\Kernel\Dtype\DtypeTextBox
  • Xoops\Core\Kernel\Dtype\DtypeTimeZone
  • Xoops\Core\Kernel\Dtype\DtypeUrl
  • Xoops\Core\Kernel\Handlers\XoopsBlock
  • Xoops\Core\Kernel\Handlers\XoopsBlockHandler
  • Xoops\Core\Kernel\Handlers\XoopsBlockModuleLink
  • Xoops\Core\Kernel\Handlers\XoopsBlockModuleLinkHandler
  • Xoops\Core\Kernel\Handlers\XoopsConfigHandler
  • Xoops\Core\Kernel\Handlers\XoopsConfigItem
  • Xoops\Core\Kernel\Handlers\XoopsConfigItemHandler
  • Xoops\Core\Kernel\Handlers\XoopsConfigOption
  • Xoops\Core\Kernel\Handlers\XoopsConfigOptionHandler
  • Xoops\Core\Kernel\Handlers\XoopsGroup
  • Xoops\Core\Kernel\Handlers\XoopsGroupHandler
  • Xoops\Core\Kernel\Handlers\XoopsGroupPerm
  • Xoops\Core\Kernel\Handlers\XoopsGroupPermHandler
  • Xoops\Core\Kernel\Handlers\XoopsMemberHandler
  • Xoops\Core\Kernel\Handlers\XoopsMembership
  • Xoops\Core\Kernel\Handlers\XoopsMembershipHandler
  • Xoops\Core\Kernel\Handlers\XoopsModule
  • Xoops\Core\Kernel\Handlers\XoopsModuleHandler
  • Xoops\Core\Kernel\Handlers\XoopsOnline
  • Xoops\Core\Kernel\Handlers\XoopsOnlineHandler
  • Xoops\Core\Kernel\Handlers\XoopsPrivateMessage
  • Xoops\Core\Kernel\Handlers\XoopsPrivateMessageHandler
  • Xoops\Core\Kernel\Handlers\XoopsTplFile
  • Xoops\Core\Kernel\Handlers\XoopsTplFileHandler
  • Xoops\Core\Kernel\Handlers\XoopsTplSet
  • Xoops\Core\Kernel\Handlers\XoopsTplSetHandler
  • Xoops\Core\Kernel\Handlers\XoopsUser
  • Xoops\Core\Kernel\Handlers\XoopsUserHandler
  • Xoops\Core\Kernel\Model\Joint
  • Xoops\Core\Kernel\Model\Read
  • Xoops\Core\Kernel\Model\Stats
  • Xoops\Core\Kernel\Model\Sync
  • Xoops\Core\Kernel\Model\Write
  • Xoops\Core\Kernel\XoopsModelAbstract
  • Xoops\Core\Kernel\XoopsModelFactory
  • Xoops\Core\Kernel\XoopsObject
  • Xoops\Core\Kernel\XoopsObjectHandler
  • Xoops\Core\Kernel\XoopsPersistableObjectHandler
  • Xoops\Core\Lists\Country
  • Xoops\Core\Lists\Directory
  • Xoops\Core\Lists\Editor
  • Xoops\Core\Lists\File
  • Xoops\Core\Lists\HtmlFile
  • Xoops\Core\Lists\ImageFile
  • Xoops\Core\Lists\ListAbstract
  • Xoops\Core\Lists\Locale
  • Xoops\Core\Lists\Module
  • Xoops\Core\Lists\Month
  • Xoops\Core\Lists\SubjectIcon
  • Xoops\Core\Lists\SubSet
  • Xoops\Core\Lists\Theme
  • Xoops\Core\Lists\Time
  • Xoops\Core\Lists\TimeZone
  • Xoops\Core\Locale\LegacyCodes
  • Xoops\Core\Locale\Punic\Calendar
  • Xoops\Core\Locale\Time
  • Xoops\Core\Logger
  • Xoops\Core\MediaUploader
  • Xoops\Core\MimeTypes
  • Xoops\Core\PreloadItem
  • Xoops\Core\Psr0ClassLoader
  • Xoops\Core\Psr4ClassLoader
  • Xoops\Core\Random
  • Xoops\Core\Registry
  • Xoops\Core\Request
  • Xoops\Core\Security
  • Xoops\Core\Service\AbstractContract
  • Xoops\Core\Service\Manager
  • Xoops\Core\Service\NullProvider
  • Xoops\Core\Service\Provider
  • Xoops\Core\Service\Response
  • Xoops\Core\Session\Fingerprint
  • Xoops\Core\Session\Handler
  • Xoops\Core\Session\Manager
  • Xoops\Core\Session\RememberMe
  • Xoops\Core\Session\SessionUser
  • Xoops\Core\Text\Sanitizer
  • Xoops\Core\Text\Sanitizer\Configuration
  • Xoops\Core\Text\Sanitizer\ConfigurationAbstract
  • Xoops\Core\Text\Sanitizer\DefaultConfiguration
  • Xoops\Core\Text\Sanitizer\ExtensionAbstract
  • Xoops\Core\Text\Sanitizer\Extensions\Censor
  • Xoops\Core\Text\Sanitizer\Extensions\Clickable
  • Xoops\Core\Text\Sanitizer\Extensions\Embed
  • Xoops\Core\Text\Sanitizer\Extensions\Flash
  • Xoops\Core\Text\Sanitizer\Extensions\Iframe
  • Xoops\Core\Text\Sanitizer\Extensions\Image
  • Xoops\Core\Text\Sanitizer\Extensions\Mms
  • Xoops\Core\Text\Sanitizer\Extensions\Mp3
  • Xoops\Core\Text\Sanitizer\Extensions\Quote
  • Xoops\Core\Text\Sanitizer\Extensions\Rtsp
  • Xoops\Core\Text\Sanitizer\Extensions\SoundCloud
  • Xoops\Core\Text\Sanitizer\Extensions\SyntaxHighlight
  • Xoops\Core\Text\Sanitizer\Extensions\TextFilter
  • Xoops\Core\Text\Sanitizer\Extensions\UnorderedList
  • Xoops\Core\Text\Sanitizer\Extensions\Wiki
  • Xoops\Core\Text\Sanitizer\Extensions\Wmp
  • Xoops\Core\Text\Sanitizer\Extensions\XoopsCode
  • Xoops\Core\Text\Sanitizer\Extensions\Xss
  • Xoops\Core\Text\Sanitizer\Extensions\YouTube
  • Xoops\Core\Text\Sanitizer\FilterAbstract
  • Xoops\Core\Text\Sanitizer\NullExtension
  • Xoops\Core\Text\Sanitizer\NullFilter
  • Xoops\Core\Text\Sanitizer\SanitizerComponent
  • Xoops\Core\Text\Sanitizer\SanitizerConfigurable
  • Xoops\Core\Text\ShortCodes
  • Xoops\Core\Theme\AdminFactory
  • Xoops\Core\Theme\Factory
  • Xoops\Core\Theme\NullTheme
  • Xoops\Core\Theme\PluginAbstract
  • Xoops\Core\Theme\Plugins\Blocks
  • Xoops\Core\Theme\XoopsTheme
  • Xoops\Core\XoopsTpl
  • Xoops\Core\Yaml
  • Xoops\Form\BlockForm
  • Xoops\Form\Button
  • Xoops\Form\ButtonTray
  • Xoops\Form\Captcha
  • Xoops\Form\Checkbox
  • Xoops\Form\ColorPicker
  • Xoops\Form\DateSelect
  • Xoops\Form\DateTime
  • Xoops\Form\DhtmlTextArea
  • Xoops\Form\Editor
  • Xoops\Form\Element
  • Xoops\Form\ElementFactory
  • Xoops\Form\ElementTray
  • Xoops\Form\File
  • Xoops\Form\Form
  • Xoops\Form\GroupCheckbox
  • Xoops\Form\GroupFormCheckbox
  • Xoops\Form\GroupPermissionForm
  • Xoops\Form\Hidden
  • Xoops\Form\Label
  • Xoops\Form\Mail
  • Xoops\Form\OptionElement
  • Xoops\Form\Password
  • Xoops\Form\Radio
  • Xoops\Form\RadioYesNo
  • Xoops\Form\Raw
  • Xoops\Form\Select
  • Xoops\Form\SelectCountry
  • Xoops\Form\SelectEditor
  • Xoops\Form\SelectGroup
  • Xoops\Form\SelectLanguage
  • Xoops\Form\SelectLocale
  • Xoops\Form\SelectMatchOption
  • Xoops\Form\SelectTheme
  • Xoops\Form\SelectTimeZone
  • Xoops\Form\SelectUser
  • Xoops\Form\SimpleForm
  • Xoops\Form\Tab
  • Xoops\Form\TableForm
  • Xoops\Form\TabTray
  • Xoops\Form\Text
  • Xoops\Form\TextArea
  • Xoops\Form\ThemeForm
  • Xoops\Form\Token
  • Xoops\Form\Url
  • Xoops\Html\Attributes
  • Xoops\Html\Img
  • Xoops\Locale
  • Xoops\Locale\AbstractLocale
  • Xoops\Module\Admin
  • Xoops\Module\Helper
  • Xoops\Module\Helper\Dummy
  • Xoops\Module\Helper\HelperAbstract
  • Xoops\Module\Plugin
  • Xoops\Module\Plugin\ConfigCollector
  • Xoops\Module\Plugin\PluginAbstract
  • Xoops\Utils
  • Xoops_Locale_Mailer_Abstract
  • XoopsAdminThemeFactory
  • XoopsApi
  • XoopsArt
  • XoopsBaseConfig
  • XoopsBlock
  • XoopsBlockHandler
  • XoopsBlockmodulelink
  • XoopsBlockmodulelinkHandler
  • XoopsCache
  • XoopsCaptcha
  • XoopsCaptchaImage
  • XoopsCaptchaImageHandler
  • XoopsCaptchaMethod
  • XoopsCaptchaRecaptcha
  • XoopsCaptchaText
  • XoopsConfigHandler
  • XoopsConfigItem
  • XoopsConfigItemHandler
  • XoopsConfigOption
  • XoopsConfigOptionHandler
  • XoopsDatabase
  • XoopsDatabaseFactory
  • XoopsDatabaseManager
  • XoopsDownloader
  • XoopsEditor
  • XoopsEditorHandler
  • XoopsFile
  • XoopsFileHandler
  • XoopsFilterInput
  • XoopsFolderHandler
  • XoopsForm
  • XoopsFormButton
  • XoopsFormButtonTray
  • XoopsFormCaptcha
  • XoopsFormCheckBox
  • XoopsFormColorPicker
  • XoopsFormDateTime
  • XoopsFormDhtmlTextArea
  • XoopsFormEditor
  • XoopsFormElement
  • XoopsFormElementTray
  • XoopsFormFile
  • XoopsFormHidden
  • XoopsFormHiddenToken
  • XoopsFormLabel
  • XoopsFormPassword
  • XoopsFormRadio
  • XoopsFormRadioYN
  • XoopsFormSelect
  • XoopsFormSelectCheckGroup
  • XoopsFormSelectCountry
  • XoopsFormSelectEditor
  • XoopsFormSelectGroup
  • XoopsFormSelectLang
  • XoopsFormSelectMatchOption
  • XoopsFormSelectTheme
  • XoopsFormSelectTimezone
  • XoopsFormSelectUser
  • XoopsFormText
  • XoopsFormTextArea
  • XoopsFormTextDateSelect
  • XoopsFormTinymce
  • XoopsFormTinymce4
  • XoopsGroup
  • XoopsGroupHandler
  • XoopsGroupPerm
  • XoopsGroupPermForm
  • XoopsGroupPermHandler
  • XoopsGTicket
  • XoopsGuiDefault
  • XoopsInstallWizard
  • XoopsLists
  • XoopsLoad
  • XoopsLocal
  • XoopsLocale
  • XoopsLocaleEn_US
  • XoopsLogger
  • XoopsMailer
  • XoopsMailerLocal
  • XoopsMailerLocale
  • XoopsMediaUploader
  • XoopsMemberHandler
  • XoopsMembership
  • XoopsMembershipHandler
  • XoopsModule
  • XoopsModuleHandler
  • XoopsMultiMailer
  • XoopsMySQLDatabase
  • XoopsMySQLDatabaseProxy
  • XoopsMySQLDatabaseSafe
  • XoopsObject
  • XoopsObjectHandler
  • XoopsObjectTree
  • XoopsOnline
  • XoopsOnlineHandler
  • XoopsPageNav
  • XoopsPathController
  • XoopsPersistableObjectHandler
  • XoopsPreload
  • XoopsPreloadItem
  • XoopsPrivmessage
  • XoopsPrivmessageHandler
  • XoopsRequest
  • XoopsSecurity
  • XoopsSimpleForm
  • XoopsTableForm
  • XoopsTarDownloader
  • XoopsTheme
  • XoopsThemeBlocksPlugin
  • XoopsThemeFactory
  • XoopsThemeForm
  • XoopsThemePlugin
  • XoopsThemeSetParser
  • XoopsTpl
  • XoopsTplfile
  • XoopsTplfileHandler
  • XoopsTplset
  • XoopsTplsetHandler
  • XoopsUser
  • XoopsUserHandler
  • XoopsUserUtility
  • XoopsUtility
  • XoopsXmlRpcApi
  • XoopsXmlRpcArray
  • XoopsXmlRpcBase64
  • XoopsXmlRpcBoolean
  • XoopsXmlRpcDatetime
  • XoopsXmlRpcDocument
  • XoopsXmlRpcDouble
  • XoopsXmlRpcFault
  • XoopsXmlRpcInt
  • XoopsXmlRpcParser
  • XoopsXmlRpcRequest
  • XoopsXmlRpcResponse
  • XoopsXmlRpcString
  • XoopsXmlRpcStruct
  • XoopsXmlRpcTag
  • XoopsXmlRss2Parser
  • XoopsZipDownloader
  • zipfile

Interfaces

  • CommentsPluginInterface
  • MenusDecoratorInterface
  • MenusPluginInterface
  • NotificationsPluginInterface
  • SearchPluginInterface
  • SystemPluginInterface
  • UserconfigsPluginInterface
  • Xoops\Core\AttributeInterface
  • Xoops\Core\Handler\Scheme\SchemeInterface
  • Xoops\Core\Service\Contract\AvatarInterface
  • Xoops\Core\Service\Contract\CountryflagInterface
  • Xoops\Core\Service\Contract\EmojiInterface
  • Xoops\Core\Service\Contract\HtmlToPdfInterface
  • Xoops\Core\Service\Contract\QrcodeInterface
  • Xoops\Core\Service\Contract\ThumbnailInterface
  • Xoops\Core\Service\Contract\UserRankInterface
  • Xoops\Core\Session\FingerprintInterface
  • Xoops\Form\ContainerInterface

Exceptions

  • Xoops\Core\Exception\InvalidHandlerSpecException
  • Xoops\Core\Exception\NoHandlerException

Functions

  • _changeMimeValue
  • _clearAddSessionVars
  • _clearEditSessionVars
  • _ee
  • _recaptcha_aes_encrypt
  • _recaptcha_aes_pad
  • _recaptcha_http_post
  • _recaptcha_mailhide_email_parts
  • _recaptcha_mailhide_urlbase64
  • _recaptcha_qsencode
  • _tt
  • add
  • addCriteria
  • admin_refcheck
  • b_comments_edit
  • b_comments_show
  • b_notification_show
  • b_search_show
  • b_system_info_edit
  • b_system_info_show
  • b_system_login_show
  • b_system_main_edit
  • b_system_main_show
  • b_system_newmembers_edit
  • b_system_newmembers_show
  • b_system_online_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
  • b_xlanguage_select_edit
  • b_xlanguage_select_show
  • banners_blocks_edit
  • banners_blocks_show
  • base_url
  • buildRssFeedCache
  • buildTable
  • check_files_extensions_on_path
  • check_files_extensions_on_phar
  • checkEmail
  • clearAddSession
  • clearEditSession
  • config_loading
  • create_folder
  • create_img
  • create_img_gd
  • createConfigform
  • createDir
  • createThemeform
  • dateSort
  • debugger
  • delete
  • deleteDir
  • duplicate_file
  • edit
  • endsWith
  • exception_handler
  • extensionSort
  • file_put_contents
  • filenameSort
  • filescount
  • fix_dirname
  • fix_filename
  • fix_get_params
  • fix_path
  • fix_strtolower
  • fix_strtoupper
  • foldersize
  • formatTimestamp
  • formatURL
  • genPathCheckHtml
  • get_file_by_url
  • get_writeoks_from_protector
  • getBrightness
  • getDbConnection
  • getDbConnectionParams
  • getDirList
  • handle_uploaded_files
  • http_response_code
  • image_check_memory_usage
  • install_acceptUser
  • install_finalize
  • installHtmlSpecialCharacters
  • is_function_callable
  • is_really_writable
  • load_functions
  • load_object
  • load_objectHandler
  • loadModuleAdminMenu
  • makeSize
  • manage
  • menus_block_edit
  • menus_block_show
  • menus_mainmenu_show
  • 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_getMysqlVersion
  • mod_isModuleAction
  • mod_loadCacheFile
  • mod_loadCacheFile_byGroup
  • mod_loadConfg
  • mod_loadConfig
  • mod_loadFile
  • mod_loadFunctions
  • mod_loadRenderer
  • mod_message
  • modify_chmod
  • new_thumbnails_creation
  • normalizeColor
  • page_blocks_edit
  • page_blocks_show
  • profile_getRegisterForm
  • profile_getUserForm
  • profile_install_addCategory
  • profile_install_addField
  • profile_install_addStep
  • profile_install_initializeProfiles
  • profile_install_setPermissions
  • protector_ip_cmp
  • protector_postcheck
  • protector_precheck
  • publisher_category_items_sel_edit
  • publisher_category_items_sel_show
  • publisher_cloneFileFolder
  • publisher_createLogo
  • publisher_date_to_date_edit
  • publisher_date_to_date_show
  • publisher_displayCategory
  • publisher_editCat
  • publisher_editFile
  • publisher_editItem
  • publisher_items_columns_edit
  • publisher_items_columns_show
  • publisher_items_menu_edit
  • publisher_items_menu_show
  • publisher_items_new_edit
  • publisher_items_new_show
  • publisher_items_random_item_show
  • publisher_items_recent_edit
  • publisher_items_recent_show
  • publisher_items_spot_edit
  • publisher_items_spot_show
  • publisher_latest_files_edit
  • publisher_latest_files_show
  • publisher_latest_news_edit
  • publisher_latest_news_show
  • publisher_mk_chkbox
  • publisher_mk_select
  • publisher_pagewrap_upload
  • publisher_search
  • publisher_search_show
  • publisher_tag_iteminfo
  • publisher_tag_synchronization
  • rcopy
  • recaptcha_check_answer
  • recaptcha_get_html
  • recaptcha_get_signup_url
  • recaptcha_mailhide_html
  • recaptcha_mailhide_url
  • redirect_header
  • rename_file
  • rename_folder
  • rrename
  • rrename_after_cleaner
  • search
  • sizeSort
  • smarty_block_assets
  • smarty_block_noshortcodes
  • smarty_compiler_xoAdminIcons
  • smarty_compiler_xoAdminNav
  • smarty_compiler_xoAppUrl
  • smarty_compiler_xoImgUrl
  • smarty_compiler_xoModuleIcons16
  • smarty_compiler_xoModuleIcons32
  • smarty_compiler_xoModuleIconsBookmarks
  • smarty_function_addBaseScript
  • smarty_function_addBaseStylesheet
  • smarty_function_securityToken
  • smarty_function_thumbnail
  • smarty_function_translate
  • smarty_function_translateTheme
  • smarty_function_xoblock
  • smarty_function_xoInboxCount
  • smarty_function_xoMemberInfo
  • smarty_function_xoops_link
  • smarty_function_xoPageNav
  • smarty_modifier_datetime
  • smarty_modifier_debug_print_var
  • smarty_outputfilter_shortcodes
  • synchronize
  • system_AdminIcons
  • system_adminVersion
  • system_cleanVars
  • system_loadLanguage
  • system_loadTemplate
  • updateMimeValue
  • userTimeToServerTime
  • xhtmlspecialchars
  • xlanguage_convert_encoding
  • xlanguage_convert_item
  • xlanguage_copyfile
  • xlanguage_detectLang
  • xlanguage_encoding
  • xlanguage_lang_detect
  • xlanguage_mkdirs
  • xlanguage_ml
  • xlanguage_ml_escape_bracket
  • xlanguage_select_show
  • xoBoolField
  • xoDiag
  • xoDiagBoolSetting
  • xoDiagIfWritable
  • xoFormField
  • xoops_comment_count
  • xoops_comment_delete
  • xoops_confirm
  • 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_getMailer
  • xoops_getModuleHandler
  • xoops_getModuleOption
  • xoops_getOption
  • xoops_getrank
  • xoops_getUrlDomain
  • xoops_getUserTimestamp
  • xoops_groupperm_deletebymoditem
  • xoops_header
  • xoops_isActiveModule
  • xoops_load
  • xoops_loadLanguage
  • xoops_makepass
  • xoops_message
  • xoops_module_install_avatars
  • xoops_module_install_banners
  • xoops_module_install_comments
  • xoops_module_install_debugbar
  • xoops_module_install_notifications
  • xoops_module_install_page
  • xoops_module_install_pm
  • xoops_module_install_profile
  • xoops_module_install_publisher
  • xoops_module_install_smilies
  • xoops_module_install_system
  • xoops_module_install_userrank
  • xoops_module_install_xlanguage
  • xoops_module_pre_uninstall_comments
  • xoops_module_pre_uninstall_notifications
  • xoops_module_update_comments
  • xoops_module_update_debugbar
  • xoops_module_update_notifications
  • xoops_module_update_pm
  • xoops_module_update_profile
  • xoops_module_update_publisher
  • xoops_module_update_search
  • xoops_module_update_system
  • xoops_module_update_xlanguage
  • xoops_notification_deletebyitem
  • xoops_notification_deletebymodule
  • xoops_notification_deletebyuser
  • xoops_result
  • xoops_setActiveModules
  • xoops_setConfigOption
  • xoops_substr
  • xoops_template_clear_module_cache
  • xoops_template_touch
  • xoops_trim
  • xoops_utf8_encode
  • xoopseditor_get_rootpath
  • xoPassField
  • xoPhpVersion
  • Overview
  • Namespace
  • Class
  • Tree
  1: <?php
  2: /*
  3:  You may not change or alter any portion of this comment or credits
  4:  of supporting developers from this source code or any supporting source code
  5:  which is considered copyrighted (c) material of the original comment or credit authors.
  6: 
  7:  This program is distributed in the hope that it will be useful,
  8:  but WITHOUT ANY WARRANTY; without even the implied warranty of
  9:  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 10: */
 11: 
 12: use Psr\Log\LoggerInterface;
 13: use Psr\Log\LogLevel;
 14: use Xoops\Core\Logger;
 15: 
 16: /**
 17:  * Collects information for a page request
 18:  * Records information about database queries, blocks, and execution time
 19:  * and can display it as HTML. It also catches php runtime errors.
 20:  *
 21:  * @category  Logger
 22:  * @package   Logger
 23:  * @author    trabis <lusopoemas@gmail.com>
 24:  * @author    Richard Griffith <richard@geekwright.com>
 25:  * @copyright 2013 XOOPS Project (http://xoops.org)
 26:  * @license   GNU GPL 2 or later (http://www.gnu.org/licenses/gpl-2.0.html)
 27:  * @version   Release: 1.0
 28:  * @link      http://xoops.org
 29:  * @since     1.0
 30:  */
 31: class LegacyLogger implements LoggerInterface
 32: {
 33:     /**
 34:      * @var $queries array of query log lines
 35:      */
 36:     protected $queries = array();
 37: 
 38:     /**
 39:      * @var $blocks array of block log lines
 40:      */
 41:     protected $blocks = array();
 42: 
 43:     /**
 44:      * @var $extra array of extra log lines
 45:      */
 46:     protected $extra = array();
 47: 
 48:     /**
 49:      * @var start time information by name
 50:      */
 51:     protected $logstart = array();
 52: 
 53:     /**
 54:      * @var end time information by name
 55:      */
 56:     protected $logend = array();
 57: 
 58:     /**
 59:      * @var $errors array of error log lines
 60:      */
 61:     protected $errors = array();
 62: 
 63:     /**
 64:      * @var $deprecated array of deprecated log lines
 65:      */
 66:     protected $deprecated = array();
 67: 
 68:     /**
 69:      * @var true if rendering enables
 70:      */
 71:     protected $renderingEnabled = false;
 72: 
 73:     /**
 74:      * @var true is logging is activated
 75:      */
 76:     protected $activated = false;
 77: 
 78:     /**
 79:      * @var mixed boolean false if configs no set or read, array of module/user configs
 80:      */
 81:     protected $configs = false;
 82: 
 83:     /**
 84:      * constructor
 85:      */
 86:     public function __construct()
 87:     {
 88:         Logger::getInstance()->addLogger($this);
 89:     }
 90: 
 91:     /**
 92:      * @var true if rendering enables
 93:      */
 94:     protected $usePopup = false;
 95: 
 96: 
 97:     /**
 98:      * Get a reference to the only instance of this class
 99:      *
100:      * @return  object LoggerAbstract  reference to the only instance
101:      */
102:     public static function getInstance()
103:     {
104:         static $instance;
105:         if (!isset($instance)) {
106:             $class = __CLASS__;
107:             $instance = new $class();
108:         }
109: 
110:         return $instance;
111:     }
112: 
113:     /**
114:      * Save a copy of our config array
115:      * 
116:      * @param array $configs array of module/user config options
117:      * 
118:      * @return void
119:      */
120:     public function setConfigs($configs)
121:     {
122:         $this->configs = $configs;
123:     }
124: 
125:     /**
126:      * disable logging
127:      * 
128:      * @return void
129:      */
130:     public function disable()
131:     {
132:         //error_reporting(0);
133:         $this->activated = false;
134:     }
135: 
136:     /**
137:      * Enable logger output rendering
138:      * When output rendering is enabled, the logger will insert its output within the page content.
139:      * If the string <!--{xo-logger-output}--> is found in the page content, the logger output will
140:      * replace it, otherwise it will be inserted after all the page output.
141:      * 
142:      * @return void
143:      */
144:     public function enable()
145:     {
146:         error_reporting(E_ALL | E_STRICT);
147:         $xoops = Xoops::getInstance();
148:         if ($this->configs && array_key_exists('logger_enable', $this->configs)) {
149:             if ($this->configs['logger_popup']) {
150:                 $this->usePopup = true;
151:             }
152:         }
153:         $this->activated = true;
154:         $this->enableRendering();
155:     }
156: 
157:     /**
158:      * report enabled status
159:      * 
160:      * @return bool
161:      */
162:     public function isEnable()
163:     {
164:         return $this->activated;
165:     }
166: 
167:     /**
168:      * disable output for the benefit of ajax scripts
169:      * 
170:      * @return void
171:      */
172:     public function quiet()
173:     {
174:         $this->activated = false;
175:     }
176: 
177:     /**
178:      * Add our resources to the theme as soon as it is available, otherwise return
179:      * 
180:      * @return void
181:      */
182:     private function addToTheme()
183:     {
184:         static $addedResource = false;
185: 
186:         if ($this->activated && !$addedResource) {
187:             if (isset($GLOBALS['xoTheme'])) {
188:                 /*
189:                 $xoops = Xoops::getInstance();
190:                 $head = '</style>' . $this->renderer->renderHead()
191:                     . '<style>.icon-tags:before { content: ""; width: 16px; background-position: -25px -48px;}';
192:                 $xoops->theme()->addStylesheet(null, null, $head);
193:                 */
194:                 $addedResource = true;
195:             }
196:         }
197:     }
198: 
199:     /**
200:      * Start a timer
201:      *
202:      * @param string $name name of the timer
203:      * 
204:      * @return void
205:      */
206:     public function startTime($name = 'XOOPS')
207:     {
208:         if ($this->activated) {
209:             $this->logstart[$name] = microtime(true);
210:         }
211:     }
212: 
213:     /**
214:      * Stop a timer
215:      *
216:      * @param string $name name of the timer
217:      * 
218:      * @return void
219:      */
220:     public function stopTime($name = 'XOOPS')
221:     {
222:         if ($this->activated) {
223:             $this->logend[$name] = microtime(true);
224:         }
225:     }
226: 
227:     /**
228:      * Log a database query
229:      *
230:      * @param string $sql        sql that was processed
231:      * @param string $error      error message
232:      * @param int    $errno      error number
233:      * @param float  $query_time execution time
234:      *
235:      * @return void
236:      */
237:     public function addQuery($sql, $error = null, $errno = null, $query_time = null)
238:     {
239:         if ($this->activated) {
240:             $this->queries[] = array(
241:                 'sql' => $sql, 'error' => $error, 'errno' => $errno, 'query_time' => $query_time
242:             );
243:         }
244:     }
245: 
246:     /**
247:      * Log display of a block
248:      *
249:      * @param string $name      name of the block
250:      * @param bool   $cached    was the block cached?
251:      * @param int    $cachetime cachetime of the block
252:      * 
253:      * @return void
254:      */
255:     public function addBlock($name, $cached = false, $cachetime = 0)
256:     {
257:         if ($this->activated) {
258:             $this->blocks[] = array('name' => $name, 'cached' => $cached, 'cachetime' => $cachetime);
259:         }
260:     }
261: 
262:     /**
263:      * Log extra information
264:      *
265:      * @param string $name name for the entry
266:      * @param string $msg  text message for the entry
267:      * 
268:      * @return void
269:      */
270:     public function addExtra($name, $msg)
271:     {
272:         if ($this->activated) {
273:             $this->extra[] = array('name' => $name, 'msg' => $msg);
274:         }
275:     }
276: 
277:     /**
278:      * Log messages for deprecated functions
279:      *
280:      * @param string $msg name for the entry
281:      * 
282:      * @return void
283:      */
284:     public function addDeprecated($msg)
285:     {
286:         if ($this->activated) {
287:             $this->deprecated[] = $msg;
288:         }
289:     }
290: 
291:     /**
292:      * Log exceptions
293:      *
294:      * @param Exception $e name for the entry
295:      * 
296:      * @return void
297:      */
298:     public function addException($e)
299:     {
300:         if ($this->activated) {
301:             $this->log(
302:                 LogLevel::ERROR,
303:                 'Exception: ' . $e->getMessage() . ' - ' .
304:                 $this->sanitizePath($e->getFile()) . ' ' . $e->getLine()
305:             );
306:         }
307:     }
308: 
309:     /**
310:      * sanitizePath
311:      * 
312:      * @param string $path path name to sanitize 
313:      * 
314:      * @return string path with top levels removed
315:      */
316:     public function sanitizePath($path)
317:     {
318:         $path = str_replace(
319:             array(
320:                 '\\',
321:                 \XoopsBaseConfig::get('root-path'),
322:                 str_replace('\\', '/', realpath(\XoopsBaseConfig::get('root-path')))
323:             ),
324:             array('/', '', ''),
325:             $path
326:         );
327:         return $path;
328:     }
329: 
330:     /**
331:      * Enable logger output rendering
332:      * When output rendering is enabled, the logger will insert its output within the page content.
333:      * If the string <!--{xo-logger-output}--> is found in the page content, the logger output will
334:      * replace it, otherwise it will be inserted after all the page output.
335:      * 
336:      * @return void
337:      */
338:     public function enableRendering()
339:     {
340:         if (!$this->renderingEnabled) {
341:             ob_start(array(&$this, 'render'));
342:             $this->renderingEnabled = true;
343:         }
344:     }
345: 
346:     /**
347:      * Output buffering callback inserting logger dump in page output
348:      * 
349:      * @param string $output output buffer to add logger rendering to
350:      * 
351:      * @return string output
352:      */
353:     public function render($output)
354:     {
355:         if (!$this->activated) {
356:             return $output;
357:         }
358: 
359:         $log = $this->dump($this->usePopup ? 'popup' : '');
360:         $this->renderingEnabled = $this->activated = false;
361: 
362:         $pattern = '<!--{xo-logger-output}-->';
363:         $pos = strpos($output, $pattern);
364:         if ($pos !== false) {
365:             return substr($output, 0, $pos) . $log . substr($output, $pos + strlen($pattern));
366:         } else {
367:             return $output . $log;
368:         }
369:     }
370: 
371:     /**
372:      * Dump output
373:      * 
374:      * @param string $mode unused
375:      * 
376:      * @return string output
377:      */
378:     public function dump($mode = '')
379:     {
380:         $ret = '';
381: // -------------------------------------------------------------
382:         $xoops = Xoops::getInstance();
383:         /* @var $this LoggerLegacy */
384:         $ret = '';
385:         if ($mode === 'popup') {
386:             $dump = $this->dump('');
387:             $content = '
388: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
389: <head>
390:     <meta http-equiv="content-language" content="' . XoopsLocale::getLangCode() . '" />
391:     <meta http-equiv="content-type" content="text/html; charset=' . XoopsLocale::getCharset() . '" />
392:     <title>' . $xoops->getConfig('sitename') . ' - ' . _MD_LOGGER_DEBUG . ' </title>
393:     <meta name="generator" content="XOOPS" />
394:     <link rel="stylesheet" type="text/css" media="all" href="' . $xoops->getCss($xoops->getConfig('theme_set')) . '" />
395: </head>
396: <body>' . $dump . '
397:     <div style="text-align:center;">
398:         <input class="formButton" value="' . XoopsLocale::A_CLOSE . '" type="button" onclick="javascript:window.close();" />
399:     </div>
400: ';
401:             $ret .= '
402: <script type="text/javascript">
403:     debug_window = openWithSelfMain("about:blank", "popup", 680, 450, true);
404:     debug_window.document.clear();
405: ';
406:             $lines = preg_split("/(\r\n|\r|\n)( *)/", $content);
407:             foreach ($lines as $line) {
408:                 $ret .= "\n" . 'debug_window.document.writeln("'
409:                     . str_replace(array('"', '</'), array('\"', '<\/'), $line) . '");';
410:             }
411:             $ret .= '
412:     debug_window.focus();
413:     debug_window.document.close();
414: </script>
415: ';
416:         }
417: 
418:         $this->addExtra(
419:             _MD_LOGGER_INCLUDED_FILES,
420:             sprintf(_MD_LOGGER_FILES, count(get_included_files()))
421:         );
422: 
423:         /*
424:         $included_files = get_included_files();
425:         foreach ($included_files as $filename) {
426:             $this->addExtra('files',$filename);
427:         }
428:         
429:         if (function_exists('memory_get_peak_usage')) {
430:             $this->addExtra('Peak memory',memory_get_peak_usage());
431:         }
432:         */
433: 
434:         $memory = 0;
435:         
436:         if (function_exists('memory_get_usage')) {
437:             $memory = memory_get_usage() . ' bytes';
438:         } else {
439:             if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
440:                 $out = array();
441:                 exec('tasklist /FI "PID eq ' . getmypid() . '" /FO LIST', $out);
442:                 if (isset($out[5])) {
443:                     $memory = sprintf(_MD_LOGGER_MEM_ESTIMATED, substr($out[5], strpos($out[5], ':') + 1));
444:                 }
445:             }
446:         }
447:         if ($memory) {
448:             $this->addExtra(_MD_LOGGER_MEM_USAGE, $memory);
449:         }
450: 
451:         if (empty($mode)) {
452:             $views = array('errors', 'deprecated', 'queries', 'blocks', 'extra');
453:             $ret .= "\n<div id=\"xo-logger-output\">\n<div id='xo-logger-tabs'>\n";
454:             $ret .= "<a href='javascript:xoSetLoggerView(\"none\")'>" . _MD_LOGGER_NONE . "</a>\n";
455:             $ret .= "<a href='javascript:xoSetLoggerView(\"\")'>" . _MD_LOGGER_ALL . "</a>\n";
456:             foreach ($views as $view) {
457:                 $count = count($this->$view);
458:                 $ret .= "<a href='javascript:xoSetLoggerView(\"$view\")'>" . constant('_MD_LOGGER_' . strtoupper($view)) . " ($count)</a>\n";
459:             }
460:             $count = count($this->logstart);
461:             $ret .= "<a href='javascript:xoSetLoggerView(\"timers\")'>" . _MD_LOGGER_TIMERS . "($count)</a>\n";
462:             $ret .= "</div>\n";
463:         }
464:         
465:         if (empty($mode) || $mode === 'errors') {
466:             $class = 'even';
467:             $ret .= '<table id="xo-logger-errors" class="outer"><thead><tr><th>' . _MD_LOGGER_ERRORS . '</th></tr></thead><tbody>';
468:             foreach ($this->errors as $error) {
469:                 $ret .= "\n<tr><td class='$class'>";
470:                 $ret .= $error;
471:                 $ret .= "<br />\n</td></tr>";
472:                 $class = ($class === 'odd') ? 'even' : 'odd';
473:             }
474:             $ret .= "\n</tbody></table>\n";
475:         }
476: 
477:         if (empty($mode) || $mode === 'deprecated') {
478:             $class = 'even';
479:             $ret .= '<table id="xo-logger-deprecated" class="outer"><thead><tr><th>' . _MD_LOGGER_DEPRECATED . '</th></tr></thead><tbody>';
480:             foreach ($this->deprecated as $message) {
481:                 $ret .= "\n<tr><td class='$class'>";
482:                 $ret .= $message;
483:                 $ret .= "<br />\n</td></tr>";
484:                 $class = ($class === 'odd') ? 'even' : 'odd';
485:             }
486:             $ret .= "\n</tbody></table>\n";
487:         }
488: 
489:         if (empty($mode) || $mode === 'queries') {
490:             $class = 'even';
491:             $ret .= '<table id="xo-logger-queries" class="outer"><thead><tr><th>' . _MD_LOGGER_QUERIES . '</th></tr></thead><tbody>';
492:             $pattern = '/\b' . preg_quote(\XoopsBaseConfig::get('db-prefix')) . '\_/i';
493:         
494:             foreach ($this->queries as $q) {
495:                 $sql = preg_replace($pattern, '', $q['sql']);
496:                 $query_time = isset($q['query_time']) ? sprintf('%0.6f - ', $q['query_time']) : '';
497:         
498:                 if (isset($q['error'])) {
499:                     $ret .= '<tr class="' . $class . '"><td><span style="color:#ff0000;">' . $query_time . htmlentities($sql) . '<br /><strong>Error number:</strong> ' . $q['errno'] . '<br /><strong>Error message:</strong> ' . $q['error'] . '</span></td></tr>';
500:                 } else {
501:                     $ret .= '<tr class="' . $class . '"><td>' . $query_time . htmlentities($sql) . '</td></tr>';
502:                 }
503:         
504:                 $class = ($class === 'odd') ? 'even' : 'odd';
505:             }
506:             $ret .= '</tbody><tfoot><tr class="foot"><td>' . _MD_LOGGER_TOTAL . ': <span style="color:#ff0000;">' . count($this->queries) . '</span></td></tr></tfoot></table>';
507:         }
508:         if (empty($mode) || $mode === 'blocks') {
509:             $class = 'even';
510:             $ret .= '<table id="xo-logger-blocks" class="outer"><thead><tr><th>' . _MD_LOGGER_BLOCKS . '</th></tr></thead><tbody>';
511:             foreach ($this->blocks as $b) {
512:                 if ($b['cached']) {
513:                     $ret .= '<tr><td class="' . $class . '"><strong>' . $b['name'] . ':</strong> ' . sprintf(_MD_LOGGER_CACHED, (int)($b['cachetime'])) . '</td></tr>';
514:                 } else {
515:                     $ret .= '<tr><td class="' . $class . '"><strong>' . $b['name'] . ':</strong> ' . _MD_LOGGER_NOT_CACHED . '</td></tr>';
516:                 }
517:                 $class = ($class === 'odd') ? 'even' : 'odd';
518:             }
519:             $ret .= '</tbody><tfoot><tr class="foot"><td>' . _MD_LOGGER_TOTAL . ': <span style="color:#ff0000;">' . count($this->blocks) . '</span></td></tr></tfoot></table>';
520:         }
521:         if (empty($mode) || $mode === 'extra') {
522:             $class = 'even';
523:             $ret .= '<table id="xo-logger-extra" class="outer"><thead><tr><th>' . _MD_LOGGER_EXTRA . '</th></tr></thead><tbody>';
524:             foreach ($this->extra as $ex) {
525:                 $ret .= '<tr><td class="' . $class . '"><strong>';
526:                 $ret .= htmlspecialchars($ex['name']) . ':</strong> ' . htmlspecialchars($ex['msg']);
527:                 $ret .= '</td></tr>';
528:                 $class = ($class === 'odd') ? 'even' : 'odd';
529:             }
530:             $ret .= '</tbody></table>';
531:         }
532:         if (empty($mode) || $mode === 'timers') {
533:             $class = 'even';
534:             $ret .= '<table id="xo-logger-timers" class="outer"><thead><tr><th>' . _MD_LOGGER_TIMERS . '</th></tr></thead><tbody>';
535:             foreach ($this->logstart as $k => $v) {
536:                 $ret .= '<tr><td class="' . $class . '"><strong>';
537:                 $ret .= sprintf(_MD_LOGGER_TIMETOLOAD, htmlspecialchars($k) . '</strong>', '<span style="color:#ff0000;">' . sprintf("%.03f", $this->dumpTime($k)) . '</span>');
538:                 $ret .= '</td></tr>';
539:                 $class = ($class === 'odd') ? 'even' : 'odd';
540:             }
541:             $ret .= '</tbody></table>';
542:         }
543:         
544:         if (empty($mode)) {
545:             $ret .= <<<EOT
546: </div>
547: <script type="text/javascript">
548:     function xoLogCreateCookie(name,value,days) {
549:         if (days) {
550:             var date = new Date();
551:             date.setTime(date.getTime()+(days*24*60*60*1000));
552:             var expires = "; expires="+date.toGMTString();
553:         }
554:         else var expires = "";
555:         document.cookie = name+"="+value+expires+"; path=/";
556:     }
557:     function xoLogReadCookie(name) {
558:         var nameEQ = name + "=";
559:         var ca = document.cookie.split(';');
560:         for(var i=0;i < ca.length;i++) {
561:             var c = ca[i];
562:             while (c.charAt(0)==' ') c = c.substring(1,c.length);
563:             if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
564:         }
565:         return null;
566:     }
567:     function xoLogEraseCookie(name) {
568:         createCookie(name,"",-1);
569:     }
570:     function xoSetLoggerView( name ) {
571:         var log = document.getElementById( "xo-logger-output" );
572:         if ( !log ) return;
573:         var i, elt;
574:         for ( i=0; i!=log.childNodes.length; i++ ) {
575:             elt = log.childNodes[i];
576:             if ( elt.tagName && elt.tagName.toLowerCase() != 'script' && elt.id != "xo-logger-tabs" ) {
577:                 elt.style.display = ( !name || elt.id == "xo-logger-" + name ) ? "block" : "none";
578:             }
579:         }
580:         xoLogCreateCookie( 'XOLOGGERVIEW', name, 1 );
581:     }
582:     xoSetLoggerView( xoLogReadCookie( 'XOLOGGERVIEW' ) );
583: </script>
584: 
585: EOT;
586:         }
587: // -------------------------------------------------------------
588:         return $ret;
589:     }
590: 
591:     /**
592:      * get the current execution time of a timer
593:      *
594:      * @param string $name  name of the counter
595:      * @param bool   $unset removes counter from global log
596:      *
597:      * @return float current execution time of the counter
598:      */
599:     public function dumpTime($name = 'XOOPS', $unset = false)
600:     {
601:         if (!$this->activated) {
602:             return null;
603:         }
604: 
605:         if (!isset($this->logstart[$name])) {
606:             return 0;
607:         }
608:         $stop = isset($this->logend[$name]) ? $this->logend[$name] : microtime(true);
609:         $start = $this->logstart[$name];
610: 
611:         if ($unset) {
612:             unset($this->logstart[$name]);
613:             unset($this->logend[$name]);
614:         }
615: 
616:         return $stop - $start;
617:     }
618: 
619: 
620:     /**
621:      * PSR-3 System is unusable.
622:      *
623:      * @param string $message message
624:      * @param array  $context array of additional context
625:      * 
626:      * @return null
627:      */
628:     public function emergency($message, array $context = array())
629:     {
630:         if ($this->activated) {
631:             $this->log(LogLevel::EMERGENCY, $message, $context);
632:         }
633:     }
634: 
635:     /**
636:      * PSR-3 Action must be taken immediately.
637:      *
638:      * Example: Entire website down, database unavailable, etc. This should
639:      * trigger the SMS alerts and wake you up.
640:      *
641:      * @param string $message message
642:      * @param array  $context array of additional context
643:      * 
644:      * @return null
645:      */
646:     public function alert($message, array $context = array())
647:     {
648:         if ($this->activated) {
649:             $this->log(LogLevel::ALERT, $message, $context);
650:         }
651:     }
652: 
653:     /**
654:      * PSR-3 Critical conditions.
655:      *
656:      * Example: Application component unavailable, unexpected exception.
657:      *
658:      * @param string $message message
659:      * @param array  $context array of additional context
660:      * 
661:      * @return null
662:      */
663:     public function critical($message, array $context = array())
664:     {
665:         if ($this->activated) {
666:             $this->log(LogLevel::CRITICAL, $message, $context);
667:         }
668:     }
669: 
670:     /**
671:      * PSR-3 Runtime errors that do not require immediate action but should typically
672:      * be logged and monitored.
673:      *
674:      * @param string $message message
675:      * @param array  $context array of additional context
676:      * 
677:      * @return null
678:      */
679:     public function error($message, array $context = array())
680:     {
681:         if ($this->activated) {
682:             $this->log(LogLevel::ERROR, $message, $context);
683:         }
684:     }
685: 
686:     /**
687:      * PSR-3 Exceptional occurrences that are not errors.
688:      *
689:      * Example: Use of deprecated APIs, poor use of an API, undesirable things
690:      * that are not necessarily wrong.
691:      *
692:      * @param string $message message
693:      * @param array  $context array of additional context
694:      * 
695:      * @return null
696:      */
697:     public function warning($message, array $context = array())
698:     {
699:         if ($this->activated) {
700:             $this->log(LogLevel::WARNING, $message, $context);
701:         }
702:     }
703: 
704:     /**
705:      * PSR-3 Normal but significant events.
706:      *
707:      * @param string $message message
708:      * @param array  $context array of additional context
709:      * 
710:      * @return null
711:      */
712:     public function notice($message, array $context = array())
713:     {
714:         if ($this->activated) {
715:             $this->log(LogLevel::NOTICE, $message, $context);
716:         }
717:     }
718: 
719:     /**
720:      * PSR-3 Interesting events.
721:      *
722:      * Example: User logs in, SQL logs.
723:      *
724:      * @param string $message message
725:      * @param array  $context array of additional context
726:      * 
727:      * @return null
728:      */
729:     public function info($message, array $context = array())
730:     {
731:         if ($this->activated) {
732:             $this->log(LogLevel::INFO, $message, $context);
733:         }
734:     }
735: 
736:     /**
737:      * PSR-3 Detailed debug information.
738:      *
739:      * @param string $message message
740:      * @param array  $context array of additional context
741:      * 
742:      * @return null
743:      */
744:     public function debug($message, array $context = array())
745:     {
746:         if ($this->activated) {
747:             $this->log(LogLevel::DEBUG, $message, $context);
748:         }
749:     }
750: 
751:     /**
752:      * PSR-3 Logs with an arbitrary level.
753:      *
754:      * @param mixed  $level   logging level
755:      * @param string $message message
756:      * @param array  $context array of additional context
757:      * 
758:      * @return null
759:      */
760:     public function log($level, $message, array $context = array())
761:     {
762:         if (!$this->activated) {
763:             return;
764:         }
765: 
766:         $this->errors[] = $message;
767:     }
768: }
769: 
API documentation generated by ApiGen