File Manager / wp-content Search Upload New Item Settings File "db5.php" Full path: /home1/epichome/public_html/wp-content/db5.php File size: 60.67 B (60.67 KB bytes) MIME-type: text/x-php Charset: utf-8 Download Open Edit Advanced Editor Back
<?php
declare(strict_types=1);
namespace MaxButtons;
defined('ABSPATH') or die('No direct access permitted');
class maxInstall
{
public static function activation_hook($network_wide) {
if ($network_wide) {
static::call_function_for_each_site( array('self','activate_plugin') );
}
else {
static::activate_plugin();
}
}
public static function deactivation_hook($network_wide) {
if ($network_wide) {
static::call_function_for_each_site( array('self','deactivate_plugin') );
}
else {
static::deactivate_plugin();
}
}
public static function hasAddOn($addon)
{
switch($addon)
{
case 'socialshare':
if (defined('MBSOCIAL_ROOT_FILE'))
{
return true;
}
break;
}
return false;
}
// This should be done - once! Removed in time as well.
public static function check_database()
{
$version = MAXBUTTONS_VERSION_NUM;
$installed_version = MB()->get_installed_version();
if ($version !== $installed_version)
{
$table = maxUtils::get_table_name();
self::activate_plugin(); // always run the DBdelta on version mismatch.
}
}
public static function activate_plugin($gocreate = true)
{
static::create_database_table();
static::migrate();
static::upgradeUTF();
static::updateFA();
static::migrateResponsive();
$button = MB()->getClass('button');
$button->reset_cache(); //refresh cache
update_option(MAXBUTTONS_VERSION_KEY, MAXBUTTONS_VERSION_NUM);
$created = get_option("MBFREE_CREATED");
if ($created == '' && $gocreate)
{ update_option("MBFREE_CREATED", time());
update_option("MBFREE_HOMEURL", home_url());
}
}
/** MOVE Button Database records from FA4 to FA5 */
public static function updateFA()
{
global $wpdb;
$table_name = maxUtils::get_table_name();
$sql = ' SHOW COLUMNS FROM ' . $table_name . ' LIKE "icon"';
$result = $wpdb->get_results($sql, ARRAY_A);
// when the icon field does not exist. Otherwise this causes an activate notice.
if (count($result) == 0)
return;
$conversion_path = MB()->get_plugin_path() . '/assets/libraries/font-awesome-5/shims.json';
$conversion_array = json_decode(file_get_contents($conversion_path), true);
$sql = 'select id, icon from ' . maxUtils::get_table_name();
$result = $wpdb->get_results($sql, ARRAY_A);
if (count($result) == 0)
return;
foreach($result as $item)
{
$button_id = $item['id'];
if (! $button_id > 0)
{ continue; }
// procedure from setupdata by button class
$icondata = maybe_unserialize($item['icon']);
if ( false === $icondata) // unserialize failed?
{
return;
}
if (! is_array($icondata) && ! is_null($icondata) )
{
$icondata = json_decode($icondata, true);
if (isset($icondata['fa_icon_value']) && strlen($icondata['fa_icon_value']) > 0)
{
$fa_icon = $icondata['fa_icon_value'];
$fa_icon = str_replace('fa-', '', $fa_icon); // remove the prefix
// don't convert converted icons.
if (strpos($fa_icon, 'fas') === false && strpos($fa_icon, 'fab') === false && strpos($fa_icon,'far') === false)
{
$new_fa_icon = self::searchNewFA($fa_icon, $conversion_array);
$icondata['fa_icon_value'] = $new_fa_icon;
$wpdb->update(maxUtils::get_table_name(), array('icon' => json_encode($icondata)), array('id' => $button_id) );
}
}
}
}
}
/** Convert Font Awesome 4 to Font Awesome 5 via the conversion shims array
* @param $old The old value, without the fa- prefix
* @param $conversion_array The loaded FA5 shims library
*/
public static function searchNewFA($old, $conversion_array)
{
$new = false;
foreach($conversion_array as $key => $items)
{
if ($items[0] == $old)
{
$new = (strlen($items[1]) > 0) ? $items[1] : 'fas'; // if not set, fas is the set
$new .= ' fa-';
$new .= (strlen($items[2]) > 0) ? $items[2] : $old ;
}
}
if (! $new)
{
$new = 'fas fa-'. $old;
}
return $new;
}
/** Move data from old version database to new version
*
* Check if new database table is empty ( aka new ) to prevent migrating the same data multiple times then copy all rows from old table to the new one.
*/
public static function migrate()
{
global $wpdb;
$old_table = maxUtils::get_table_name(true);
$table = maxUtils::get_table_name();
if (! self::maxbuttons_database_table_exists($old_table))
{
return;
}
$sql = "SELECT id from $table";
$result = $wpdb->get_results($sql, ARRAY_A);
if(count($result) > 0) return; // don't do this if table already has data.
$sql = "SELECT * FROM $old_table";
$rows = $wpdb->get_results($sql, ARRAY_A);
if (count($rows) == 0 ) // no button in all table; all is good.
return true;
foreach($rows as $row)
{
$data = static::convertOldFields($row);
$id = $data["id"];
global $wpdb;
$wpdb->insert($table, array("id" => $id));
//$data = apply_filters("mb-migration-data",$data, $row);
$button = MB()->getClass('button');
$button->set($id);
$button->save($data);
}
}
/** Import fields from the old database format ( pre version 3.0 ) */
public static function convertOldFields($row)
{
$data = array();
$data["id"] = (isset($row["id"])) ? $row["id"] : -1;
$data["name"] = $row["name"];
$data["status"] = isset($row["status"]) ? $row["status"] : 'publish'; // happens with downloadable packs.
$data["description"] = $row["description"];
$data["url"] = $row["url"];
$data["text"] = $row["text"];
$data["new_window"] = (isset($row["new_window"]) && $row["new_window"] != "") ? 1 : 0;
$data["nofollow"] = (isset($row["nofollow"]) && $row["nofollow"] != "") ? 1 : 0;
$data["font"] = $row["text_font_family"];
$data["font_size"] = $row["text_font_size"];
$data["font_style"] = $row["text_font_style"];
$data["font_weight"] = $row["text_font_weight"];
$data["text_shadow_offset_left"] = $row["text_shadow_offset_left"];
$data["text_shadow_offset_top"] = $row["text_shadow_offset_top"];
$data["text_shadow_width"] = $row["text_shadow_width"];
$data["padding_top"] = $row["text_padding_top"];
$data["padding_right"] = $row["text_padding_right"];
$data["padding_bottom"] = $row["text_padding_bottom"];
$data["padding_left"] = $row["text_padding_left"];
$data["radius_top_left"] = $row["border_radius_top_left"];
$data["radius_top_right"] = $row["border_radius_top_right"];
$data["radius_bottom_left"] = $row["border_radius_bottom_left"];
$data["radius_bottom_right"] = $row["border_radius_bottom_right"];
$data["border_style"] = $row["border_style"];
$data["border_width"] = $row["border_width"];
$data["box_shadow_offset_left"] = $row["box_shadow_offset_left"];
$data["box_shadow_offset_top"] = $row["box_shadow_offset_top"];
$data["box_shadow_width"] = $row["box_shadow_width"];
$data["text_color"] = $row["text_color"];
$data["text_shadow_color"] = $row["text_shadow_color"];
$data["gradient_start_color"] = $row["gradient_start_color"];
$data["gradient_end_color"] = $row["gradient_end_color"];
$data["border_color"] = $row["border_color"];
$data["box_shadow_color"] = $row["box_shadow_color"];
$data["text_color_hover"] = $row["text_color_hover"];
$data["text_shadow_color_hover"] = $row["text_shadow_color_hover"];
$data["gradient_start_color_hover"] = $row["gradient_start_color_hover"];
$data["gradient_end_color_hover"] = $row["gradient_end_color_hover"];
$data["border_color_hover"] = $row["border_color_hover"];
$data["box_shadow_color_hover"] = $row["box_shadow_color_hover"];
$data["gradient_stop"] = (isset($row["gradient_stop"])) ? $row["gradient_stop"] : 45;
$data["gradient_start_opacity"] = (isset($row["gradient_start_opacity"])) ? $row["gradient_start_opacity"] : 100;
$data["gradient_end_opacity"] = (isset($row["gradient_end_opacity"])) ? $row["gradient_end_opacity"] : 100;
$data["gradient_start_opacity_hover"] = (isset($row["gradient_start_opacity_hover"])) ? $row["gradient_start_opacity_hover"] : 100;
$data["gradient_end_opacity_hover"] = (isset($row["gradient_end_opacity_hover"])) ? $row["gradient_end_opacity_hover"] : 100;
$data["container_enabled"] = (isset($row["container_enabled"]) && $row["container_enabled"] != "") ? 1 : 0;
$data["container_center_div_wrap"] = (isset($row["container_center_div_wrap_enabled"]) && $row["container_center_div_wrap_enabled"] != "") ? 1 : 0;
$data["container_width"] = isset($row["container_width"]) ? $row["container_width"] : '';
$data["container_margin_top"] = isset($row["container_margin_top"]) ? $row["container_margin_top"] : '';
$data["container_margin_right"] = isset($row["container_margin_right"]) ? $row["container_margin_right"] : '';
$data["container_margin_bottom"] = isset($row["container_margin_bottom"]) ? $row["container_margin_right"] : '';
$data["container_margin_left"] = isset($row["container_margin_left"]) ? $row["container_margin_left"] : '';
$data["container_alignment"] = isset($row["container_alignment"]) ? $row["container_alignment"] : '';
$data["status"] = (isset($row["status"])) ? $row["status"] : 'publish';
$data["external_css"] = (isset($row["external_css"]) && $row["external_css"] != "") ? 1: 0;
$data["important_css"] = (isset($row["important_css"]) && $row["important_css"] != "") ? 1 : 0;
// icon
$data["use_fa_icon"] = (isset($row["use_font_awesome_icon"]) && $row["use_font_awesome_icon"] != '') ? 1 : 0;
$data["fa_icon_value"] = (isset($row["font_awesome_icon"])) ? $row["font_awesome_icon"] : '';
$data["fa_icon_size"] = (isset($row["font_awesome_icon_size"])) ? $row["font_awesome_icon_size"] : '';
$data["icon_url"] = (isset($row["icon_url"])) ? $row["icon_url"] : '';
$data["icon_alt"] = (isset($row["icon_alt"])) ? $row["icon_alt"] : '';
$data["icon_position"] = (isset($row["icon_position"])) ? $row["icon_position"] : '';
$data["icon_padding_top"] = (isset($row["icon_padding_top"])) ? $row["icon_padding_top"] : '';
$data["icon_padding_bottom"] = (isset($row["icon_padding_bottom"])) ? $row["icon_padding_bottom"] : '';
$data["icon_padding_left"] = (isset($row["icon_padding_left"])) ? $row["icon_padding_left"] : '';
$data["icon_padding_right"] = (isset($row["icon_padding_right"]))? $row["icon_padding_right"] : '';
// dimension
$data["button_width"] = (isset($row["width"])) ? $row["width"] : '';
$data["button_height"] = (isset($row["height"])) ? $row["height"] : '';
// colorPro
$data["icon_color"] = (isset($row["icon_color"])) ? $row["icon_color"] : '';
$data["icon_color_hover"] = (isset($row["icon_color_hover"])) ? $row["icon_color_hover"] : '';
// textPro
$data["text2"] = $row["text2"];
$data["font2"] = $row["text2_font_family"];
$data["font_size2"] = $row["text2_font_size"];
$data["font_style2"] = $row["text2_font_style"];
$data["font_weight2"] = $row["text2_font_weight"];
$data["padding_top2"] = $row["text2_padding_top"];
$data["padding_right2"] = $row["text2_padding_right"];
$data["padding_bottom2"] = $row["text2_padding_bottom"];
$data["padding_left2"] = $row["text2_padding_left"];
$data["text_align"] = (isset($row["text_align"])) ? $row["text_align"] : '';
$data["text_align2"] = (isset($row["text2_align"])) ? $row["text2_align"] : '';
// here old / new Pro Database fields.
return $data;
}
// Movements version < 8.0 to 8.0 >
public static function migrateResponsive()
{
global $wpdb;
$table = maxUtils::get_table_name();
$sql = "SELECT id, responsive from $table";
$results = $wpdb->get_results($sql, ARRAY_A);
$fieldMap = array(
'button_width' => array('dimension', 'button_width'), // check to add px to this val or not.
'button_width_unit' => array('dimension', 'button_size_unit_width'), // px must be converted to pixel, % prob. to percent!
'button_height' => array('dimension', 'button_height'),
'button_height_unit' => array('dimension', 'button_size_unit_height'), // see above
'container_width' => array('container','container_width'),
'container_float' => array('container','container_alignment' ),
'container_width_unit' => array('container', 'container_width_unit'),
'font_size' => array('text', 'font_size'),
);
// The name of the sizes and it's min-width, max-width.
$sizeNames = array(
'phone' => array(0, 480),
'phone_land' => array(321, 480),
'phone_portrait' => array(0, 320),
'ipad' => array(768, 1024),
'medium_phone' => array(480, 768),
'ipad_land' => array(768, 1024),
'ipad_portrait' => array(768, 1024),
'desktop' => array(1224,0),
'large_desktop' => array(1824,0),
//custom
);
foreach ($results as $row)
{
$id = $row['id'];
$responsive_data = $row['responsive'];
if (is_null($responsive_data))
{
continue;
}
$respdata = json_decode($row['responsive'], true);
if (isset($respdata['auto_responsive']))
unset($respdata['auto_responsive']);
// perhaps have some data?
if (! isset($respdata['media_query']))
{
continue; // no responsive data.
}
elseif (count($respdata['media_query']) == 0)
{
continue; // nope
}
else
{
$mediaq = $respdata['media_query'];
if (isset($mediaq['auto_responsive']))
unset($mediaq['auto_responsive']);
$button = new maxButton();
$button->set($id);
$button_data = $button->get();
$screens = $button->getResponsiveScreens();
if (isset($screens['new']))
unset($screens['new']);
if (isset($screens['default']))
unset($screens['default']);
// screens. loop the sizes.
$responsive = array();
foreach($mediaq as $qsize => $qdata)
{
$fielddata = $qdata;
if (count($fielddata) == 1) // seems there is an extra dimension here.
$fielddata = array_shift($qdata);
$next_id = count($screens) + 1;
$screen = new Screen('rs' . $next_id, array('name' => $qsize) );
$responsive['screens'][] = $screen->id;
// find qsize, add screen, width, height.
if (isset($sizeNames[$qsize]))
{
list($minwidth, $maxwidth) = $sizeNames[$qsize];
}
else // not set, must be custom, use custom_midiwdh
{
$minwidth = isset($fielddata['mq_custom_minwidth']) ? $fielddata['mq_custom_minwidth'] : 0;
$maxwidth = isset($fielddata['mq_custom_maxwidth']) ? $fielddata['mq_custom_maxwidth'] : 0;
}
$responsive[$screen->getFieldID('min_width')] = $minwidth;
$responsive[$screen->getFieldID('max_width')] = $maxwidth;
$responsive[$screen->getFieldID('screen_name')] = $qsize;
if (isset($fielddata['mq_hide']) && $fielddata['mq_hide'] == 'none')
{
$responsive[$screen->getFieldID('hide_screen')] = 1;
}
$button_data['responsive'] = $responsive;
// convert fields.
foreach($fielddata as $fname => $fvalue)
{
if ($fvalue === '')
continue;
$fname = str_replace('mq_', '', $fname);
if (isset($fieldMap[$fname]))
{
list($block, $field) = $fieldMap[$fname];
if (strpos($fname, '_unit') >= 0)
{
if ($fvalue == 'px')
$fvalue = 'pixel';
elseif($fvalue == '%')
$fvalue = 'percent';
}
if ($fname == 'container_float')
{
switch($fvalue)
{
case 'left':
$fvalue ='float: left';
break;
case 'right':
$fvalue ='float: right';
break;
case 'none':
$fvalue ='float: none';
break;
}
}
// echo "$fname set, doing $block and $field for $fvalue <BR>";
$button_data[$block][$screen->getFieldID($field)] = $fvalue;
}
}
$screens[] = $screen;
}
// doing responsive
}
// ok ok
foreach($button_data as $block_name => $block_data)
{
if (is_array($block_data)) // id, document_id returned are not data blocks
$button->setData($block_name, $block_data);
}
$button_data['name'] = $button->getName();
$button_data['status'] = $button->getStatus();
$button_data['updated'] = $button->getUpdated(false);
$button->update($button_data);
} // button
}
public static function deactivate_plugin()
{
delete_option(MAXBUTTONS_VERSION_KEY);
}
public static function maxbuttons_database_table_exists($table_name) {
global $wpdb;
$dbaseTable = $wpdb->get_var("SHOW TABLES LIKE '$table_name'");
if (is_null($dbaseTable))
return false;
else
return strtolower($dbaseTable) == strtolower($table_name);
}
public static function create_database_table() {
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
$table_name = maxUtils::get_table_name();
$button = MB()->getClass('button');
$blocks = $button->getBlocks();
// IMPORTANT: There MUST be two spaces between the PRIMARY KEY keywords
// and the column name, and the column name MUST be in parenthesis.
$sql = "CREATE TABLE " . $table_name . " (
id int(14) NOT NULL AUTO_INCREMENT,
name varchar(100) NULL,
status varchar(10) default 'publish' NOT NULL,
cache text,
";
foreach($blocks as $block)
{
$block_name = $block->get_name();
$sql .= "" . $block_name . " TEXT NULL, \n ";
}
$sql .= "updated TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
created TIMESTAMP DEFAULT 0 NOT NULL,
PRIMARY KEY (id) )";
$result = dbDelta($sql); // always dbdelta
// Reset the cache if there were any left from before
$button->reset_cache();
// Collection table
$collection_table_name = maxUtils::get_collection_table_name();
$sql = "CREATE TABLE " . $collection_table_name . " (
meta_id int(11) NOT NULL AUTO_INCREMENT,
collection_id int(11) NOT NULL,
collection_key varchar(255),
collection_value text,
PRIMARY KEY (meta_id) )
";
dbDelta($sql);
$collection_trans_table = maxUtils::get_coltrans_table_name();
$sql = "CREATE TABLE " . $collection_trans_table . " (
id int(11) NOT NULL AUTO_INCREMENT,
name varchar(1000),
value varchar(255),
expire int(11),
PRIMARY KEY (id) )";
$res = dbDelta($sql);
}
/** Attempt to upgrade UTF table to UTFmb4 - see this article https://make.wordpress.org/core/2015/04/02/the-utf8mb4-upgrade/
*/
public static function upgradeUTF()
{
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
if (! function_exists('maybe_convert_table_to_utf8mb4'))
return; // Versions before 4.2.0
$table_name = maxUtils::get_table_name();
$collection_table_name = maxUtils::get_collection_table_name();
maybe_convert_table_to_utf8mb4($table_name);
maybe_convert_table_to_utf8mb4($collection_table_name);
}
/** Routine for activation for WPMU - All blogs */
public static function call_function_for_each_site($function) {
global $wpdb;
// Hold this so we can switch back to it
$root_blog = $wpdb->blogid;
// Get all the blogs/sites in the network and invoke the function for each one
$blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
foreach ($blog_ids as $blog_id) {
switch_to_blog($blog_id);
call_user_func($function);
}
// Now switch back to the root blog
switch_to_blog($root_blog);
}
} // class
