MSV FM

dot.antimicrobial@66.96.161.157: ~ $
Path : /hermes/sb_web/b2432/ssquaredconstruction.com/wp-content/plugins/backupbuddy/controllers/
File Upload :
Current < : /hermes/sb_web/b2432/ssquaredconstruction.com/wp-content/plugins/backupbuddy/controllers/ajax.php

<?php
/**
 * AJAX Controller
 *
 * backupbuddy_core class always available to functions here.
 *
 * @package BackupBuddy
 */

/**
 * BackupBuddy AJAX Controller
 */
class pb_backupbuddy_ajax extends pb_backupbuddy_ajaxcore {

	/**
	 * Load file based on GET/POST var.
	 *
	 * @todo Evaluate security risks.
	 */
	public function backupbuddy() {
		$function = str_replace( array( '/', '\\' ), '', pb_backupbuddy::_GET( 'function' ) );
		if ( '' == $function ) {
			$function = str_replace( array( '/', '\\' ), '', pb_backupbuddy::_POST( 'function' ) );
		}
		$file = pb_backupbuddy::plugin_path() . '/controllers/ajax/' . $function . '.php';
		if ( ! file_exists( $file ) ) {
			die( '0' );
		}

		pb_backupbuddy::load();
		require_once 'ajax/' . $function . '.php';
		die();
	} // End backupbuddy().

	/**
	 * Access credentials _MUST_ always be checked before allowing any access whatsoever.
	 */
	public function api() {
		die( '0' ); // So... this does nothing?

		// @TODO  Internal security lockout.
		if ( empty( pb_backupbuddy::$options['api_key_test'] ) ) {
			die( '0' );
		}
		if ( 'dsnfilasbfisybfdjybfjalybsfaklsbfa' !== pb_backupbuddy::$options['api_key_test'] ) {
			die( '0' );
		}

		$run = pb_backupbuddy::_POST( 'run' );

		// @TODO  TESTING temp allow GET method.
		if ( '' == $run ) {
			$run = pb_backupbuddy::_GET( 'run' );
		}

		if ( '' == $run ) {
			die(
				json_encode(
					array(
						'success' => false,
						'error'   => 'Error #489384: Missing run command.',
					)
				)
			);
		} else {
			$return = call_user_func( 'backupbuddy_api::' . $run );
			if ( false === $return ) {
				die(
					json_encode(
						array(
							'success' => false,
							'error'   => 'Error #328983: Command failed.',
						)
					)
				);
			} else {
				die(
					json_encode(
						array(
							'success' => true,
							'version' => pb_backupbuddy::settings( 'version' ),
							'data'    => $return,
						)
					)
				);
			}
		}

		die();
	} // end api().

} // end class.