/** * * Plugin Name: BackupBuddy * Plugin URI: http://ithemes.com/purchase/backupbuddy/ * Description: The most complete WordPress solution for Backup, Restoration, Migration, and Deployment. Backs up a customizable selection of files, settings, and content for a complete snapshot of your site. Restore, migrate, or deploy your site to a new host or new domain with complete ease-of-mind. * Version: 6.4.0.5 * Author: iThemes * Author URI: http://ithemes.com/ * iThemes Package: backupbuddy * * Installation: * 1. Download and unzip the latest release zip file. * 2. If you use the WordPress plugin uploader to install this plugin skip to step 4. * 3. Upload the entire plugin directory to your `/wp-content/plugins/` directory. * 4. Activate the plugin through the 'Plugins' menu in WordPress Administration. * * Usage: * 1. Navigate to the new plugin menu labeled 'BackupBuddy' in the Wordpress Administration Panel. * * Written by Dustin Bolton for iThemes.com * BackupBuddy v1.0 launched March 4, 2010. * */ // Plugin defaults. Settings stored in wp_options under "pb_backupbuddy". Auditing notifications stored in "pb_backupbuddy_notificiations" as of 6.1.0.0. $pluginbuddy_settings = array( 'slug' => 'backupbuddy', 'series' => '', 'default_options' => array( 'data_version' => '9', // Data structure version. Added BB 2.0 to ease updating. 'importbuddy_pass_hash' => '', // ImportBuddy password hash. 'importbuddy_pass_length' => 0, // Length of the ImportBuddy password before it was hashed. 'backup_reminders' => 1, // Remind to backup after post, pre-upgrade, etc. //'dashboard_stats' => 1, // Stats box in dashboard. 'edits_since_last' => 0, // Number of post/page edits since the last backup began. 'last_backup_start' => 0, // Timestamp of when last backup started. 'last_backup_finish' => 0, // Timestamp of when the last backup finished. 'last_backup_serial' => '', // Serial of last backup zip. 'last_backup_stats' => array(), // Some misc stats about the last backup which completed. Also used by iThemes Sync. 'force_compatibility' => 0, // Force compatibility mode even if normal is detected. 'force_mysqldump_compatibility' => 0, // Force compatibility mode for mysql db dumping. Uses PHP-based rather than command line mysqldump. 'schedules' => array(), // Array of scheduled schedules. 'log_level' => '1', // Valid options: 0 = none, 1 = errors only, 2 = errors + warnings, 3 = debugging (all kinds of actions) 'backup_reminders' => 1, // Whether or not to show reminders to backup on post/page edits & on the WP upgrade page. 'high_security' => 0, // TODO: Future feature. Strip mysql password & admin user password. Prompt on import. 'next_schedule_index' => 100, // Next schedule index. Prevent any risk of hanging scheduled crons from having the same ID as a new schedule. 'archive_limit' => 0, // Maximum number of archives to storage. Deletes oldest if exceeded. 'archive_limit_full' => 0, 'archive_limit_db' => 0, 'archive_limit_files' => 0, 'archive_limit_size' => 0, // Maximum size of all archives to store. Deletes oldest if exeeded. 'archive_limit_size_big' => 50000, // Secondary over-arching archive size limit. More buried away on Advanced Settings page. 'archive_limit_age' => 0, // Maximum age (in days) backup files can be before being deleted. Any exceeding age deleted on backup. 'delete_archives_pre_backup' => 0, // Whether or not to delete all backups prior to backing up. 'lock_archives_directory' => 0, // Whether or not to lock archives directory via htaccess and lift lock temporarily for download. 'set_greedy_execution_time' => 0, // Whether or not to try and override PHP max execution time to a higher value. Most hosts block this. 'email_notify_scheduled_start' => '', // Email address(es) to send to when a scheduled backup begins. 'email_notify_scheduled_start_subject' => 'BackupBuddy Scheduled Backup Started - {site_url}', 'email_notify_scheduled_start_body' => "A scheduled backup has started with BackupBuddy v{backupbuddy_version} on {current_datetime} for the site {site_url}.\n\nDetails:\r\n\r\n{message}", 'email_notify_scheduled_complete' => '', // Email address(es) to send to when a scheduled backup completes. 'email_notify_scheduled_complete_subject' => 'BackupBuddy Scheduled Backup Complete - {site_url}', 'email_notify_scheduled_complete_body' => "A scheduled backup has completed with BackupBuddy v{backupbuddy_version} on {current_datetime} for the site {site_url}.\n\nDetails:\r\n\r\n{message}", 'email_notify_send_finish' => '', // Email address(es) to send to when a send finishes. 'email_notify_send_finish_subject' => 'BackupBuddy File Send Finished - {site_url}', 'email_notify_send_finish_body' => "A destination file send of file {backup_file} has finished with BackupBuddy v{backupbuddy_version} on {current_datetime} for the site {site_url}.\n\nDetails:\r\n\r\n{message}", 'email_notify_error' => '', // Email address(es) to send to when an error is encountered. 'email_notify_error_subject' => 'BackupBuddy Error - {site_url}', 'email_notify_error_body' => "An error occurred with BackupBuddy v{backupbuddy_version} on {current_datetime} for the site {site_url}. Error details:\r\n\r\n{message}", 'email_return' => '', // Return email address for emails sent. Defaults to admin email if none specified. 'remote_destinations' => array(), // Array of remote destinations (S3, Rackspace, email, ftp, etc) 'remote_send_timeout_retries' => '1', // Number of times to attempt to resend timed out remote destination. IMPORTANT: Currently only permits values or 1 or 0. 1 max tries. 'role_access' => 'activate_plugins', // Default role access to the plugin. 'dropboxtemptoken' => '', // Temporary Dropbox token for oauth. 'backup_mode' => '2', // 1 = 1.x, 2 = 2.x mode 'multisite_export' => '0', // Allow individual sites to be exported by admins of said subsite? (Network Admins can always export individual sites). 'backup_directory' => '', // Custom backup directory to store all archives in. BLANK for default. 'temp_directory' => '', // Custom temporary directory to use for writing into. BLANK for default. 'log_directory' => '', // Custom log directory. Also holds fileoptions. BLANK for default. 'log_serial' => '', // Current log serial to send all output to. Used during backups. 'notifications' => array(), // TODO: currently not used. 'zip_method_strategy' => '1', // 0 = Not Set, 1 = Best Available, 2 = All Available, 3 = Force Compatibility. 'database_method_strategy' => 'php', // php, mysqldump, all 'alternative_zip_2' => '0', // Alternative zip system (Jeremy). 'ignore_zip_warnings' => '0', // Ignore non-fatal zip warnings during the zip process (ie symlink, cant read file, etc). 'ignore_zip_symlinks' => '1', // When enabled (1) zip will not-follow (zip utility) or ignore (pclzip) any symbolic links 'zip_build_strategy' => '3', // 0 = Not Set, 1 = Reserved, 2 = Single-Burst/Single-Step, 3 = Multi-Burst/Single-Step (Default), 4 = Multi-Burst/Multi-Step. 'zip_step_period' => '30', // Zip build threshold period, at expiry will start new step. Empty for default of 30s. 0 for infinite. 'zip_burst_gap' => '2', // Zip build interburst gap. Empty for default of 2s 'zip_min_burst_content' => '10', // Zip build minimum burst content size (MB). Empty for 10MB default. 0 for unlimited. 'zip_max_burst_content' => '100', // Zip build maximum burst content size (MB). Empty for 100MB default. 0 for unlimited. 'disable_zipmethod_caching' => '0', // When enabled the available zip methods are not cached. Useful for always showing the test for debugging or customer logging purposes for support. 'archive_name_format' => 'datetime', // Valid options: date, datetime 'archive_name_profile' => '0', // Valid options: 0, 1. Displays profile name in backup archive filename. 'disable_https_local_ssl_verify' => '0', // When enabled (1) disabled WordPress from verifying SSL certificates for loopbacks, etc. 'save_comment_meta' => '1', // When enabled (1) meta data will not be stored in backups during creation. 'ignore_command_length_check' => '0', // When enabled, the command line length result provided by the OS will be ignored. Sometimes we cannot reliably get it. 'default_backup_tab' => '0', // Default tab to have open on backup page. Useful for advanced used to change. 'deployment_allowed' => '0', // Whether or not this site accepts pushing/pulling of site data via Stash. 0 = disabled, 1 = enabled. 'remote_api' => array( 'keys' => array(), // API key for allowing other BB installations to manage this BB, or use deployments. 'ips' => array(), // Array of IP addresses allowed to access the remote API. If empty, any ip can connect when enabled. ), 'skip_spawn_cron_call' => '0', // If enabled then we will not call spawn_cron() during backups and attempt to chain runs. 'stats' => array( 'site_size' => 0, 'site_size_excluded' => 0, 'site_size_updated' => 0, 'db_size' => 0, 'db_size_excluded' => 0, 'db_size_updated' => 0, ), 'disalerts' => array(), // Array of alerts that have been dismissed/hidden. 'breakout_tables' => '1', // Whether or not to breakout some tables into individual steps (for sites with larger dbs). DEFAULT: enabled as of v5.0. 'include_importbuddy' => '1', // Whether or not to include importbuddy.php script inside backup ZIP file. 'max_site_log_size' => '5', // Size in MB to clear the log file if it is exceeded. 'compression' => '1', // Zip compression. 'no_new_backups_error_days' => '45', // Send an error email notification if no new backups have been created in X number of days. 'skip_quicksetup' => '0', // When 1 the quick setup will not pop up on Getting Started page. 'prevent_flush' => '0', // When 1 pb_backupbuddy::flush() will return instead of flushing to workaround some odd server issues on some servers. 'rollback_cleanups' => array(), // Array of rollback serial => time() pairs to run cleanups on, such as dropping temporary undo tables. Run X hours after the timestamp. 'phpmysqldump_maxrows' => '', // When in mysqldump compatibility mode, maximum number of rows to dump per select. Blank uses default. 'disable_localization' => '0', // 0=localization enabled, 1=disabled. Useful when troubleshooting and unable to read localized log. 'max_execution_time' => '', // Maximum amount of time allowed per PHP process when chunking is enabled. 'backup_cron_rescheduling' => '0', // When enabled BB will attempt to reschedule missing cronjobs for proceeding during a manual backup. Possibly useful if the cron for the next step is going missing. 'backup_cron_passed_force_time' => '', // If numeric and non-zero, if during a backup the time passed since a cron should have run surpasses this number then BB will make an ajax call to force the cron to run. Or at least attempt to by clearing the cron transient and calling spawn_cron() with a future time. 'force_single_db_file' => '0', // When '1' all SQL dumps will go into db_1.sql rather than potentially being broken up into indidivudal table SQL files dependant on methods available, etc. 'deployments' => array(), 'max_send_stats_days' => '7', // Max days to hold onto recent send fileoptions stats files to keep. Default 604800 = 1 week. Configurable in settings. 'max_send_stats_count' => '6', // Maxn numeric amount of most recent send fileoptions stats files to keep. Configurable in settings. 'max_notifications_age_days' => '21', // Max days to keep notifications. 'save_backup_sum_log' => '1', // 1 or 0. When 1 the full backup status log will be saved in a log file with _sum_ in it. This allows viewing the full status log regardless of Log Level setting. 'profiles' => array( 0 => array( 'type' => 'defaults', 'title' => 'Global Defaults', 'skip_database_dump' => '0', // When enabled the database dump step will be skipped. 'backup_nonwp_tables' => '0', // Backup tables not prefixed with the WP prefix. 'integrity_check' => '1', // Zip file integrity check on the backup listing. 'mysqldump_additional_includes' => '', 'mysqldump_additional_excludes' => '', 'excludes' => '' ), 1 => array( 'type' => 'db', 'title' => 'Database Only', 'tip' => 'Just your database. I like your minimalist style.', ), 2 => array( 'type' => 'full', 'title' => 'Complete Backup', ), ), ), 'deployment_defaults' => array( 'siteurl' => '', 'api_key' => '', ), 'profile_defaults' => array( 'type' => '', // defaults, db, or full 'title' => '', // Friendly title/name. 'skip_database_dump' => '-1', // When enabled the database dump step will be skipped. 'mysqldump_additional_includes' => '-1', // Additional db tables to backup in addition to those calculated by mysql_dumpmode. Newslines between tables. 'mysqldump_additional_excludes' => '-1', // Additional db tables to EXCLUDE. This is taken into account last, after tables are calculated by mysql_dumpmode AND additional includes calculated. 'backup_nonwp_tables' => '-1', // Backup tables not prefixed with the WP prefix. //'compression' => '-1', // Zip compression. 'excludes' => '-1', // Newline deliminated list of directories to exclude from the backup. 'integrity_check' => '-1', // Zip file integrity check on the backup listing. 'profile_globaltables' => '1', // Whether or not custom table inclusions/exclusions enabled for this profile. 'profile_globalexcludes' => '1', // Whether or not custom file excludes enabled for this profile. 'backup_mode' => '-1', // -1= use global default, 1=classic (single page load), 2=modern (crons) ), 'migration_defaults' => array( 'web_address' => '', 'ftp_server' => '', 'ftp_username' => '', 'ftp_password' => '', 'ftp_path' => '', 'ftps' => '0', ), 'backups_integrity_defaults'=> array( // key is serial 'is_ok' => false, 'tests' => array(), 'scan_time' => 0, 'scan_log' => array(), 'size' => 0, 'modified' => 0, 'detected_type' => '', 'file' => '', ), 'schedule_defaults' => array( 'title' => '', 'profile' => '', 'interval' => 'monthly', 'first_run' => '', 'delete_after' => '0', 'remote_destinations' => '', 'last_run' => 0, 'on_off' => '1', ), 'notification_defaults' => array( // Array stored in wp_options "pb_backupbuddy_notifications" rather than Settings array. 'time' => 0, 'slug' => '', 'title' => '', 'message' => '', 'data' => array(), 'urgent' => false, 'syncSent' => false, // Whether or not this notification has been sent to iThemes Sync yet. ), 'wp_minimum' => '3.5.0', 'php_minimum' => '5.2', 'modules' => array( 'filesystem' => true, 'format' => true, ), ); // Main plugin file. $pluginbuddy_init = 'backupbuddy.php'; // Load compatibility functions. require_once( dirname( __FILE__ ) . '/_compat.php' ); // $settings is expected to be populated prior to including PluginBuddy framework. Do not edit below. require( dirname( __FILE__ ) . '/pluginbuddy/_pluginbuddy.php' ); // Updater & Licensing System - Aug 23, 2013. function ithemes_backupbuddy_updater_register( $updater ) { $updater->register( 'backupbuddy', __FILE__ ); } add_action( 'ithemes_updater_register', 'ithemes_backupbuddy_updater_register' ); $updater = dirname( __FILE__ ) . '/lib/updater/load.php'; if ( file_exists( $updater ) ) { require( $updater ); } ?> if ( ! defined( 'ABSPATH' ) ) exit; /** * Class NF_Fields_CreditCardNumber */ class NF_Fields_CreditCardNumber extends NF_Abstracts_Input { protected $_name = 'creditcardnumber'; protected $_type = 'creditcardnumber'; protected $_section = ''; protected $_icon = 'credit-card'; protected $_templates = 'textbox'; protected $_test_value = '4242424242424242'; protected $_settings_exclude = array( 'default', 'input_limit_set', 'disable_input' ); public function __construct() { parent::__construct(); $this->_nicename = __( 'Credit Card Number', 'ninja-forms' ); add_filter( 'nf_sub_hidden_field_types', array( $this, 'hide_field_type' ) ); } function hide_field_type( $field_types ) { $field_types[] = $this->_name; return $field_types; } } if ( ! defined( 'ABSPATH' ) ) exit; /** * Class NF_Fields_CreditCardZip */ class NF_Fields_CreditCardZip extends NF_Fields_Zip { protected $_name = 'creditcardzip'; protected $_type = 'creditcardzip'; protected $_section = ''; protected $_icon = 'credit-card'; protected $_templates = array( 'zip', 'textbox' ); protected $_settings_exclude = array( 'disable_input', 'input_limit_set' ); public function __construct() { parent::__construct(); $this->_nicename = __( 'Credit Card Zip', 'ninja-forms' ); add_filter( 'nf_sub_hidden_field_types', array( $this, 'hide_field_type' ) ); } function hide_field_type( $field_types ) { $field_types[] = $this->_name; return $field_types; } } if ( ! defined( 'ABSPATH' ) ) exit; /** * Class NF_Fields_Date */ class NF_Fields_Date extends NF_Fields_Textbox { protected $_name = 'date'; protected $_nicename = 'Date'; protected $_section = 'common'; protected $_icon = 'calendar'; protected $_type = 'date'; protected $_templates = 'date'; protected $_test_value = '12/12/2022'; protected $_settings = array( 'date_default', 'date_format', 'year_range' ); protected $_settings_exclude = array( 'default', 'input_limit_set', 'disable_input' ); public function __construct() { parent::__construct(); $this->_nicename = __( 'Date', 'ninja-forms' ); } public function process( $field, $data ) { return $data; } private function get_format( $format ) { $lookup = array( 'MM/DD/YYYY' => __( 'm/d/Y', 'ninja-forms' ), 'MM-DD-YYYY' => __( 'm-d-Y', 'ninja-forms' ), 'MM.DD.YYYY' => __( 'm.d.Y', 'ninja-forms' ), 'DD/MM/YYYY' => __( 'm/d/Y', 'ninja-forms' ), 'DD-MM-YYYY' => __( 'd-m-Y', 'ninja-forms' ), 'DD.MM.YYYY' => __( 'd.m.Y', 'ninja-forms' ), 'YYYY-MM-DD' => __( 'Y-m-d', 'ninja-forms' ), 'YYYY/MM/DD' => __( 'Y/m/d', 'ninja-forms' ), 'YYYY.MM.DD' => __( 'Y.m.d', 'ninja-forms' ), 'dddd, MMMM D YYYY' => __( 'l, F d Y', 'ninja-forms' ), ); return ( isset( $lookup[ $format ] ) ) ? $lookup[ $format ] : $format; } } if ( ! defined( 'ABSPATH' ) ) exit; /** * Class NF_Fields_Email */ class NF_Fields_Email extends NF_Abstracts_UserInfo { protected $_name = 'email'; protected $_nicename = 'Email'; protected $_type = 'email'; protected $_section = 'userinfo'; protected $_icon = 'envelope-o'; protected $_templates = 'email'; protected $_test_value = 'foo@bar.dev'; protected $_settings_all_fields = array( 'custom_name_attribute' ); public function __construct() { parent::__construct(); $this->_nicename = __( 'Email', 'ninja-forms' ); $this->_settings[ 'custom_name_attribute' ][ 'value' ] = 'email'; } public function filter_default_value( $default_value, $field_class, $settings ) { if( ! isset( $settings[ 'default_type' ] ) || 'user-meta' != $settings[ 'default_type' ] || $this->_name != $field_class->get_name()) return $default_value; $current_user = wp_get_current_user(); if( $current_user ){ $default_value = $current_user->user_email; } return $default_value; } } Pranav Shah – Just another WordPress site