Issue 695: Added VirtualMachine domain class and example xml. Tweaked TaskedHandler

This commit is contained in:
Jason King 2011-11-10 17:04:02 +00:00
parent 508973b7ab
commit d0f77def4f
3 changed files with 252 additions and 200 deletions

View File

@ -18,66 +18,21 @@
*/
package org.jclouds.trmk.enterprisecloud.domain;
import static com.google.common.base.CaseFormat.UPPER_CAMEL;
import static com.google.common.base.CaseFormat.UPPER_UNDERSCORE;
import static com.google.common.base.Preconditions.checkNotNull;
import java.net.URI;
import java.util.Date;
import java.util.Map;
import org.jclouds.javax.annotation.Nullable;
import org.jclouds.trmk.enterprisecloud.domain.internal.BaseNamedResource;
import org.jclouds.trmk.enterprisecloud.domain.internal.BaseResource;
import java.net.URI;
import java.util.List;
import java.util.Map;
import static com.google.common.base.Preconditions.checkNotNull;
/**
*
* @author Adrian Cole
* @author Jason King
*
*/
public class VirtualMachine extends BaseResource<VirtualMachine> {
public static enum Status {
/**
* the task is queued for execution.
*/
QUEUED,
/**
* the task is running.
*/
RUNNING,
/**
* the task failed.
*/
FAILED,
/**
* the task completed successfully.
*/
SUCCESS,
/**
* the task failed with an error.
*/
ERROR,
/**
* Status was not parsed by jclouds.
*/
UNRECOGNIZED;
public String value() {
return UPPER_UNDERSCORE.to(UPPER_CAMEL, name());
}
@Override
public String toString() {
return value();
}
public static Status fromValue(String status) {
try {
return valueOf(UPPER_CAMEL.to(UPPER_UNDERSCORE, checkNotNull(status, "status")));
} catch (IllegalArgumentException e) {
return UNRECOGNIZED;
}
}
}
public class VirtualMachine extends BaseNamedResource<VirtualMachine> {
@SuppressWarnings("unchecked")
public static Builder builder() {
@ -89,93 +44,59 @@ public class VirtualMachine extends BaseResource<VirtualMachine> {
*/
@Override
public Builder toBuilder() {
return new Builder().fromTask(this);
return new Builder().fromVirtualMachine(this);
}
public static class Builder extends BaseResource.Builder<VirtualMachine> {
protected String operation;
protected Status status;
protected NamedResource impactedItem;
protected Date startTime;
protected Date completedTime;
protected String notes;
protected String errorMessage;
protected NamedResource initiatedBy;
public static class Builder extends BaseNamedResource.Builder<VirtualMachine> {
private List<Link> links;
private List<Action> actions;
private List<Task> tasks;
private String description;
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getOperation
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getLinks
*/
public Builder operation(String operation) {
this.operation = operation;
public Builder links(List<Link> links) {
this.links = links;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getStatus
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getActions
*/
public Builder status(Status status) {
this.status = status;
public Builder actions(List<Action> actions) {
this.actions = actions;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getImpactedItem
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getTasks
*/
public Builder impactedItem(NamedResource impactedItem) {
this.impactedItem = impactedItem;
public Builder tasks(List<Task> tasks) {
this.tasks = tasks;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getStartTime
*/
public Builder startTime(Date startTime) {
this.startTime = startTime;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getCompletedTime
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getDescription
*/
public Builder completedTime(Date completedTime) {
this.completedTime = completedTime;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getNotes
*/
public Builder notes(String notes) {
this.notes = notes;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getErrorMessage
*/
public Builder errorMessage(String errorMessage) {
this.errorMessage = errorMessage;
return this;
}
/**
* @see org.jclouds.trmk.enterprisecloud.domain.VirtualMachine#getInitiatedBy
*/
public Builder initiatedBy(NamedResource initiatedBy) {
this.initiatedBy = initiatedBy;
public Builder description(String description) {
this.description = description;
return this;
}
@Override
public VirtualMachine build() {
return new VirtualMachine(href, type, operation, status, impactedItem, startTime, completedTime, notes, errorMessage,
initiatedBy);
return new VirtualMachine(href, type, name, tasks, actions, links, description);
}
public Builder fromTask(VirtualMachine in) {
return fromResource(in).operation(in.getOperation()).status(in.getStatus()).impactedItem(in.getImpactedItem())
.startTime(in.getStartTime()).completedTime(in.getCompletedTime()).notes(in.getNotes())
.errorMessage(in.getErrorMessage()).initiatedBy(in.getInitiatedBy());
public Builder fromVirtualMachine(VirtualMachine in) {
return fromNamedResource(in)
.links(in.getLinks())
.tasks(in.getTasks())
.actions(in.getActions())
.description(in.getDescription());
}
/**
@ -186,6 +107,14 @@ public class VirtualMachine extends BaseResource<VirtualMachine> {
return Builder.class.cast(super.fromResource(in));
}
/**
* {@inheritDoc}
*/
@Override
public Builder fromNamedResource(BaseNamedResource<VirtualMachine> in) {
return Builder.class.cast(super.fromNamedResource(in));
}
/**
* {@inheritDoc}
*/
@ -202,108 +131,89 @@ public class VirtualMachine extends BaseResource<VirtualMachine> {
return Builder.class.cast(super.href(href));
}
/**
* {@inheritDoc}
*/
@Override
public Builder name(String name) {
return Builder.class.cast(super.name(name));
}
/**
* {@inheritDoc}
*/
@Override
public Builder fromAttributes(Map<String, String> attributes) {
return Builder.class.cast(super.fromAttributes(attributes));
// TODO Other fields?
}
}
protected final String operation;
protected final Status status;
protected final NamedResource impactedItem;
protected final Date startTime;
protected final Date completedTime;
protected final String notes;
protected final String errorMessage;
protected final NamedResource initiatedBy;
private final List<Link> links;
private final List<Task> tasks;
private final List<Action> actions;
private final String description;
public VirtualMachine(URI href, String type, String operation, Status status, NamedResource impactedItem, Date startTime,
@Nullable Date completedTime, @Nullable String notes, @Nullable String errorMessage, NamedResource initiatedBy) {
super(href, type);
this.operation = checkNotNull(operation, "operation");
this.status = checkNotNull(status, "status");
this.impactedItem = checkNotNull(impactedItem, "impactedItem");
this.startTime = checkNotNull(startTime, "startTime");
this.completedTime = completedTime;// null if Queued or Running
this.notes = notes;
this.errorMessage = errorMessage;
this.initiatedBy = checkNotNull(initiatedBy, "initiatedBy");
public VirtualMachine(URI href, String type, String name, List<Task> tasks, List<Action> actions, List<Link> links, String description) {
super(href, type, name);
this.description = checkNotNull(description, "description");
this.links = checkNotNull(links, "links");
this.tasks = checkNotNull(tasks, "tasks");
this.actions = checkNotNull(actions, "actions");
}
public List<Link> getLinks() {
return links;
}
/**
*
*
* @return name of action performed
* refers to tasks regarding the virtual machine.
* Only the most recent tasks, up to twenty, are returned.
* Use the href to retrieve the complete list of tasks.
* @return most recent tasks
*/
public String getOperation() {
return operation;
public List<Task> getTasks() {
return tasks;
}
/**
*
*
* @return the status of the task
*/
public Status getStatus() {
return status;
public List<Action> getActions() {
return actions;
}
/**
*
* @return the item acted upon
*/
public NamedResource getImpactedItem() {
return impactedItem;
}
/**
*
* @return time action started
*/
public Date getStartTime() {
return startTime;
}
/**
*
* @return time action completed, or null if Queued or Running
*/
@Nullable
public Date getCompletedTime() {
return completedTime;
}
/**
* @return notes on action
*/
public String getNotes() {
return notes;
}
/**
* @return error message
*/
public String getErrorMessage() {
return errorMessage;
}
/**
*
* @return the item acted upon
*/
public NamedResource getInitiatedBy() {
return initiatedBy;
public String getDescription() {
return description;
}
@Override
public String toString() {
return "[type=" + type + ", href=" + href + ", operation=" + operation + ", status=" + status + ", impactedItem="
+ impactedItem + ", startTime=" + startTime + ", completedTime=" + completedTime + ", notes=" + notes
+ ", errorMessage=" + errorMessage + ", initiatedBy=" + initiatedBy + "]";
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
if (!super.equals(o)) return false;
VirtualMachine that = (VirtualMachine) o;
if (!actions.equals(that.actions)) return false;
if (!description.equals(that.description)) return false;
if (!links.equals(that.links)) return false;
if (!tasks.equals(that.tasks)) return false;
return true;
}
@Override
public int hashCode() {
int result = super.hashCode();
result = 31 * result + links.hashCode();
result = 31 * result + tasks.hashCode();
result = 31 * result + actions.hashCode();
result = 31 * result + description.hashCode();
return result;
}
@Override
public String string() {
return super.string()+", links="+links+", tasks="+tasks+", actions="+actions+", description="+description;
}
}

View File

@ -30,7 +30,6 @@ import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.ImmutableSet.Builder;
/**
* @author Adrian Cole
@ -46,7 +45,7 @@ public class TasksHandler extends ParseSax.HandlerWithResult<Set<Task>> {
protected final TaskHandler taskHandler;
protected Builder<Task> builder = ImmutableSet.<Task> builder();
protected ImmutableSet.Builder<Task> builder = ImmutableSet.<Task> builder();
@Inject
public TasksHandler(TaskHandler taskHandler) {

View File

@ -0,0 +1,143 @@
<VirtualMachine href="/cloudapi/ecloud/virtualmachines/5504" name="helloworld"
type="application/vnd.tmrk.cloud.virtualMachine"
xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<Links>
<Link href="/cloudapi/ecloud/computepools/89"
name="Default Compute Pool"
type="application/vnd.tmrk.cloud.computePool" rel="up"/>
<Link href="/cloudapi/ecloud/environments/77" name="Beta Environment 01"
type="application/vnd.tmrk.cloud.environment" rel="up"/>
<Link href="/cloudapi/ecloud/tasks/virtualmachines/5504"
type="application/vnd.tmrk.cloud.task; type=collection"
rel="down"/>
<Link href="/cloudapi/ecloud/virtualmachines/5504/guest/processes"
name="helloworld"
type="application/vnd.tmrk.cloud.guest.process; type=collection"
rel="down"/>
<Link href="/cloudapi/ecloud/virtualmachines/5504/configurationoptions"
name="helloworld"
type="application/vnd.tmrk.cloud.virtualMachineConfigurationOptions"
rel="down"/>
<Link href="/cloudapi/ecloud/virtualmachines-streaming/5504/guest/action/files"
name="helloworld" type="application/octet-stream" rel="down"/>
</Links>
<Actions>
<Action href="/cloudapi/ecloud/virtualmachines/5504" name="edit"
type="application/vnd.tmrk.cloud.virtualMachine"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/action/move"
name="move"
type="application/vnd.tmrk.cloud.moveLayoutRequest"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504" name="remove"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/action/poweroff"
name="power:powerOff" actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/action/reboot"
name="power:reboot" actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/action/shutdown"
name="power:shutdown" actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/action/poweron"
name="power:powerOn"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/tools/action/mount"
name="tools:mount" actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/tools/action/unmount"
name="tools:unmount" actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines/5504/guest/action/createprocess"
name="createGuestProcess"
type="application/vnd.tmrk.cloud.guest.process"
actionDisabled="disabled"/>
<Action href="/cloudapi/ecloud/virtualmachines-streaming/5504/guest/action/files"
name="createFile" type="application/octet-stream"
actionDisabled="disabled"/>
</Actions>
<Tasks type="application/vnd.tmrk.cloud.task; type=collection">
<Links>
<Link href="/cloudapi/ecloud/virtualmachines/5504" name="helloworld"
type="application/vnd.tmrk.cloud.virtualMachine" rel="up"/>
</Links>
<Task href="/cloudapi/ecloud/tasks/12345"
type="application/vnd.tmrk.cloud.task">
<Operation>Create Server</Operation>
<Status>Complete</Status>
<ImpactedItem href="/cloudapi/ecloud/virtualmachines/5504"
name="helloworld"
type="application/vnd.tmrk.cloud.virtualMachine"/>
<StartTime>2011-11-09T21:46:11.787Z</StartTime>
<CompletedTime>2011-11-09T21:50:32.933Z</CompletedTime>
<InitiatedBy href="/cloudapi/ecloud/admin/users/1804"
name="Jason King"
type="application/vnd.tmrk.cloud.admin.user"/>
</Task>
<TotalCount>1</TotalCount>
</Tasks>
<Description>My first terremark server</Description>
<Layout>
<Row href="/cloudapi/ecloud/layoutrows/285" name="test row"
type="application/vnd.tmrk.cloud.layoutRow"/>
<Group href="/cloudapi/ecloud/layoutgroups/308" name="test group"
type="application/vnd.tmrk.cloud.layoutGroup"/>
</Layout>
<Status>Deployed</Status>
<PoweredOn>false</PoweredOn>
<HardwareConfiguration
href="/cloudapi/ecloud/virtualmachines/5504/hardwareconfiguration"
type="application/vnd.tmrk.cloud.virtualMachineHardware">
<Actions>
<Action href="/cloudapi/ecloud/virtualmachines/5504/hardwareconfiguration"
name="edit"
type="application/vnd.tmrk.cloud.virtualMachineHardware"/>
</Actions>
<ProcessorCount>1</ProcessorCount>
<Memory>
<Unit>MB</Unit>
<Value>384</Value>
</Memory>
<Disks>
<Disk>
<Index>0</Index>
<Size>
<Unit>GB</Unit>
<Value>10</Value>
</Size>
<Name>Hard Disk 1</Name>
</Disk>
</Disks>
<Nics>
<Nic>
<UnitNumber>7</UnitNumber>
<Name>Network adapter 1</Name>
<MacAddress>00:50:56:b8:00:58</MacAddress>
<Network href="/cloudapi/ecloud/networks/3936"
name="10.146.204.64/28"
type="application/vnd.tmrk.cloud.network">
<NetworkType>Internal</NetworkType>
</Network>
</Nic>
</Nics>
</HardwareConfiguration>
<IpAddresses>
<AssignedIpAddresses
href="/cloudapi/ecloud/virtualmachines/5504/assignedips"
type="application/vnd.tmrk.cloud.virtualMachineAssignedIps">
<Actions>
<Action href="/cloudapi/ecloud/virtualmachines/5504/assignedips"
name="edit"
type="application/vnd.tmrk.cloud.virtualMachineAssignedIps"/>
</Actions>
<Networks>
<Network href="/cloudapi/ecloud/networks/3936"
name="10.146.204.64/28 (INT_202)"
type="application/vnd.tmrk.cloud.network">
<IpAddresses>
<IpAddress>10.146.204.67</IpAddress>
</IpAddresses>
</Network>
</Networks>
</AssignedIpAddresses>
</IpAddresses>
<OperatingSystem
href="/cloudapi/ecloud/operatingsystems/rhel5_64guest/computepools/89"
name="Red Hat Enterprise Linux 5 (64-bit)"
type="application/vnd.tmrk.cloud.operatingSystem"/>
<ToolsStatus>NotRunning</ToolsStatus>
<MediaStatus>Unmounted</MediaStatus>
<CustomizationPending>false</CustomizationPending>
</VirtualMachine>