Location: PHPKode > projects > php-opencloud > php-opencloud-master/lib/instance.php
<?php
/**
 * A Cloud Databases instance (similar to a Compute Server)
 *
 * @copyright 2012-2013 Rackspace Hosting, Inc.
 * See COPYING for licensing information
 *
 * @package phpOpenCloud
 * @version 1.0
 * @author Glen Campbell <hide@address.com>
 */

namespace OpenCloud\DbService;

require_once(__DIR__.'/persistentobject.php');
require_once(__DIR__.'/database.php');
require_once(__DIR__.'/user.php');

/**
 * Instance represents an instance of DbService, similar to a Server in a
 * Compute service
 *
 * @author Glen Campbell <hide@address.com>
 */
class Instance extends \OpenCloud\PersistentObject {

	public
		$id,
		$name,
		$status,
		$links,
		$hostname,
		$volume,
		$created,
		$updated,
		$flavor;
	
	protected static
		$json_name = 'instance',
		$url_resource = 'instances';

	private
		$_databases,	// used to Create databases simultaneously
		$_users;		// used to Create users simultaneously

	/**
	 * Creates a new instance object
	 *
	 * This could use the default constructor, but we want to make sure that
	 * the volume attribute is an object.
	 *
	 * @param \OpenCloud\DbService $service the DbService object associated 
	 *		with this
	 * @param mixed $info the ID or array of info for the object
	 */
	public function __construct(\OpenCloud\DbService $service, $info=NULL) {
		$this->volume = new \stdClass();
		return parent::__construct($service, $info);
	}

	/**
	 * Updates a database instance (not permitted)
	 *
	 * Update() is not supported by database instances; thus, this always
	 * throws an exception.
	 *
	 * @throws InstanceUpdateError always
	 */
	public function Update($params=array()) {
		throw new InstanceUpdateError(
			_('Updates are not currently supported by Cloud Databases'));
	}

	/**
	 * Restarts the database instance
	 *
	 * @api
	 * @returns \OpenCloud\HttpResponse
	 */
	public function Restart() {
		return $this->Action($this->RestartJson());
	}

	/**
	 * Resizes the database instance (sets RAM)
	 *
	 * @api
	 * @param \OpenCloud\Compute\Flavor $flavor a flavor object
	 * @returns \OpenCloud\HttpResponse
	 */
	public function Resize(\OpenCloud\Compute\Flavor $flavor) {
		return $this->Action($this->ResizeJson($flavor));
	}

	/**
	 * Resizes the volume associated with the database instance (disk space)
	 *
	 * @api
	 * @param integer $newvolumesize the size of the new volume, in gigabytes
	 * @return \OpenCloud\HttpResponse
	 */
	public function ResizeVolume($newvolumesize) {
		return $this->Action($this->ResizeVolumeJson($newvolumesize));
	}

	/**
	 * Enables the root user for the instance
	 *
	 * @api
	 * @return User the root user, including name and password
	 * @throws InstanceError if HTTP response is not Success
	 */
	public function EnableRootUser() {
		$response = $this->Service()->Request($this->Url('root'), 'POST');

		// check response
		if ($response->HttpStatus() > 202)
			throw New InstanceError(sprintf(
				_('Error enabling root user for instance [%s], '.
				  'status [%d] response [%s]'),
				$this->name, $response->HttpStatus(), $response->HttpBody()));

		$obj = json_decode($response->HttpBody());
		if ($this->CheckJsonError())
			return FALSE;
		if (isset($obj->user))
			return new User($this, $obj->user);
		else
			return FALSE;
	}

	/**
	 * Returns TRUE if the root user is enabled
	 *
	 * @api
	 * @return boolean TRUE if the root user is enabled; FALSE otherwise
	 * @throws InstanceError if HTTP status is not Success
	 */
	public function IsRootEnabled() {
		$response = $this->Service()->Request($this->Url('root'), 'GET');

		// check response
		if ($response->HttpStatus() > 202)
			throw New InstanceError(sprintf(
				_('Error enabling root user for instance [%s], '.
				  'status [%d] response [%s]'),
				$this->name, $response->HttpStatus(), $response->HttpBody()));

		$obj = json_decode($response->HttpBody());
		if ($this->CheckJsonError())
			return FALSE;
		if (isset($obj->rootEnabled) && $obj->rootEnabled)
			return TRUE;
		else
			return FALSE;
	}

