/* * Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ package com.amazonaws.services.ec2.model; import java.io.Serializable; import com.amazonaws.util.BinaryUtils; import com.amazonaws.AmazonClientException; import java.io.UnsupportedEncodingException; /** * <p> * Contains the output of GetConsoleOutput. * </p> */ public class GetConsoleOutputResult implements Serializable { /** * The ID of the instance. */ private String instanceId; /** * The time the output was last updated. */ private java.util.Date timestamp; /** * The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. */ private String output; /** * The ID of the instance. * * @return The ID of the instance. */ public String getInstanceId() { return instanceId; } /** * The ID of the instance. * * @param instanceId The ID of the instance. */ public void setInstanceId(String instanceId) { this.instanceId = instanceId; } /** * The ID of the instance. * <p> * Returns a reference to this object so that method calls can be chained together. * * @param instanceId The ID of the instance. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetConsoleOutputResult withInstanceId(String instanceId) { this.instanceId = instanceId; return this; } /** * The time the output was last updated. * * @return The time the output was last updated. */ public java.util.Date getTimestamp() { return timestamp; } /** * The time the output was last updated. * * @param timestamp The time the output was last updated. */ public void setTimestamp(java.util.Date timestamp) { this.timestamp = timestamp; } /** * The time the output was last updated. * <p> * Returns a reference to this object so that method calls can be chained together. * * @param timestamp The time the output was last updated. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetConsoleOutputResult withTimestamp(java.util.Date timestamp) { this.timestamp = timestamp; return this; } /** * The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. * * @return The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. */ public String getOutput() { return output; } /** * The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. * * @param output The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. */ public void setOutput(String output) { this.output = output; } /** * The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. * <p> * Returns a reference to this object so that method calls can be chained together. * * @param output The console output, base64-encoded. If using a command line tool, the * tools decode the output for you. * * @return A reference to this updated object so that method calls can be chained * together. */ public GetConsoleOutputResult withOutput(String output) { this.output = output; return this; } /** * The decoded console output. * * @return The decoded console output. */ public String getDecodedOutput() { byte[] bytes = BinaryUtils.fromBase64(output); String decoded; try { decoded = new String(bytes, "UTF-8"); } catch (UnsupportedEncodingException e) { throw new AmazonClientException("Cannot decode the output, since UTF-8 is not supported.", e); } return decoded; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getInstanceId() != null) sb.append("InstanceId: " + getInstanceId() + ","); if (getTimestamp() != null) sb.append("Timestamp: " + getTimestamp() + ","); if (getOutput() != null) sb.append("Output: " + getOutput() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getInstanceId() == null) ? 0 : getInstanceId().hashCode()); hashCode = prime * hashCode + ((getTimestamp() == null) ? 0 : getTimestamp().hashCode()); hashCode = prime * hashCode + ((getOutput() == null) ? 0 : getOutput().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof GetConsoleOutputResult == false) return false; GetConsoleOutputResult other = (GetConsoleOutputResult)obj; if (other.getInstanceId() == null ^ this.getInstanceId() == null) return false; if (other.getInstanceId() != null && other.getInstanceId().equals(this.getInstanceId()) == false) return false; if (other.getTimestamp() == null ^ this.getTimestamp() == null) return false; if (other.getTimestamp() != null && other.getTimestamp().equals(this.getTimestamp()) == false) return false; if (other.getOutput() == null ^ this.getOutput() == null) return false; if (other.getOutput() != null && other.getOutput().equals(this.getOutput()) == false) return false; return true; } }