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:  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: namespace Xmf\Database;
 13: 
 14: use Xmf\Module\Helper;
 15: use Xmf\Yaml;
 16: 
 17: /**
 18:  * Xmf\Database\Migrate
 19:  *
 20:  * For a given module, compare the existing tables with a defined target schema
 21:  * and build a work queue of DDL/SQL to transform the existing tables to the
 22:  * target definitions.
 23:  *
 24:  * Typically Migrate will be extended by a module specific class that will supply custom
 25:  * logic (see preSyncActions() method.)
 26:  *
 27:  * @category  Xmf\Database\Migrate
 28:  * @package   Xmf
 29:  * @author    Richard Griffith <richard@geekwright.com>
 30:  * @copyright 2016 XOOPS Project (http://xoops.org)
 31:  * @license   GNU GPL 2 or later (http://www.gnu.org/licenses/gpl-2.0.html)
 32:  * @link      http://xoops.org
 33:  */
 34: class Migrate
 35: {
 36: 
 37:     /** @var false|\Xmf\Module\Helper|\Xoops\Module\Helper\HelperAbstract  */
 38:     protected $helper;
 39: 
 40:     /** @var string[] table names used by module */
 41:     protected $moduleTables;
 42: 
 43:     /** @var Tables */
 44:     protected $tableHandler;
 45: 
 46:     /** @var string yaml definition file */
 47:     protected $tableDefinitionFile;
 48: 
 49:     /** @var array target table definitions in Xmf\Database\Tables::dumpTables() format */
 50:     protected $targetDefinitions;
 51: 
 52:     /**
 53:      * Migrate constructor
 54:      *
 55:      * @param string $dirname module directory name that defines the tables to be migrated
 56:      *
 57:      * @throws \InvalidArgumentException
 58:      * @throws \RuntimeException
 59:      */
 60:     public function __construct($dirname)
 61:     {
 62:         $this->helper = Helper::getHelper($dirname);
 63:         if (false === $this->helper) {
 64:             throw new \InvalidArgumentException("Invalid module $dirname specified");
 65:         }
 66:         $module = $this->helper->getModule();
 67:         $this->moduleTables = $module->getInfo('tables');
 68:         if (empty($this->moduleTables)) {
 69:             throw new \RuntimeException("No tables established in module");
 70:         }
 71:         $version = $module->getInfo('version');
 72:         $this->tableDefinitionFile = $this->helper->path("sql/{$dirname}_{$version}_migrate.yml");
 73:         $this->tableHandler = new Tables();
 74:     }
 75: 
 76:     /**
 77:      * Save current table definitions to a file
 78:      *
 79:      * This is intended for developer use when setting up the migration by using the current database state
 80:      *
 81:      * @internal intended for module developers only
 82:      *
 83:      * @return int|false count of bytes written or false on error
 84:      */
 85:     public function saveCurrentSchema()
 86:     {
 87:         $this->tableHandler = new Tables(); // start fresh
 88: 
 89:         $schema = $this->getCurrentSchema();
 90: 
 91:         foreach ($schema as $tableName => $tableData) {
 92:             unset($schema[$tableName]['name']);
 93:         }
 94: 
 95:         return Yaml::save($schema, $this->tableDefinitionFile);
 96:     }
 97: 
 98:     /**
 99:      * get the current definitions
100:      *
101:      * @return array
102:      */
103:     public function getCurrentSchema()
104:     {
105:         foreach ($this->moduleTables as $tableName) {
106:             $this->tableHandler->useTable($tableName);
107:         }
108: 
109:         return $this->tableHandler->dumpTables();
110:     }
111: 
112:     /**
113:      * Return the target database condition
114:      *
115:      * @return array|bool table structure or false on error
116:      *
117:      * @throws \RuntimeException
118:      */
119:     public function getTargetDefinitions()
120:     {
121:         if (!isset($this->targetDefinitions)) {
122:             $this->targetDefinitions = Yaml::read($this->tableDefinitionFile);
123:             if (null === $this->targetDefinitions) {
124:                 throw new \RuntimeException("No schema definition " . $this->tableDefinitionFile);
125:             }
126:         }
127:         return $this->targetDefinitions;
128:     }
129: 
130:     /**
131:      * Execute synchronization to transform current schema to target
132:      *
133:      * @param bool $force true to force updates even if this is a 'GET' request
134:      *
135:      * @return bool true if no errors, false if errors encountered
136:      */
137:     public function synchronizeSchema($force = true)
138:     {
139:         $this->tableHandler = new Tables(); // start fresh
140:         $this->getSynchronizeDDL();
141:         return $this->tableHandler->executeQueue($force);
142:     }
143: 
144:     /**
145:      * Compare target and current schema, building work queue in $this->migrate to synchronized
146:      *
147:      * @return string[] array of DDL/SQL statements to transform current to target schema
148:      */
149:     public function getSynchronizeDDL()
150:     {
151:         $this->getTargetDefinitions();
152:         $this->preSyncActions();
153:         foreach ($this->moduleTables as $tableName) {
154:             if ($this->tableHandler->useTable($tableName)) {
155:                 $this->synchronizeTable($tableName);
156:             } else {
157:                 $this->addMissingTable($tableName);
158:             }
159:         }
160:         return $this->tableHandler->dumpQueue();
161:     }
162: 
163:     /**
164:      * Perform any upfront actions before synchronizing the schema.
165:      *
166:      * The schema comparison cannot recognize changes such as renamed columns or renamed tables. By overriding
167:      * this method, an implementation can provide the logic to accomplish these types of changes, and leave
168:      * the other details to be handled by synchronizeSchema().
169:      *
170:      * An suitable implementation should be provided by a module by extending Migrate to define any required
171:      * actions.
172:      *
173:      * Some typical uses include:
174:      *  - table and column renames
175:      *  - data conversions
176:      *  - move column data
177:      *
178:      * @return void
179:      */
180:     protected function preSyncActions()
181:     {
182:     }
183: 
184:     /**
185:      * Add table create DDL to the work queue
186:      *
187:      * @param string $tableName table to add
188:      *
189:      * @return void
190:      */
191:     protected function addMissingTable($tableName)
192:     {
193:         $this->tableHandler->addTable($tableName);
194:         $this->tableHandler->setTableOptions($tableName, $this->targetDefinitions[$tableName]['options']);
195:         foreach ($this->targetDefinitions[$tableName]['columns'] as $column) {
196:             $this->tableHandler->addColumn($tableName, $column['name'], $column['attributes']);
197:         }
198:         foreach ($this->targetDefinitions[$tableName]['keys'] as $key => $keyData) {
199:             if ($key === 'PRIMARY') {
200:                 $this->tableHandler->addPrimaryKey($tableName, $keyData['columns']);
201:             } else {
202:                 $this->tableHandler->addIndex($key, $tableName, $keyData['columns'], $keyData['unique']);
203:             }
204:         }
205:     }
206: 
207:     /**
208:      * Build any DDL required to synchronize an existing table to match the target schema
209:      *
210:      * @param string $tableName table to synchronize
211:      *
212:      * @return void
213:      */
214:     protected function synchronizeTable($tableName)
215:     {
216:         foreach ($this->targetDefinitions[$tableName]['columns'] as $column) {
217:             $attributes = $this->tableHandler->getColumnAttributes($tableName, $column['name']);
218:             if ($attributes === false) {
219:                 $this->tableHandler->addColumn($tableName, $column['name'], $column['attributes']);
220:             } elseif ($column['attributes'] !== $attributes) {
221:                 $this->tableHandler->alterColumn($tableName, $column['name'], $column['attributes']);
222:             }
223:         }
224: 
225:         $tableDef = $this->tableHandler->dumpTables();
226:         if (isset($tableDef[$tableName])) {
227:             foreach ($tableDef[$tableName]['columns'] as $columnData) {
228:                 if (!$this->targetHasColumn($tableName, $columnData['name'])) {
229:                     $this->tableHandler->dropColumn($tableName, $columnData['name']);
230:                 }
231:             }
232:         }
233: 
234:         $existingIndexes = $this->tableHandler->getTableIndexes($tableName);
235:         if (isset($this->targetDefinitions[$tableName]['keys'])) {
236:             foreach ($this->targetDefinitions[$tableName]['keys'] as $key => $keyData) {
237:                 if ($key === 'PRIMARY') {
238:                     if (!isset($existingIndexes[$key])) {
239:                         $this->tableHandler->addPrimaryKey($tableName, $keyData['columns']);
240:                     } elseif ($existingIndexes[$key]['columns'] !== $keyData['columns']) {
241:                         $this->tableHandler->dropPrimaryKey($tableName);
242:                         $this->tableHandler->addPrimaryKey($tableName, $keyData['columns']);
243:                     }
244:                 } else {
245:                     if (!isset($existingIndexes[$key])) {
246:                         $this->tableHandler->addIndex($key, $tableName, $keyData['columns'], $keyData['unique']);
247:                     } elseif ($existingIndexes[$key]['unique'] !== $keyData['unique']
248:                         || $existingIndexes[$key]['columns'] !== $keyData['columns']
249:                     ) {
250:                         $this->tableHandler->dropIndex($key, $tableName);
251:                         $this->tableHandler->addIndex($key, $tableName, $keyData['columns'], $keyData['unique']);
252:                     }
253:                 }
254:             }
255:         }
256:         if (false !== $existingIndexes) {
257:             foreach ($existingIndexes as $key => $keyData) {
258:                 if (!isset($this->targetDefinitions[$tableName]['keys'][$key])) {
259:                     $this->tableHandler->dropIndex($key, $tableName);
260:                 }
261:             }
262:         }
263:     }
264: 
265:     /**
266:      * determine if a column on a table exists in the target definitions
267:      *
268:      * @param string $tableName  table containing the column
269:      * @param string $columnName column to check
270:      *
271:      * @return bool true if table and column combination is defined, otherwise false
272:      */
273:     protected function targetHasColumn($tableName, $columnName)
274:     {
275:         if (isset($this->targetDefinitions[$tableName])) {
276:             foreach ($this->targetDefinitions[$tableName]['columns'] as $col) {
277:                 if (strcasecmp($col['name'], $columnName) === 0) {
278:                     return true;
279:                 }
280:             }
281:         }
282: 
283:         return false;
284:     }
285: 
286:     /**
287:      * determine if a table exists in the target definitions
288:      *
289:      * @param string $tableName table containing the column
290:      *
291:      * @return bool true if table is defined, otherwise false
292:      */
293:     protected function targetHasTable($tableName)
294:     {
295:         if (isset($this->targetDefinitions[$tableName])) {
296:             return true;
297:         }
298:         return false;
299:     }
300: 
301:     /**
302:      * Return message from last error encountered
303:      *
304:      * @return string last error message
305:      */
306:     public function getLastError()
307:     {
308:         return $this->tableHandler->getLastError();
309:     }
310: 
311:     /**
312:      * Return code from last error encountered
313:      *
314:      * @return int last error number
315:      */
316:     public function getLastErrNo()
317:     {
318:         return $this->tableHandler->getLastErrNo();
319:     }
320: }
321: 
API documentation generated by ApiGen