	/********** FACTORY METHODS **********/

	/**
	 * Returns a new Database object
	 *
	 * @param string $name the database name
	 * @return Database
	 */
	public function Database($name='') {
	    return new Database($this, $name);
	}

	/**
	 * Returns a new User object
	 *
	 * @param string $name the user name
	 * @param array $databases a simple array of database names
	 * @return User
	 */
	public function User($name='', $databases=array()) {
	    return new User($this, $name, $databases);
	}

	/**
	 * Returns a Collection of all databases in the instance
	 *
	 * @return Collection
	 * @throws DatabaseListError if HTTP status is not Success
	 */
	public function DatabaseList() {
		$response = $this->Service()->Request($this->Url('databases'));

		// check response status
		if ($response->HttpStatus() > 200)
			throw new DatabaseListError(sprintf(
				_('Error listing databases for instance [%s], '.
				  'status [%d] response [%s]'),
				$this->name, $response->HttpStatus(), $response->HttpBody()));

		// parse the response
		$obj = json_decode($response->HttpBody());
		if (!$this->CheckJsonError()) {
			if (!isset($obj->databases))
				return new \OpenCloud\Collection(
					$this, '\OpenCloud\DbService\Database', array());
			return new \OpenCloud\Collection(
				$this, '\OpenCloud\DbService\Database', $obj->databases);
		}
		return FALSE;
	}

	/**
	 * Returns a Collection of all users in the instance
	 *
	 * @return Collection
	 * @throws UserListError if HTTP status is not Success
	 */
	public function UserList() {
		$response = $this->Service()->Request($this->Url('users'));

		// check response status
		if ($response->HttpStatus() > 200)
			throw new UserListError(sprintf(
				_('Error listing users for instance [%s], '.
				  'status [%d] response [%s]'),
				$this->name, $response->HttpStatus(), $response->HttpBody()));

		// parse the response
		$obj = json_decode($response->HttpBody());
		if (!$this->CheckJsonError()) {
			if (!isset($obj->users))
				return new \OpenCloud\Collection(
					$this, '\OpenCloud\DbService\User', array());
			return new \OpenCloud\Collection(
				$this, '\OpenCloud\DbService\User', $obj->users);
		}
		return FALSE;
	}

	/********** PROTECTED METHODS **********/

	/**
	 * Generates the JSON string for Create()
	 *
	 * @return \stdClass
	 */
	protected function CreateJson() {
	    $obj = new \stdClass();
	    $obj->instance = new \stdClass();

	    // flavor
	    if (!isset($this->flavor))
	        throw new InstanceFlavorError(
	            _('a flavor must be specified'));
	    if (!is_object($this->flavor))
	        throw new InstanceFlavorError(
	            _('the [flavor] attribute must be a Flavor object'));
	    $obj->instance->flavorRef = $this->flavor->links[0]->href;

	    // name
	    if (!isset($this->name))
	        throw new InstanceError(
	            _('Instance name is required'));
	    $obj->instance->name = $this->name;

	    // volume
	    $obj->instance->volume = $this->volume;

		return $obj;
	}

	/********** PRIVATE METHODS **********/

	/**
	 * Generates the JSON object for Restart
	 */
	private function RestartJson() {
		$obj = new \stdClass();
		$obj->restart = new \stdClass();
		return $obj;
	}

	/**
	 * Generates the JSON object for Resize
	 */
	private function ResizeJson($flavorRef) {
		$obj = new \stdClass();
		$obj->resize = new \stdClass();
		$obj->resize->flavorRef = $flavorRef;
		return $obj;
	}

	/**
	 * Generates the JSON object for ResizeVolume
	 */
	private function ResizeVolumeJson($size) {
		$obj = new \stdClass();
		$obj->resize = new \stdClass();
		$obj->resize->volume = new \stdClass();
		$obj->resize->volume->size = $size;
		return $obj;
	}

}
Return current item: php-opencloud