org.jclouds.smartos.compute.strategy
Class SmartOSComputeServiceAdapter

java.lang.Object
  extended by org.jclouds.smartos.compute.strategy.SmartOSComputeServiceAdapter
All Implemented Interfaces:
ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

@Singleton
public class SmartOSComputeServiceAdapter
extends Object
implements ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

defines the connection between the SmartOSHost implementation and the jclouds ComputeService


Nested Class Summary
 
Nested classes/interfaces inherited from interface org.jclouds.compute.ComputeServiceAdapter
ComputeServiceAdapter.NodeAndInitialCredentials<N>
 
Constructor Summary
SmartOSComputeServiceAdapter(SmartOSHost host)
           
 
Method Summary
 ComputeServiceAdapter.NodeAndInitialCredentials<VM> createNodeWithGroupEncodedIntoName(String tag, String name, Template template)
          ComputeService.createNodesInGroup(String, int, Template) generates the parameters passed into this method such that each node in the set has a unique name.
 void destroyNode(String id)
           
 DataSet getImage(String id)
          get a specific image by id
 VM getNode(String id)
           
 Iterable<VmSpecification> listHardwareProfiles()
          Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.
 Iterable<DataSet> listImages()
          Images are the available configured operating systems that someone can run a node with.
 Iterable<SmartOSHost> listLocations()
           
 Iterable<VM> listNodes()
           
 void rebootNode(String id)
           
 void resumeNode(String id)
           
 void suspendNode(String id)
           
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

SmartOSComputeServiceAdapter

@Inject
public SmartOSComputeServiceAdapter(SmartOSHost host)
Method Detail

createNodeWithGroupEncodedIntoName

public ComputeServiceAdapter.NodeAndInitialCredentials<VM> createNodeWithGroupEncodedIntoName(String tag,
                                                                                              String name,
                                                                                              Template template)
Description copied from interface: ComputeServiceAdapter
ComputeService.createNodesInGroup(String, int, Template) generates the parameters passed into this method such that each node in the set has a unique name.

note

It is intentional to return the library native node object, as generic type N. If you are not using library-native objects (such as libvirt Domain) use JCloudsNativeComputeServiceAdapter instead.

note

Your responsibility is to create a node with the underlying library and return after storing its credentials in the supplied map corresponding to credentialStore

Specified by:
createNodeWithGroupEncodedIntoName in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>
Parameters:
tag - used to aggregate nodes with identical configuration
name - unique supplied name for the node, which has the group encoded into it.
template - includes imageId, locationId, and hardwareId used to resume the instance.
Returns:
library-native representation of a node. TODO: return typed exception on createNodeFailure
See Also:
ComputeService.createNodesInGroup(String, int, Template)

listHardwareProfiles

public Iterable<VmSpecification> listHardwareProfiles()
Description copied from interface: ComputeServiceAdapter
Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.

To implement this method, return the library native hardware profiles available to the user. These will be used to launch nodes as a part of the template.

Specified by:
listHardwareProfiles in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>
Returns:
a non-null iterable of available hardware profiles.
See Also:
ComputeService.listHardwareProfiles()

listImages

public Iterable<DataSet> listImages()
Description copied from interface: ComputeServiceAdapter
Images are the available configured operating systems that someone can run a node with.

To implement this method, return the library native images available to the user. These will be used to launch nodes as a part of the template.

Specified by:
listImages in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>
Returns:
a non-null iterable of available images.
See Also:
ComputeService.listImages()

getImage

public DataSet getImage(String id)
Description copied from interface: ComputeServiceAdapter
get a specific image by id

Specified by:
getImage in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>
Parameters:
id - ComputeMetadata.getId(), which is not necessarily ComputeMetadata.getProviderId()
Returns:
image or null if not exists.

listNodes

public Iterable<VM> listNodes()
Specified by:
listNodes in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

listLocations

public Iterable<SmartOSHost> listLocations()
Specified by:
listLocations in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

getNode

public VM getNode(String id)
Specified by:
getNode in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

destroyNode

public void destroyNode(String id)
Specified by:
destroyNode in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

rebootNode

public void rebootNode(String id)
Specified by:
rebootNode in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

resumeNode

public void resumeNode(String id)
Specified by:
resumeNode in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>

suspendNode

public void suspendNode(String id)
Specified by:
suspendNode in interface ComputeServiceAdapter<VM,VmSpecification,DataSet,SmartOSHost>


Copyright © 2009-2012 jclouds. All Rights Reserved.