Current File : /var/www/pediatribu/wp-content/plugins/independent-analytics/IAWP/Migrations/Migration_22.php |
<?php
namespace IAWP\Migrations;
use IAWP\Database;
use IAWP\Query;
/** @internal */
class Migration_22 extends \IAWP\Migrations\Step_Migration
{
/**
* @return int
*/
protected function database_version() : int
{
return 22;
}
/**
* @return array
*/
protected function queries() : array
{
return [$this->remove_index(), $this->add_columns(), $this->clip_domains(), $this->reduce_domain_column_size(), $this->populate_group_data(), $this->update_non_grouped_referrers(), $this->match_session_with_new_referrers(), $this->remove_duplicates(), $this->restore_index(), $this->create_direct_referrer(), $this->link_direct_sessions_to_direct_referrer(), $this->drop_referrer_groups()];
}
private function remove_index() : ?string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
if (!Database::has_index($referrers_table, 'referrers_domain_index')) {
return null;
}
return "\n ALTER TABLE {$referrers_table} DROP INDEX referrers_domain_index;\n ";
}
private function add_columns() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
return "\n ALTER TABLE {$referrers_table}\n ADD COLUMN type ENUM('Ad', 'Direct', 'Referrer', 'Search', 'Social'),\n ADD COLUMN referrer VARCHAR(128)\n ";
}
private function clip_domains() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
return "\n UPDATE {$referrers_table}\n SET domain = SUBSTRING(domain, 1, 128)\n WHERE LENGTH(domain) > 128;\n ";
}
private function reduce_domain_column_size() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
return "\n ALTER TABLE {$referrers_table}\n MODIFY COLUMN domain VARCHAR(128) NOT NULL;\n ";
}
private function populate_group_data() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
$referrer_groups_table = Query::get_table_name(Query::REFERRER_GROUPS);
return "\n UPDATE {$referrers_table} AS referrers\n JOIN {$referrer_groups_table} AS referrer_groups ON referrers.domain = referrer_groups.domain_to_match\n SET\n referrers.referrer = referrer_groups.name,\n referrers.type = referrer_groups.type,\n referrers.domain = referrer_groups.domain\n ";
}
private function update_non_grouped_referrers() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
return "\n UPDATE {$referrers_table} AS referrers\n SET type = 'Referrer', referrer = IF(referrers.domain LIKE 'www.%', SUBSTR(referrers.domain, 5), referrers.domain)\n WHERE referrers.referrer IS NULL\n ";
}
private function match_session_with_new_referrers() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
$sessions_table = Query::get_table_name(Query::SESSIONS);
return "\n UPDATE {$sessions_table} AS sessions\n JOIN {$referrers_table} AS referrers ON sessions.referrer_id = referrers.id\n JOIN (\n SELECT\n MIN(referrers.id) AS referrer_id,\n domain,\n type,\n referrer\n FROM {$sessions_table} AS sessions\n JOIN {$referrers_table} AS referrers ON sessions.referrer_id = referrers.id\n WHERE domain IS NOT NULL AND type IS NOT NULL AND referrer IS NOT NULL\n GROUP BY domain, type, referrer\n ) AS first_match\n ON referrers.domain = first_match.domain\n AND referrers.type = first_match.type\n AND referrers.referrer = first_match.referrer\n SET sessions.referrer_id = first_match.referrer_id\n ";
}
private function remove_duplicates() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
$sessions_table = Query::get_table_name(Query::SESSIONS);
return "\n DELETE referrers FROM {$referrers_table} AS referrers\n LEFT JOIN {$sessions_table} AS sessions on referrers.id = sessions.referrer_id\n WHERE sessions.session_id IS NULL\n ";
}
private function restore_index() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
return "\n CREATE UNIQUE INDEX referrers_domain_index ON {$referrers_table} (domain);\n ";
}
private function create_direct_referrer() : string
{
global $wpdb;
$referrers_table = Query::get_table_name(Query::REFERRERS);
return $wpdb->prepare("\n INSERT INTO {$referrers_table}\n (domain, type, referrer)\n VALUES (%s, %s, %s); \n ", '', 'Direct', 'Direct');
}
private function link_direct_sessions_to_direct_referrer() : string
{
$referrers_table = Query::get_table_name(Query::REFERRERS);
$sessions_table = Query::get_table_name(Query::SESSIONS);
return "\n UPDATE {$sessions_table} AS sessions\n SET\n sessions.referrer_id = (\n SELECT id FROM {$referrers_table} WHERE domain = ''\n )\n WHERE sessions.referrer_id IS NULL \n ";
}
private function drop_referrer_groups() : string
{
$referrer_groups_table = Query::get_table_name(Query::REFERRER_GROUPS);
return "\n DROP TABLE IF EXISTS {$referrer_groups_table}\n ";
}
}