Current Path : /storage/v11800/testtest/public_html/wp-content/plugins/post-smtp/Postman/Postman-Email-Log/ |
Linux v11800 5.3.0-1023-aws #25~18.04.1-Ubuntu SMP Fri Jun 5 15:19:18 UTC 2020 aarch64
|
Current File : /storage/v11800/testtest/public_html/wp-content/plugins/post-smtp/Postman/Postman-Email-Log/PostmanEmailLogMigration.php |
<?php
if( !class_exists( 'PostmanEmailLogsMigration' ) ):
class PostmanEmailLogsMigration {
private $new_logging = false;
private $migrating = false;
private $have_old_logs = false;
private $logging_file = '';
private $logging_file_url = '';
/**
* Constructor PostmanEmailLogsMigration
*
* @since 2.4.0
* @version 1.0.0
*/
public function __construct() {
if( is_multisite() ) {
$this->logging_file = WP_CONTENT_DIR . '/post-smtp-migration-' . get_current_blog_id() . '.log';
$this->logging_file_url = WP_CONTENT_URL . '/post-smtp-migration-' . get_current_blog_id() . '.log';
}
else {
$this->logging_file = WP_CONTENT_DIR . '/post-smtp-migration.log';
$this->logging_file_url = WP_CONTENT_URL . '/post-smtp-migration.log';
}
$this->new_logging = get_option( 'postman_db_version' );
$this->migrating = get_option( 'ps_migrate_logs' );
$this->have_old_logs = $this->have_old_logs();
$hide_notice = get_transient( 'ps_dismiss_update_notice' );
//Show DB Update Notice
if(
( !$hide_notice )
&&
( $this->have_old_logs && !$this->has_migrated() )
||
( $this->has_migrated() && $this->have_old_logs && isset( $_GET['page'] ) && $_GET['page'] == 'postman_email_log' )
) {
add_action( 'admin_notices', array( $this, 'notice' ) );
}
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-migrate-logs' ) {
$this->update_database();
}
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-delete-old-logs' ) {
$this->log( 'Info: Delete old logs' );
$this->trash_all_old_logs();
}
//Add Hook of Migration, Schedule Migration
if( $this->migrating && ( isset( $_GET['page'] ) && $_GET['page'] == 'postman_email_log' ) ) {
add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_script' ) );
}
//Switch back to old system
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-switch-back' ) {
$this->switch_back();
}
//Switch to new system
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-switch-to-new' ) {
$this->switch_to_new();
}
//Revert Migration
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-revert-migration' ) {
$this->revert_migration();
}
//Skip Migration
if( isset( $_GET['action'] ) && $_GET['action'] == 'ps-skip-migration' ) {
$this->skip_migration();
}
add_action( 'wp_ajax_ps-migrate-logs', array( $this, 'migrate_logs' ) );
add_action( 'wp_ajax_ps-db-update-notice-dismiss', array( $this, 'dismiss_update_notice' ) );
}
/**
* Checks if have logs in old system
*
* @since 2.5.0
* @version 1.0.0
*/
public function have_old_logs() {
global $wpdb;
$data = $wpdb->get_results(
"SELECT ID FROM {$wpdb->posts} WHERE post_type = 'postman_sent_mail' LIMIT 1;"
);
if( !empty( $data ) ) {
return true;
}
return false;
}
/**
* Shows DB Update Notice | Action call-back
*
* @since 2.4.0
* @version 1.0.0
*/
public function notice() {
$security = wp_create_nonce( 'ps-migrate-logs' );
$migration_url = admin_url( 'admin.php?page=postman' ) . '&security=' . $security . '&action=ps-migrate-logs';
$delete_url = admin_url( 'admin.php?page=postman_email_log' ) . '&security=' . $security . '&action=ps-delete-old-logs';
$switch_back = admin_url( 'admin.php?page=postman_email_log' ) . '&security=' . $security . '&action=ps-switch-back';
$switch_to_new = admin_url( 'admin.php?page=postman_email_log' ) . '&security=' . $security . '&action=ps-switch-to-new';
$status_url = admin_url( 'admin.php?page=postman_email_log' );
$total_old_logs = wp_count_posts( 'postman_sent_mail' );
$this->migrating = get_option( 'ps_migrate_logs' );
$migrated_logs = $this->get_migrated_count();
$current_page = isset( $_GET['page'] ) ? $_GET['page'] : '';
$new_logging = get_option( 'postman_db_version' );
$dismissible = ( $this->have_old_logs() && !$this->has_migrated() && !$this->migrating ) ? 'is-dismissible' : '';
$revert_url = admin_url( 'admin.php?page=postman_email_log' ) . '&security=' . $security . '&action=ps-revert-migration';
$skip_migration_url = admin_url( 'admin.php?page=postman_email_log' ) . '&security=' . $security . '&action=ps-skip-migration';
?>
<div class="notice ps-db-update-notice <?php echo esc_attr( $dismissible ); ?>" style="border: 1px solid #2271b1; border-left-width: 4px;">
<input type="hidden" value="<?php echo esc_attr( $security ); ?>" class="ps-security">
<p><b><?php _e( 'Post SMTP database update required', 'post-smtp' ); ?></b></p>
<?php if( $this->have_old_logs && !$this->migrating && !$this->is_migrated() ): ?>
<p><?php echo _e( 'Post SMTP has been updated! To keep things running smoothly, we have to update your database to the newest version, migrate email logs to new system. The database update process runs in the background and may take a little while, so please be patient.', 'post-smtp' ); ?></p>
<a href="<?php echo esc_url( $migration_url ) ?>" class="button button-primary">Update and Migrate Logs</a>
<?php endif; ?>
<?php if(
( $this->is_migrated() && $current_page !== 'postman_email_log' )
||
( $this->migrating )
&&
( $current_page !== 'postman_email_log' )
): ?>
<p><?php echo _e( 'Post SMTP is migrating logs to new system.', 'post-smtp' ); ?></p>
<a href="<?php echo esc_url( $status_url ); ?>" class="button button-secondary">View Progress →</a>
<?php endif; ?>
<?php
if(
$this->have_old_logs()
&&
$this->is_migrated()
&&
( $current_page == 'postman_email_log' )
&&
$new_logging
): ?>
<p><?php echo _e( 'Great! You have successfully migrated to new logs.', 'post-smtp' ); ?>
<?php echo file_exists( $this->logging_file ) ? '<a href="'.$this->logging_file_url.'" target="_blank">View Migration Log</a>' : ''; ?>
</p>
<a href="<?php echo esc_url( $switch_back ); ?>" class="button button-primary">View old logs</a>
<a href="<?php echo esc_url( $delete_url ); ?>" class="button button-primary">Delete old Logs</a>
<?php endif; ?>
<?php if(
$this->migrating
&&
( isset( $_GET['page'] ) && $_GET['page'] == 'postman_email_log' )
): ?>
<p><?php _e( 'Post SMTP is migrating logs to new system.', 'post-smtp' ); ?></p>
<?php endif; ?>
<?php if(
!$new_logging
&&
$this->is_migrated()
&&
$this->have_old_logs()
&&
$current_page == 'postman_email_log'
): ?>
<a href="<?php echo esc_url( $switch_to_new ); ?>" class="button button-primary">Switch to new System</a>
<?php endif; ?>
<?php
if(
$this->have_old_logs()
&&
$this->migrating
&&
( $current_page == 'postman_email_log' )
&&
$new_logging
): ?>
<a href="<?php echo esc_url( $switch_back ); ?>" class="button button-primary">View old logs</a>
<?php endif; ?>
<?php if(
!$new_logging
&&
$this->migrating
&&
$this->have_old_logs()
&&
$current_page == 'postman_email_log'
): ?>
<a href="<?php echo esc_url( $switch_to_new ); ?>" class="button button-primary">Switch to new System</a>
<?php endif; ?>
<a href="https://postmansmtp.com/new-and-better-email-log-post-smtp-feature-update/" target="__blank" class="button button-secondary">Learn about migration</a>
<div style="float: right">
<?php
//Revert Migration
if( $this->have_old_logs() && $new_logging ) {
?>
<a href="<?php echo esc_url( $revert_url ); ?>" style="font-size: 13px;">Revert Migration</a>
<br>
<?php
}
if( $this->have_old_logs() ) {
?>
<a href="<?php echo esc_url( $skip_migration_url ); ?>" style="font-size: 13px;">Switch to new logs without migration</a>
<?php
}
?>
</div>
<div style="clear: both;"></div>
<div style="margin: 10px 0;"></div>
<?php
if(
$this->migrating
&&
( isset( $_GET['page'] ) && $_GET['page'] == 'postman_email_log' )
) {
?>
<div class="ps-migration-box" style="text-align: center; width: 100%; margin: 10px 0;">
<progress style="width: 100%;" id="ps-migration-progress" value="<?php echo esc_attr( $migrated_logs ); ?>" max="<?php echo esc_attr( $total_old_logs->private ); ?>"></progress>
<h5 id="ps-progress"><?php echo esc_attr( "{$migrated_logs}/ {$total_old_logs->private}" ); ?></h5>
</div>
<?php
}
?>
</div>
<?php
if(
$this->have_old_logs
&&
$this->migrating
&&
!$this->is_migrated()
&&
( isset( $_GET['page'] ) && $_GET['page'] == 'postman_email_log' )
) {
?>
<?php
}
}
/**
* Updates Database
*
* @since 2.5.0
* @version 1.0.0
*/
public function update_database() {
if( !wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
$this->log( 'Error: Creating table, Nonce Verification Failed' );
return;
}
$this->log( 'Info: Creating table' );
//Let's start migration
$email_logs = new PostmanEmailLogs;
$email_logs->install_table();
$this->log( 'Info: Table created' );
if( $this->have_old_logs && !$this->migrating ) {
update_option( 'ps_migrate_logs', 1 );
}
}
/**
* Gets last old log, to be migrated
*
* @since 2.5.0
* @version 1.0.0
*/
public function get_last_old_log() {
global $wpdb;
return $wpdb->get_results(
"SELECT * FROM {$wpdb->postmeta} WHERE post_id = ( SELECT ID FROM {$wpdb->posts} ORDER BY ID DESC LIMIT 1 )"
);
}
/**
* Migrate Logs | AJAX call-back
*
* @since 2.5.0
* @version 1.0.0
*/
public function migrate_logs() {
if( wp_verify_nonce( $_POST['security'], 'ps-migrate-logs' ) ) {
if( isset( $_POST['action'] ) && $_POST['action'] == 'ps-migrate-logs' ) {
if( $this->have_old_logs ) {
$this->log( 'Info: `migrate_logs` Have old logs' );
$old_logs = $this->get_old_logs();
if( $old_logs && !empty( $old_logs )) {
//Migrating Logs
foreach( $old_logs as $ID => $log ) {
$this->log( 'Info: `migrate_logs` Remove extra keys if contains: ' . print_r( array_keys( $log ), true ) );
$log = $this->remove_extra_keys( $log );
$this->log( 'Info: `migrate_logs` Migrating Log: ' . print_r( array_keys( $log ), true ) );
$result = PostmanEmailLogs::get_instance()->save( $log );
if( $result ) {
$this->log( 'Info: `migrate_logs` Log migrated' );
$result = wp_update_post(
array(
'ID' => $ID,
'pinged' => 1
)
);
}
else {
$this->log( 'Error: `migrate_logs` Log not migrated: ID: ' . $ID . print_r( array_keys( $log ), true ) );
}
}
//If all migrated
if( $this->get_migrated_count() == wp_count_posts( 'postman_sent_mail' )->private ) {
$this->log( 'Info: `migrate_logs` All logs migrated' );
delete_option( 'ps_migrate_logs' );
wp_send_json_success(
array(
'migrated' => $this->get_migrated_count(),
'total' => wp_count_posts( 'postman_sent_mail' )->private
),
200
);
}
$this->log( 'Info: `migrate_logs` Logs migrated: ' . $this->get_migrated_count(). ' Out of ' . wp_count_posts( 'postman_sent_mail' )->private );
wp_send_json_success(
array(
'migrated' => $this->get_migrated_count()
),
200
);
}
}
}
}
}
/**
* Enqueue Scripts | Action call-back
*
* @since 2.5.0
* @version 1.0.0
*/
public function enqueue_script() {
wp_enqueue_script( 'ps-migrate', POST_SMTP_URL . '/script/logs-migration.js', array( 'jquery' ), array(), true );
}
/**
* Get old logs
*
* @param $limit String
* @since 2.5.0
* @version 1.0.0
*/
public function get_old_logs( $limit = 500 ) {
global $wpdb;
$logs = $wpdb->get_results(
$wpdb->prepare(
"SELECT p.ID, p.post_date FROM {$wpdb->posts} AS p WHERE p.post_type = 'postman_sent_mail' && p.pinged != 1 LIMIT %d;",
$limit
),
OBJECT_K
);
$log_ids = array_keys( $logs );
$log_ids = implode( ',', $log_ids );
$this->log( 'Info: `get_old_logs` Log IDs: ' . $log_ids );
if( $log_ids ) {
$logs_meta = $wpdb->get_results(
"SELECT post_id as ID, meta_key, meta_value FROM {$wpdb->postmeta} WHERE post_id IN ({$log_ids});"
);
$this->log( 'Info: `get_old_logs` Logs Meta ' );
/**
* Filter to delete incomplete logs, force migration
*
* @param bool
* @since 2.5.0
* @version 1.0.0
*/
if( empty( $logs_meta ) ) {
$this->log( 'Error: `get_old_logs` No logs meta found: ', $logs_meta );
$log_ids = explode( ',', $log_ids );
foreach( $log_ids as $ID ) {
$this->log( 'Error: `get_old_logs` Marking as pinged: ' . $ID );
wp_delete_post( $ID, true );
}
return true;
}
if( $logs_meta ) {
//Preparing logs
foreach( $logs_meta as $log_meta ) {
if( isset( $prepared_logs[$log_meta->ID] ) ) {
$prepared_logs[$log_meta->ID][$log_meta->meta_key] = $log_meta->meta_value;
}
else {
$prepared_logs[$log_meta->ID] = array(
$log_meta->meta_key => $log_meta->meta_value,
'time' => strtotime( $logs[$log_meta->ID]->post_date )
);
}
}
$this->log( 'Info: `get_old_logs` Prepared Logs' );
return $prepared_logs;
}
return false;
}
return false;
}
/**
* Gets migrated logs Count
*
* @since 2.5.0
* @version 1.0.0
*/
public function get_migrated_count() {
global $wpdb;
$response = $wpdb->get_results(
"SELECT
count(*) AS count
FROM
{$wpdb->posts}
WHERE
post_type = 'postman_sent_mail'
&&
pinged = 1"
);
return empty( $response ) ? false : (int)$response[0]->count;
}
/**
* Checks if logs migrated or not
*
* @since 2.5.0
* @version 1.0.0
*/
public function is_migrated() {
$total_old_logs = wp_count_posts( 'postman_sent_mail' )->private;
if( $this->get_migrated_count() == (int)$total_old_logs ) {
delete_option( 'ps_migrate_logs' );
return true;
}
return false;
}
/**
* Trash all old logs
*
* @since 2.5.0
* @version 1.0.0
*/
public function trash_all_old_logs() {
if( wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
global $wpdb;
$result = $wpdb->get_results(
"SELECT ID
FROM {$wpdb->posts}
WHERE post_type = 'postman_sent_mail';",
OBJECT_K
);
$log_ids = array_keys( $result );
$log_ids = implode( ',', $log_ids );
$this->log( 'Info: `trash_all_old_logs` Delete log IDs: ' . $log_ids );
$result = $wpdb->get_results(
"DELETE p.*, pm.*
FROM {$wpdb->posts} AS p
INNER JOIN
{$wpdb->postmeta} AS pm
ON p.ID = pm.post_id
WHERE p.post_type = 'postman_sent_mail' && p.ID IN ({$log_ids});"
);
$result = $result ? 'Successfully deleted' : 'Failed';
$this->log( 'Info: `trash_all_old_logs` Delete result: ' . print_r( $result, true ) );
//Delete log file
if( file_exists( $this->logging_file ) ) {
unlink( $this->logging_file );
}
wp_redirect( admin_url( 'admin.php?page=postman_email_log' ) );
}
}
/**
* Switch back to old logs
*
* @since 2.5.0
* @version 1.0.0
*/
public function switch_back() {
if( wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
$this->log( 'Info: `switch_back` Switching to old system' );
delete_option( 'postman_db_version' );
wp_redirect( admin_url( 'admin.php?page=postman_email_log' ) );
}
}
/**
* Switch to new system
*
* @since 2.5.0
* @version 1.0.0
*/
public function switch_to_new() {
if( wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
$this->log( 'Info: `switch_to_new` Switching to new system' );
update_option( 'postman_db_version', POST_SMTP_DB_VERSION );
wp_redirect( admin_url( 'admin.php?page=postman_email_log' ) );
}
}
/**
* Remove Extra Keys
*
* @param array $array
* @since 2.5.0
* @version 1.0.0
*/
public function remove_extra_keys( $array ) {
$allowedKeys = array(
'solution',
'success',
'from_header',
'to_header',
'cc_header',
'bcc_header',
'reply_to_header',
'transport_uri',
'original_to',
'original_subject',
'original_message',
'original_headers',
'session_transcript',
'time'
);
foreach ( $array as $key => $value ) {
if ( !in_array( $key, $allowedKeys ) ) {
unset( $array[$key] );
}
}
return $array;
}
/**
* Create log file
*
* @since 2.5.0
* @version 1.0.0
*/
public function create_log_file() {
if( !file_exists( $this->logging_file ) ) {
$site_url = site_url();
$logging = fopen( $this->logging_file, 'w' );
if( $logging ) {
fwrite( $logging, 'Migration log: ' . $site_url . PHP_EOL );
fwrite( $logging, 'Info, Error' . PHP_EOL );
fclose( $logging );
}
}
}
/**
* Write to log file | Info and Error, only two types
*
* @param string $message
* @since 2.5.0
* @version 1.0.0
*/
public function log( $message ) {
if( !file_exists( $this->logging_file ) ) {
$this->create_log_file();
}
if( file_exists( $this->logging_file ) ) {
$logging = fopen( $this->logging_file, 'a' );
if( $logging ) {
fwrite( $logging, '[' . date( 'd-m-Y h:i:s' ) . '] ->' . $message . PHP_EOL );
fclose( $logging );
}
}
}
/**
* Checks if logs migrated or not | Same as is_migrated() but used custom query
*
* @since 2.5.2
* @version 1.0.0
*/
public function has_migrated() {
global $wpdb;
$response = $wpdb->get_results(
"SELECT
count(*) AS count
FROM
{$wpdb->posts}
WHERE
post_type = 'postman_sent_mail'"
);
$total_old_logs = empty( $response ) ? 0 : (int)$response[0]->count;
if( $this->get_migrated_count() >= (int)$total_old_logs ) {
return true;
}
return false;
}
/**
* Dismiss update notice | AJAX call-back
*
* @since 2.5.2
* @version 1.0.0
*/
public function dismiss_update_notice() {
if( isset( $_POST['action'] ) && $_POST['action'] == 'ps-db-update-notice-dismiss' && wp_verify_nonce( $_POST['security'], 'ps-migrate-logs' ) ) {
set_transient( 'ps_dismiss_update_notice', 1, WEEK_IN_SECONDS );
}
}
/**
* Revert migration
*
* @since 2.5.2
* @version 1.0.0
*/
public function revert_migration() {
if( wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
$this->log( 'Info: `revert_migration` Reverting Migration' );
$email_logs = new PostmanEmailLogs;
delete_option( 'ps_migrate_logs' );
$this->log( 'Info: `revert_migration` Deleted option ps_migrate_logs' );
if( $email_logs->uninstall_tables() ) {
$this->log( 'Info: `revert_migration` Tables Uninstalled' );
global $wpdb;
$response = $wpdb->query(
"UPDATE {$wpdb->posts} SET pinged = '' WHERE post_type = 'postman_sent_mail';"
);
if( $response ) {
$this->log( 'Info: `revert_migration` pinged unset' );
}
}
wp_redirect( admin_url( 'admin.php?page=postman_email_log' ) );
}
}
/**
* Skip migration
*
* @since 2.5.2
* @version 1.0.0
*/
public function skip_migration() {
if( wp_verify_nonce( $_GET['security'], 'ps-migrate-logs' ) ) {
$this->log( 'Info: `skip_migration` Skipping Migration' );
delete_option( 'ps_migrate_logs' );
$this->log( 'Info: `skip_migration` Deleted option ps_migrate_logs' );
$email_logs = new PostmanEmailLogs;
$email_logs->install_table();
$this->log( 'Info: Table created' );
global $wpdb;
$result = $wpdb->get_results(
"SELECT ID
FROM {$wpdb->posts}
WHERE post_type = 'postman_sent_mail';",
OBJECT_K
);
$log_ids = array_keys( $result );
$log_ids = implode( ',', $log_ids );
$this->log( 'Info: `trash_all_old_logs` Delete log IDs: ' . $log_ids );
$result = $wpdb->get_results(
"DELETE p.*, pm.*
FROM {$wpdb->posts} AS p
INNER JOIN
{$wpdb->postmeta} AS pm
ON p.ID = pm.post_id
WHERE p.post_type = 'postman_sent_mail' && p.ID IN ({$log_ids});"
);
$result = $result ? 'Successfully deleted' : 'Failed';
$this->log( 'Info: `trash_all_old_logs` Delete result: ' . print_r( $result, true ) );
wp_redirect( admin_url( 'admin.php?page=postman_email_log' ) );
}
}
}
new PostmanEmailLogsMigration;
endif;