public function ajax_download_export_file()
 {
     $this->ajax_nonce('not allowed');
     $folder = MYMAIL_UPLOAD_DIR;
     $file = $folder . '/' . $_REQUEST['file'];
     if (!file_exists($file)) {
         die('not found');
     }
     $format = $_REQUEST['format'];
     $filename = basename($file);
     send_nosniff_header();
     nocache_headers();
     switch ($format) {
         case 'html':
             header('Content-Type: text/html; name="' . $filename . '.html"');
             break;
         case 'csv':
             header('Content-Type: text/csv; name="' . $filename . '.csv"');
             header('Content-Transfer-Encoding: binary');
             break;
         default:
             die('format not allowed');
     }
     header('Content-Disposition: attachment; filename="' . basename($file) . '"');
     header('Content-Length: ' . filesize($file));
     header('Connection: close');
     if ($format == 'html') {
         echo '<table>';
     }
     readfile($file);
     if ($format == 'html') {
         echo '</table>';
     }
     mymail_require_filesystem();
     global $wp_filesystem;
     $wp_filesystem->delete($file);
     exit;
 }
 public function verify($options)
 {
     global $mymail;
     if (isset($_POST['mymail_generate_dkim_keys'])) {
         try {
             $res = openssl_pkey_new(array('private_key_bits' => isset($options['dkim_bitsize']) ? (int) $options['dkim_bitsize'] : 512));
             openssl_pkey_export($res, $dkim_private_key);
             $dkim_public_key = openssl_pkey_get_details($res);
             $dkim_public_key = $dkim_public_key["key"];
             $options['dkim_public_key'] = $dkim_public_key;
             $options['dkim_private_key'] = $dkim_private_key;
             add_settings_error('mymail_options', 'mymail_options', __('New DKIM keys have been created!', 'mymail'), 'updated');
         } catch (Exception $e) {
             add_settings_error('mymail_options', 'mymail_options', __('Not able to create new DKIM keys!', 'mymail'));
         }
     }
     if (!empty($_FILES['country_db_file']['name'])) {
         $file = $_FILES['country_db_file'];
         $dest = MYMAIL_UPLOAD_DIR . '/' . $file['name'];
         if (move_uploaded_file($file['tmp_name'], $dest)) {
             if (is_file($dest)) {
                 $options['countries_db'] = $dest;
                 add_settings_error('mymail_options', 'mymail_options', sprintf(__('File uploaded to %s', 'mymail'), '"' . $dest . '"'), 'updated');
             } else {
                 $options['countries_db'] = '';
             }
         } else {
             add_settings_error('mymail_options', 'mymail_options', __('unable to upload file', 'mymail'));
             $options['countries_db'] = '';
         }
     }
     if (!empty($_FILES['city_db_file']['name'])) {
         $file = $_FILES['city_db_file'];
         $dest = MYMAIL_UPLOAD_DIR . '/' . $file['name'];
         if (move_uploaded_file($file['tmp_name'], $dest)) {
             if (is_file($dest)) {
                 $options['cities_db'] = $dest;
                 add_settings_error('mymail_options', 'mymail_options', sprintf(__('File uploaded to %s', 'mymail'), '"' . $dest . '"'), 'updated');
             } else {
                 $options['cities_db'] = '';
             }
         } else {
             add_settings_error('mymail_options', 'mymail_options', __('unable to upload file', 'mymail'));
             $options['cities_db'] = '';
         }
     }
     $verify = array('from', 'reply_to', 'homepage', 'trackcountries', 'trackcities', 'vcard_content', 'custom_field', 'forms', 'form_css', 'send_period', 'bounce', 'cron_service', 'cron_secret', 'interval', 'roles', 'tweet_cache_time', 'deliverymethod', 'dkim_domain', 'dkim_selector', 'dkim_identity', 'dkim_passphrase', 'dkim_private_key', 'purchasecode');
     if (isset($_POST['mymail_import_settings']) && $_POST['mymail_import_settings']) {
         $settings = unserialize(base64_decode($_POST['mymail_import_settings']));
         $options = wp_parse_args($settings, $options);
     }
     foreach ($verify as $id) {
         if (!isset($options[$id])) {
             continue;
         }
         $value = $options[$id];
         $old = mymail_option($id);
         switch ($id) {
             case 'from':
             case 'reply_to':
             case 'bounce':
                 if ($value && !mymail_is_email($value)) {
                     add_settings_error('mymail_options', 'mymail_options', sprintf(__('%s is not a valid email address', 'mymail'), '"' . $value . '"'));
                     $value = $old;
                 }
                 break;
             case 'trackcountries':
                 if (!$options['countries_db'] || !is_file($options['countries_db'])) {
                     add_settings_error('mymail_options', 'mymail_options', __('No country database found! Please load it!', 'mymail'));
                     $value = false;
                 }
                 break;
             case 'trackcities':
                 if (!$options['cities_db'] || !is_file($options['cities_db'])) {
                     add_settings_error('mymail_options', 'mymail_options', __('No city database found! Please load it!', 'mymail'));
                     $value = false;
                 }
                 break;
             case 'homepage':
                 if ($old != $value) {
                     mymail_remove_notice('no-homepage');
                 }
                 break;
             case 'interval':
                 if ($old != $value) {
                 }
                 break;
             case 'cron_service':
                 if ($old != $value) {
                     if ($value == 'wp_cron') {
                         if (!wp_next_scheduled('mymail_cron_worker')) {
                             wp_schedule_event(floor(time() / 300) * 300, 'mymail_cron_interval', 'mymail_cron_worker');
                         }
                     } else {
                         wp_clear_scheduled_hook('mymail_cron_worker');
                     }
                 }
                 break;
             case 'cron_secret':
                 if ($old != $value) {
                     if ($value == '') {
                         $value = md5(uniqid());
                     }
                 }
                 break;
             case 'vcard_content':
                 $folder = MYMAIL_UPLOAD_DIR;
                 if (empty($options['vcard_content'])) {
                     $options['vcard'] = false;
                 }
                 if (!is_dir($folder)) {
                     wp_mkdir_p($folder);
                 }
                 $options['vcard_filename'] = sanitize_file_name($options['vcard_filename']);
                 $filename = $folder . '/' . $options['vcard_filename'];
                 if (!empty($options['vcard'])) {
                     file_put_contents($filename, $options['vcard_content']);
                 } else {
                     if (file_exists($filename)) {
                         @unlink($filename);
                     }
                 }
                 break;
             case 'custom_field':
                 if (serialize($old) != serialize($value)) {
                 }
                 break;
             case 'forms':
                 if (function_exists('add_settings_error')) {
                     foreach ($value as $form) {
                         if (!isset($form['lists']) || empty($form['lists'])) {
                             add_settings_error('mymail_options', 'mymail_options', sprintf(__('Form %s has no assigned lists', 'mymail'), '"' . $form['name'] . '"'));
                         }
                     }
                 }
                 if (serialize($old) != serialize($value)) {
                 }
                 break;
             case 'form_css':
                 if (isset($_POST['mymail_reset_form_css'])) {
                     require_once MYMAIL_DIR . '/includes/static.php';
                     $value = $mymail_form_css;
                     add_settings_error('mymail_options', 'mymail_options', __('Form CSS reseted!', 'mymail'), 'updated');
                 }
                 if ($old != $value) {
                     delete_transient('mymail_form_css');
                     $value = str_replace(array('MYMAIL_URI'), array(MYMAIL_URI), $value);
                     $options['form_css_hash'] = md5(MYMAIL_VERSION . $value);
                 }
                 break;
             case 'send_period':
                 if ($old != $value) {
                     if ($timestamp = get_option('_transient_timeout__mymail_send_period_timeout')) {
                         $new = time() + $value * 3600;
                         update_option('_transient_timeout__mymail_send_period_timeout', $new);
                     } else {
                         update_option('_transient__mymail_send_period_timeout', false);
                     }
                     mymail_remove_notice('dailylimit');
                 }
                 break;
             case 'roles':
                 if (serialize($old) != serialize($value)) {
                     require_once MYMAIL_DIR . '/includes/capability.php';
                     global $wp_roles;
                     if (!$wp_roles) {
                         break;
                     }
                     $newvalue = array();
                     //give admin all rights
                     $value['administrator'] = array();
                     //foreach role
                     foreach ($value as $role => $capabilities) {
                         if (!isset($newvalue[$role])) {
                             $newvalue[$role] = array();
                         }
                         foreach ($mymail_capabilities as $capability => $data) {
                             if (in_array($capability, $capabilities) || 'administrator' == $role) {
                                 $wp_roles->add_cap($role, $capability);
                                 $newvalue[$role][] = $capability;
                             } else {
                                 $wp_roles->remove_cap($role, $capability);
                             }
                         }
                     }
                     $value = $newvalue;
                 }
                 break;
             case 'tweet_cache_time':
                 $value = (int) $value;
                 if ($value < 10) {
                     $value = 10;
                     add_settings_error('mymail_options', 'mymail_options', sprintf(__('The caching time for tweets must be at least %d minutes', 'mymail'), '10'));
                 }
                 break;
             case 'deliverymethod':
                 if ($old != $value) {
                     if ($value == 'gmail') {
                         if ($options['send_limit'] != 500) {
                             $options['send_limit'] = 500;
                             $options['send_period'] = 24;
                             update_option('_transient__mymail_send_period_timeout', false);
                             add_settings_error('mymail_options', 'mymail_options', sprintf(__('Send limit has been adjusted to %d for Gmail', 'mymail'), 500));
                         }
                     }
                 }
                 break;
             case 'dkim_domain':
             case 'dkim_selector':
             case 'dkim_identity':
                 if ($old != $value) {
                     $value = trim($value);
                 }
                 break;
             case 'dkim_private_key':
                 if ($old != $value) {
                     global $wp_filesystem;
                     if (!mymail_require_filesystem('', '', false)) {
                         break;
                     }
                     $folder = MYMAIL_UPLOAD_DIR . '/dkim';
                     //create folder
                     if (!is_dir($folder)) {
                         wp_mkdir_p($folder);
                         $wp_filesystem->put_contents($folder . '/index.php', '<?php //silence is golden ?>', FS_CHMOD_FILE);
                     }
                     //remove old
                     if (isset($options['dkim_private_hash']) && is_file($folder . '/' . $options['dkim_private_hash'] . '.pem')) {
                         $wp_filesystem->delete($folder . '/' . $options['dkim_private_hash'] . '.pem');
                     }
                     $hash = md5($value);
                     if ($wp_filesystem->put_contents($folder . '/' . $hash . '.pem', $value, FS_CHMOD_FILE)) {
                         $options['dkim_private_hash'] = $hash;
                     }
                 }
                 break;
             case 'purchasecode':
                 if ($old != $value && $value) {
                     if (preg_match('#^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$#', $value)) {
                         $envato_plugins = get_option('envato_plugins');
                         if (isset($envato_plugins[MYMAIL_SLUG])) {
                             $envato_plugins[MYMAIL_SLUG]->last_update = 0;
                             update_option('envato_plugins', $envato_plugins);
                         }
                     } else {
                         add_settings_error('mymail_options', 'mymail_options', sprintf(__('The provided purchasecode %s is invalid', 'mymail'), '"' . $value . '"'));
                         $value = '';
                     }
                 }
                 break;
         }
         $options[$id] = $value;
     }
     $options = apply_filters('mymail_verify_options', $options);
     //clear everything thats cached
     mymail_clear_cache();
     return $options;
 }
 public function remove()
 {
     delete_option('mymail_countries');
     global $wp_filesystem;
     mymail_require_filesystem();
     return $wp_filesystem->delete($this->dbfile);
 }
 public function copy_templates()
 {
     global $wpdb;
     if (function_exists('is_multisite') && is_multisite()) {
         $old_blog = $wpdb->blogid;
         $blogids = $wpdb->get_col($wpdb->prepare("SELECT blog_id FROM {$wpdb->blogs}"));
     } else {
         $blogids = array(false);
     }
     mymail_require_filesystem();
     foreach ($blogids as $blog_id) {
         if ($blog_id) {
             switch_to_blog($blog_id);
         }
         $upload_folder = wp_upload_dir();
         if (!is_dir($upload_folder['basedir'] . '/myMail/templates')) {
             wp_mkdir_p($upload_folder['basedir'] . '/myMail/templates');
             copy_dir(MYMAIL_DIR . '/templates', $upload_folder['basedir'] . '/myMail/templates');
         }
     }
     if ($blog_id) {
         switch_to_blog($old_blog);
     }
 }