com.amazonaws.services.logs.model.Destination Maven / Gradle / Ivy
Show all versions of aws-java-sdk-logs Show documentation
/*
* Copyright 2019-2024 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.logs.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Represents a cross-account destination that receives subscription log events.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Destination implements Serializable, Cloneable, StructuredPojo {
/**
*
* The name of the destination.
*
*/
private String destinationName;
/**
*
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a Kinesis
* stream).
*
*/
private String targetArn;
/**
*
* A role for impersonation, used when delivering log events to the target.
*
*/
private String roleArn;
/**
*
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters against
* this destination.
*
*/
private String accessPolicy;
/**
*
* The ARN of this destination.
*
*/
private String arn;
/**
*
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00 UTC.
*
*/
private Long creationTime;
/**
*
* The name of the destination.
*
*
* @param destinationName
* The name of the destination.
*/
public void setDestinationName(String destinationName) {
this.destinationName = destinationName;
}
/**
*
* The name of the destination.
*
*
* @return The name of the destination.
*/
public String getDestinationName() {
return this.destinationName;
}
/**
*
* The name of the destination.
*
*
* @param destinationName
* The name of the destination.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withDestinationName(String destinationName) {
setDestinationName(destinationName);
return this;
}
/**
*
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a Kinesis
* stream).
*
*
* @param targetArn
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a
* Kinesis stream).
*/
public void setTargetArn(String targetArn) {
this.targetArn = targetArn;
}
/**
*
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a Kinesis
* stream).
*
*
* @return The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a
* Kinesis stream).
*/
public String getTargetArn() {
return this.targetArn;
}
/**
*
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a Kinesis
* stream).
*
*
* @param targetArn
* The Amazon Resource Name (ARN) of the physical target where the log events are delivered (for example, a
* Kinesis stream).
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withTargetArn(String targetArn) {
setTargetArn(targetArn);
return this;
}
/**
*
* A role for impersonation, used when delivering log events to the target.
*
*
* @param roleArn
* A role for impersonation, used when delivering log events to the target.
*/
public void setRoleArn(String roleArn) {
this.roleArn = roleArn;
}
/**
*
* A role for impersonation, used when delivering log events to the target.
*
*
* @return A role for impersonation, used when delivering log events to the target.
*/
public String getRoleArn() {
return this.roleArn;
}
/**
*
* A role for impersonation, used when delivering log events to the target.
*
*
* @param roleArn
* A role for impersonation, used when delivering log events to the target.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withRoleArn(String roleArn) {
setRoleArn(roleArn);
return this;
}
/**
*
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters against
* this destination.
*
*
* @param accessPolicy
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters
* against this destination.
*/
public void setAccessPolicy(String accessPolicy) {
this.accessPolicy = accessPolicy;
}
/**
*
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters against
* this destination.
*
*
* @return An IAM policy document that governs which Amazon Web Services accounts can create subscription filters
* against this destination.
*/
public String getAccessPolicy() {
return this.accessPolicy;
}
/**
*
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters against
* this destination.
*
*
* @param accessPolicy
* An IAM policy document that governs which Amazon Web Services accounts can create subscription filters
* against this destination.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withAccessPolicy(String accessPolicy) {
setAccessPolicy(accessPolicy);
return this;
}
/**
*
* The ARN of this destination.
*
*
* @param arn
* The ARN of this destination.
*/
public void setArn(String arn) {
this.arn = arn;
}
/**
*
* The ARN of this destination.
*
*
* @return The ARN of this destination.
*/
public String getArn() {
return this.arn;
}
/**
*
* The ARN of this destination.
*
*
* @param arn
* The ARN of this destination.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withArn(String arn) {
setArn(arn);
return this;
}
/**
*
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00 UTC.
*
*
* @param creationTime
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00
* UTC.
*/
public void setCreationTime(Long creationTime) {
this.creationTime = creationTime;
}
/**
*
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00 UTC.
*
*
* @return The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00
* UTC.
*/
public Long getCreationTime() {
return this.creationTime;
}
/**
*
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00 UTC.
*
*
* @param creationTime
* The creation time of the destination, expressed as the number of milliseconds after Jan 1, 1970 00:00:00
* UTC.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public Destination withCreationTime(Long creationTime) {
setCreationTime(creationTime);
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getDestinationName() != null)
sb.append("DestinationName: ").append(getDestinationName()).append(",");
if (getTargetArn() != null)
sb.append("TargetArn: ").append(getTargetArn()).append(",");
if (getRoleArn() != null)
sb.append("RoleArn: ").append(getRoleArn()).append(",");
if (getAccessPolicy() != null)
sb.append("AccessPolicy: ").append(getAccessPolicy()).append(",");
if (getArn() != null)
sb.append("Arn: ").append(getArn()).append(",");
if (getCreationTime() != null)
sb.append("CreationTime: ").append(getCreationTime());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof Destination == false)
return false;
Destination other = (Destination) obj;
if (other.getDestinationName() == null ^ this.getDestinationName() == null)
return false;
if (other.getDestinationName() != null && other.getDestinationName().equals(this.getDestinationName()) == false)
return false;
if (other.getTargetArn() == null ^ this.getTargetArn() == null)
return false;
if (other.getTargetArn() != null && other.getTargetArn().equals(this.getTargetArn()) == false)
return false;
if (other.getRoleArn() == null ^ this.getRoleArn() == null)
return false;
if (other.getRoleArn() != null && other.getRoleArn().equals(this.getRoleArn()) == false)
return false;
if (other.getAccessPolicy() == null ^ this.getAccessPolicy() == null)
return false;
if (other.getAccessPolicy() != null && other.getAccessPolicy().equals(this.getAccessPolicy()) == false)
return false;
if (other.getArn() == null ^ this.getArn() == null)
return false;
if (other.getArn() != null && other.getArn().equals(this.getArn()) == false)
return false;
if (other.getCreationTime() == null ^ this.getCreationTime() == null)
return false;
if (other.getCreationTime() != null && other.getCreationTime().equals(this.getCreationTime()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getDestinationName() == null) ? 0 : getDestinationName().hashCode());
hashCode = prime * hashCode + ((getTargetArn() == null) ? 0 : getTargetArn().hashCode());
hashCode = prime * hashCode + ((getRoleArn() == null) ? 0 : getRoleArn().hashCode());
hashCode = prime * hashCode + ((getAccessPolicy() == null) ? 0 : getAccessPolicy().hashCode());
hashCode = prime * hashCode + ((getArn() == null) ? 0 : getArn().hashCode());
hashCode = prime * hashCode + ((getCreationTime() == null) ? 0 : getCreationTime().hashCode());
return hashCode;
}
@Override
public Destination clone() {
try {
return (Destination) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.logs.model.transform.DestinationMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}