File "google-form.php"

Full Path: /home/vantageo/public_html/cache/cache/cache/cache/cache/.wp-cli/wp-content/plugins/wp-database-backup/includes/admin/Destination/Google/google-form.php
File size: 7.97 KB
MIME-type: text/x-php
Charset: utf-8

<?php
/**
 * Destination form.
 *
 * @package wpdbbkp
 */

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}
ob_start();

$update_msg = '';
if ( isset( $_POST['wpdb_google_drive'] ) && 'Y' === $_POST['wpdb_google_drive'] ) {
	// Validate that the contents of the form request came from the current site and not somewhere else added 21-08-15 V.3.4.
	if ( ! isset( $_POST['wpdbbackup_update_google_setting'] ) ) {
		wp_die( esc_html__('Invalid form data. form request came from the somewhere else not current site!','wpdbbkp') );
	}
	if ( ! wp_verify_nonce( $_POST['wpdbbackup_update_google_setting'] , 'wpdbbackup-update-google-setting' ) ) {
		wp_die( esc_html__('Invalid form data. form request came from the somewhere else not current site!','wpdbbkp') );
	}
	$client_id     = '';
	$client_secret = '';
	if ( isset( $_POST['Save'] ) && 'Save' === $_POST['Save'] ) {
		if ( true === isset( $_POST['wpdb_dest_google_client_key'] ) ) {
			$client_id = sanitize_text_field( wp_unslash( $_POST['wpdb_dest_google_client_key'] ) );
		}
		if ( true === isset( $_POST['wpdb_dest_google_secret_key'] ) ) {
			$client_secret = sanitize_text_field( wp_unslash( $_POST['wpdb_dest_google_secret_key'] ) );
		}
		update_option( 'wpdb_dest_google_client_key', wp_db_filter_data( $client_id ) , false);
		update_option( 'wpdb_dest_google_secret_key', wp_db_filter_data( $client_secret ) , false);
	} elseif ( isset( $_POST['Submit'] ) && 'Allow Access' === $_POST['Submit'] ) {
		// Save the posted value in the database.
		if ( true === isset( $_POST['wpdb_dest_google_client_key'] ) ) {
			$client_id = sanitize_text_field( wp_unslash( $_POST['wpdb_dest_google_client_key'] ) );
		}
		if ( true === isset( $_POST['wpdb_dest_google_secret_key'] ) ) {
			$client_secret = sanitize_text_field( wp_unslash( $_POST['wpdb_dest_google_secret_key'] ) );
		}
		update_option( 'wpdb_dest_google_client_key', wp_db_filter_data( $client_id ) , false);
		update_option( 'wpdb_dest_google_secret_key', wp_db_filter_data( $client_secret ) , false);

		require_once 'google-api-php-client/src/Google_Client.php';
		require_once 'google-api-php-client/src/contrib/Google_DriveService.php';

		$client = new Google_Client();
		// Get your credentials from the APIs Console.
		$client->setClientId( $client_id );
		$client->setClientSecret( $client_secret );
		$client->setRedirectUri( site_url() . '/wp-admin/admin.php?page=wp-database-backup&action=auth' );
		$client->setScopes( array( 'https://www.googleapis.com/auth/drive' ) );

		$service = new Google_DriveService( $client );

		$auth_url = $client->createAuthUrl();
		
		if ( isset( $_GET['code'] ) ) {
			update_option( 'wpdb_dest_google_authCode', wp_db_filter_data( sanitize_text_field( wp_unslash( $_GET['code'] ) ) ), false );
		} else {
			if ( isset( $_POST['wpdb_dest_google_client_key'] ) && ! empty( $_POST['wpdb_dest_google_client_key'] ) && isset( $_POST['wpdb_dest_google_secret_key'] ) && ! empty( $_POST['wpdb_dest_google_secret_key'] ) ) {
				wp_redirect( filter_var( $auth_url, FILTER_SANITIZE_URL ) );
				exit;
			}
		}
	} elseif ( isset( $_POST['reset'] ) && 'Reset Configure' === $_POST['reset'] ) {
		update_option( 'wpdb_dest_google_authCode', '' , false);
		wp_safe_redirect( esc_url( site_url() . '/wp-admin/admin.php?page=wp-database-backup' ) );
		exit;
	}

	// Put a "settings updated" message on the screen.
	$update_msg = '<div class="updated"><p><strong>'.esc_html__('Your google drive setting has been saved.', 'wpdbbkp').'</strong></p></div>';
}
if ( isset( $_GET['code'] ) ) {
	update_option( 'wpdb_dest_google_authCode', wp_db_filter_data( sanitize_text_field( wp_unslash( $_GET['code'] ) ) ) , false);
	$wpdbbkp_gdrive_authCode = wp_db_filter_data( sanitize_text_field( wp_unslash( $_GET['code'] ) ) );
}

