Class ServerManagerComputeServiceAdapter
- java.lang.Object
-
- org.jclouds.servermanager.compute.strategy.ServerManagerComputeServiceAdapter
-
- All Implemented Interfaces:
ComputeServiceAdapter<Server,Hardware,Image,Datacenter>
@Singleton public class ServerManagerComputeServiceAdapter extends Object implements ComputeServiceAdapter<Server,Hardware,Image,Datacenter>
defines the connection between theServerManager
implementation and the jcloudsComputeService
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.jclouds.compute.ComputeServiceAdapter
ComputeServiceAdapter.NodeAndInitialCredentials<N>
-
-
Constructor Summary
Constructors Constructor Description ServerManagerComputeServiceAdapter(ServerManager client)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ComputeServiceAdapter.NodeAndInitialCredentials<Server>
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)
Image
getImage(String id)
get a specific image by idServer
getNode(String id)
Iterable<Hardware>
listHardwareProfiles()
Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.Iterable<Image>
listImages()
Images are the available configured operating systems that someone can run a node with.Iterable<Datacenter>
listLocations()
Iterable<Server>
listNodes()
Iterable<Server>
listNodesByIds(Iterable<String> ids)
void
rebootNode(String id)
void
resumeNode(String id)
void
suspendNode(String id)
-
-
-
Constructor Detail
-
ServerManagerComputeServiceAdapter
@Inject public ServerManagerComputeServiceAdapter(ServerManager client)
-
-
Method Detail
-
createNodeWithGroupEncodedIntoName
public ComputeServiceAdapter.NodeAndInitialCredentials<Server> 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 typeN
. If you are not using library-native objects (such as libvirtDomain
) useJCloudsNativeComputeServiceAdapter
instead.note
Your responsibility is to create a node with the underlying library and return after storing its credentials in the supplied map corresponding tocredentialStore
- Specified by:
createNodeWithGroupEncodedIntoName
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
- Parameters:
tag
- used to aggregate nodes with identical configurationname
- unique supplied name for the node, which has the group encoded into it.template
- includesimageId
,locationId
, andhardwareId
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<Hardware> 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 interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
- Returns:
- a non-null iterable of available hardware profiles.
- See Also:
ComputeService.listHardwareProfiles()
-
listImages
public Iterable<Image> 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 interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
- Returns:
- a non-null iterable of available images.
- See Also:
ComputeService.listImages()
-
getImage
public Image getImage(String id)
Description copied from interface:ComputeServiceAdapter
get a specific image by id- Specified by:
getImage
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
- Parameters:
id
-Image#getId
, which is not necessarilyImage#getProviderId
- Returns:
- image or null if not exists.
-
listNodes
public Iterable<Server> listNodes()
- Specified by:
listNodes
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
listNodesByIds
public Iterable<Server> listNodesByIds(Iterable<String> ids)
- Specified by:
listNodesByIds
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
listLocations
public Iterable<Datacenter> listLocations()
- Specified by:
listLocations
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
getNode
public Server getNode(String id)
- Specified by:
getNode
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
destroyNode
public void destroyNode(String id)
- Specified by:
destroyNode
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
rebootNode
public void rebootNode(String id)
- Specified by:
rebootNode
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
resumeNode
public void resumeNode(String id)
- Specified by:
resumeNode
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
suspendNode
public void suspendNode(String id)
- Specified by:
suspendNode
in interfaceComputeServiceAdapter<Server,Hardware,Image,Datacenter>
-
-