File "cpanel.php"

Full Path: /var/www/bvnghean.vn/save_bvnghean.vn/wp-content/plugins/backupbuddy/lib/cpanel/cpanel.php
File size: 6.74 KB
MIME-type: text/x-php
Charset: utf-8

<?php
/*
EXAMPLE:

require_once( pb_backupbuddy::plugin_path() . '/lib/cpanel/cpanel.php' );
 
$cpanel_user = pb_backupbuddy::_GET( 'user' );
$cpanel_password = pb_backupbuddy::_GET( 'pass' );
$cpanel_host = "foo.com";
$db_name = 'apples';
$db_user = 'oranges';
$db_pass = 'bananas';
$create_db_result = pb_backupbuddy_cpanel::create_db( $cpanel_user, $cpanel_password, $cpanel_host, $db_name, $db_user, $db_pass );

if ( $create_db_result === true ) {
	echo 'Success! Created database, user, and assigned used to database.';
} else {
	echo 'Error(s):<br><pre>' . print_r( $create_db_result, true ) . '</pre>';
}

*/



/*	pb_backupbuddy_cpanel Class
 *	
 *	Manage some cpanel settings.
 *	
 */
class pb_backupbuddy_cpanel {


	// TODO: Use more robust than file_get_contents().

	
	/*	create_db()
	 *	
	 *	Create a database and assign a user to it with all privilages.
	 *	
	 *	@param		
	 *	@return		true|array		Boolean true on success, else an array of errors.
	 */
	public static function create_db( $cpanel_user, $cpanel_password, $cpanel_host, $db_name, $db_user, $db_userpass, $cpanel_port = '2082' ) {
		$cpanel_skin = "x3";
		$errors = array();
		
		$cpanel_password = urlencode( $cpanel_password ); // Pass often has special chars so encode.
		
		// Calculate base URL.
// 		$base_url = "http://{$cpanel_user}:{$cpanel_password}@{$cpanel_host}:{$cpanel_port}/frontend/{$cpanel_skin}";
		$base_url = "http://{$cpanel_user}:{$cpanel_password}@{$cpanel_host}:{$cpanel_port}/execute/Mysql";
		
		// Generate create database URL.
// 		$create_database_url = $base_url . "/sql/addb.html?db={$db_name}";
		$create_database_url = $base_url . "/create_database?name={$cpanel_user}_{$db_name}";
		//echo $create_database_url . '<br>';
		
		
		// Create request core obj for connecting to HTTP.
		$request = new RequestCore( $create_database_url );
		try {
			$result = $request->send_request( true );
		} catch (Exception $e) {
			if ( stristr( $e->getMessage(), 'couldn\'t connect to host' ) !== false ) {
				$errors[] = 'Unable to connect to host `' . $cpanel_host . '` on port `' . $cpanel_port . '`. Verify the cPanel domain/URL and make sure the server is able to initiate outgoing http connections on port ' . $cpanel_port . '. Some hosts block this.';
				return $errors;
			}
			$errors[] = 'Caught exception: ' . $e->getMessage();
			return $errors;
		}
		
		
		// Generate create database user URL.
// 		$create_user_url = $base_url . "/sql/adduser.html?user={$db_user}&pass={$db_userpass}";
		$create_user_url = $base_url . "/create_user?name={$cpanel_user}_{$db_user}&password={$db_userpass}";
		//echo $create_user_url . '<br>';
		
		// Generate assign user database access URL.
// 		$assign_user_url = $base_url . "/sql/addusertodb.html?user={$cpanel_user}_{$db_user}&db={$cpanel_user}_{$db_name}&ALL=ALL";
		$assign_user_url = $base_url . "/set_privileges_on_database?user={$cpanel_user}_{$db_user}&database={$cpanel_user}_{$db_name}&privileges=ALL";
		//echo $assign_user_url . '<br>';
		
		if ( false === $result->isOK() ) {
			$errors[] = 'Unable to create database - response status code: ' .  $result->status;
		} else {	
			$result_array = json_decode( $result->body, true );
			if ( isset( $result_array[ 'status' ] ) && ( 0 == $result_array[ 'status' ] ) ) {
				// status = 0 means a failure
				$errors[] = 'Unable to create database:';
				if ( isset( $result_array[ 'errors' ] ) && ( is_array( $result_array[ 'errors' ] ) ) ) {
					foreach ( $result_array[ 'errors' ] as $error ) {
						$errors[] = $error;
					}
				}
			}
		}
		
// 		if ( stristr( $result, 'Log in' ) !== false ) { // No sucess adding DB.
// 			$errors[] = 'Unable to log into cPanel with given username/password. Verify the credentials are correct for this cPanel domain.';
// 		}
// 		if ( stristr( $result, 'Added the Database' ) === false ) { // No sucess adding DB.
// 			$errors[] = 'Error encountered adding database.';
// 		}
// 		if ( stristr( $result, 'problem creating the database' ) !== false ) { // Something failed.
// 			$errors[] = 'Unable to create database.';
// 		}
// 		if ( stristr( $result, 'database name already exists' ) !== false ) { // DB already exists.
// 			$errors[] = 'The database name already exists.';
// 		}
		
		
		// Run create database user.
		if ( count( $errors ) === 0 ) {
			$request = new RequestCore( $create_user_url );
			try {
				$result = $request->send_request( true );
			} catch (Exception $e) {
				$errors[] = 'Caught exception: ' . $e->getMessage();
				return $errors;
			}
			
			if ( false === $result->isOK() ) {
				$errors[] = 'Unable to creaet user - response status code: ' .  $result->status;
			} else {	
				$result_array = json_decode( $result->body, true );
				if ( isset( $result_array[ 'status' ] ) && ( 0 == $result_array[ 'status' ] ) ) {
					// status = 0 means a failure
					$errors[] = 'Unable to create user:';
					if ( isset( $result_array[ 'errors' ] ) && ( is_array( $result_array[ 'errors' ] ) ) ) {
						foreach ( $result_array[ 'errors' ] as $error ) {
							$errors[] = $error;
						}
					}
				}
			}
		
// 			if ( stristr( $result, 'Added user' ) === false ) { // No success adding user.
// 				$errors[] = 'Error encountered adding user.';
// 			}
// 			if ( stristr( $result, 'You have successfully created a MySQL user' ) === false ) { // No success adding user.
// 				$errors[] = 'Error encountered adding user.';
// 			}
// 			if ( stristr( $result, 'No password given' ) !== false ) { // Already exists.
// 				$errors[] = 'No password given.';
// 			}
// 			if ( stristr( $result, 'exists in the database' ) !== false ) { // Already exists.
// 				$errors[] = 'Username already exists.';
// 			}
		}
		
		// Run assign user to database.
		if ( count( $errors ) === 0 ) {
			$request = new RequestCore( $assign_user_url );
			try {
				$result = $request->send_request( true );
			} catch (Exception $e) {
				$errors[] = 'Caught exception: ' . $e->getMessage();
				return $errors;
			}
			
			if ( false === $result->isOK() ) {
				$errors[] = 'Unable to set privileges for user - response status code: ' .  $result->status;
			} else {	
				$result_array = json_decode( $result->body, true );
				if ( isset( $result_array[ 'status' ] ) && ( 0 == $result_array[ 'status' ] ) ) {
					// status = 0 means a failure
					$errors[] = 'Unable to set privileges for user:';
					if ( isset( $result_array[ 'errors' ] ) && ( is_array( $result_array[ 'errors' ] ) ) ) {
						foreach ( $result_array[ 'errors' ] as $error ) {
							$errors[] = $error;
						}
					}
				}
			}
		
// 			if ( stristr( $result, 'was added to the database' ) === false ) { // No success adding user.
// 				$errors[] = 'Error encountered assigning user to database.';
// 			}
		}
		
		if ( count( $errors ) > 0 ) { // One or more errors.
			return $errors;
		} else {
			return true; // Success!
		}
		
	}

} // end class.