$wpdb_dest_google_auth_code  = get_option( 'wpdb_dest_google_authCode' );
$wpdb_dest_google_client_key = get_option( 'wpdb_dest_google_client_key' );
$wpdb_dest_google_secret_key = get_option( 'wpdb_dest_google_secret_key' );
$wpdbbkp_gdrive_status			=	'<label><b>'.esc_html__('Status','wpdbbkp').'</b>: '.esc_html__('Not Configured','wpdbbkp').' </label> ';

if(!empty($wpdb_dest_google_auth_code) && !empty($wpdb_dest_google_client_key) && !empty($wpdb_dest_google_secret_key))
{
	$wpdbbkp_gdrive_status='<label><b>'.esc_html__('Status','wpdbbkp').'</b>: <span class="dashicons dashicons-yes-alt" style="color:green;font-size:16px" title="'.esc_attr__('Destination enabled','wpdbbkp').'"></span><span class="configured">'.esc_html__('Configured','wpdbbkp').' </span> </label> ';
}
?>
<div class="panel panel-default">
	<div class="panel-heading">
		<h4 class="panel-title">
			<a data-toggle="collapse" data-parent="#accordion" href="#collapsegoogle">
				<h2><?php echo esc_html__('Google drive', 'wpdbbkp'); ?><?php echo wp_kses_post($wpdbbkp_gdrive_status);?> <span class="dashicons dashicons-admin-generic"></span></h2>
			</a>
		</h4>
	</div>
	<div id="collapsegoogle" class="panel-collapse collapse">
		<div class="panel-body">
			<?php echo esc_html( $update_msg ); ?>
			<form  class="form-group" name="googledrive" method="post" action="">
				<input type="hidden" name="wpdb_google_drive" value="Y">
				<input name="wpdbbackup_update_google_setting" type="hidden" value="<?php echo esc_attr( wp_create_nonce( 'wpdbbackup-update-google-setting' ) ); ?>" />
				<?php
				wp_nonce_field( 'wp-database-backup' );
				if ( ! empty( $wpdb_dest_google_auth_code ) && ! empty( $wpdb_dest_google_client_key ) && ! empty( $wpdb_dest_google_secret_key ) ) {
					?>
					<p class="text-success"><?php echo esc_html__('Configuration to Google Drive Access has been done successfully', 'wpdbbkp') ?></p>
					<p><?php echo esc_html__('By clicking reset, you can reconfigure Google Account', 'wpdbbkp'); ?></p>
					<p><?php echo esc_html__('For local backup click on Reset Configure', 'wpdbbkp'); ?></p>
					<p><input type="submit" name="reset" class="btn btn-primary" value="<?php esc_attr_e( 'Reset Configure' , 'wpdbbkp' ); ?>" />&nbsp;
					</p>
				<?php } else { ?>

					<p><?php echo esc_html__('Back up WordPress database to google drive.', 'wpdbbkp') ?></p>
					<p><?php echo esc_html__('Configure google account, you need to create Client ID &amp; Client secret from the API section ', 'wpdbbkp') ?><a href="https://code.google.com/apis/console/" target="_blank"><?php echo esc_html__('Google API Console', 'wpdbbkp') ?></a><?php echo esc_html__("' also use authorization redirecting url as", 'wpdbbkp') ?> <br>
						<strong> <?php echo esc_url( site_url() . '/wp-admin/admin.php?page=wp-database-backup&action=auth' ); ?></strong></p>
					<p><?php echo esc_html__('For local backup leave the setting as it is', 'wpdbbkp') ?></p>

					<div class="row form-group">
						<label class="col-sm-2" for="wpdb_dest_google_client_key"><?php echo esc_html__('Client ID', 'wpdbbkp') ?></label>
						<div class="col-sm-6">
							<input type="text" id="wpdb_dest_google_client_key" class="form-control" name="wpdb_dest_google_client_key" value="<?php echo esc_html( get_option( 'wpdb_dest_google_client_key' ) ); ?>" size="25" placeholder="<?php esc_attr_e('your client id','wpdbbkp');?>">
						</div>
					</div>

					<div class="row form-group">
						<label class="col-sm-2" for="wpdb_dest_google_secret_key"><?php echo esc_html__('Client secret', 'wpdbbkp') ?></label>
						<div class="col-sm-6">
							<input type="text" id="wpdb_dest_google_secret_key" class="form-control" name="wpdb_dest_google_secret_key" value="<?php echo esc_html( get_option( 'wpdb_dest_google_secret_key' ) ); ?>" size="25" placeholder="<?php esc_attr_e('your client secret key','wpdbbkp');?>">
						</div>
					</div>

					<p><input type="submit" name="Submit" class="btn btn-primary" value="<?php esc_attr_e( 'Allow Access' , 'wpdbbkp' ); ?>" />&nbsp;
						<input type="submit" name="Save" class="btn btn-secondary" value="<?php esc_attr_e( 'Save' , 'wpdbbkp' ); ?>" />&nbsp;
					</p>
				<?php } ?>
			</form>
		</div>
	</div>
</div>