com.amazonaws.services.taxsettings.model.TaxRegistrationEntry Maven / Gradle / Ivy
Show all versions of aws-java-sdk-taxsettings 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.taxsettings.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* The TRN information you provide when you add a new TRN, or update.
*
*
* @see AWS
* API Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class TaxRegistrationEntry implements Serializable, Cloneable, StructuredPojo {
/**
*
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
*
*/
private AdditionalInfoRequest additionalTaxInformation;
/**
*
* The email address to receive VAT invoices.
*
*/
private String certifiedEmailId;
/**
*
* The legal address associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*
*/
private Address legalAddress;
/**
*
* The legal name associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries, you
* must specify the legal name.
*
*
*/
private String legalName;
/**
*
* Your tax registration unique identifier.
*
*/
private String registrationId;
/**
*
* Your tax registration type. This can be either VAT
or GST
.
*
*/
private String registrationType;
/**
*
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country specific
* information in API document.
*
*/
private String sector;
/**
*
* Additional details needed to verify your TRN information in Brazil. You only need to specify this parameter when
* you set a TRN in Brazil that is the CPF tax type.
*
*
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another country.
*
*
*/
private VerificationDetails verificationDetails;
/**
*
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
*
*
* @param additionalTaxInformation
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
*/
public void setAdditionalTaxInformation(AdditionalInfoRequest additionalTaxInformation) {
this.additionalTaxInformation = additionalTaxInformation;
}
/**
*
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
*
*
* @return Additional tax information associated with your TRN. You only need to specify this parameter if Amazon
* Web Services collects any additional information for your country within AdditionalInfoRequest.
*/
public AdditionalInfoRequest getAdditionalTaxInformation() {
return this.additionalTaxInformation;
}
/**
*
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
*
*
* @param additionalTaxInformation
* Additional tax information associated with your TRN. You only need to specify this parameter if Amazon Web
* Services collects any additional information for your country within AdditionalInfoRequest.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withAdditionalTaxInformation(AdditionalInfoRequest additionalTaxInformation) {
setAdditionalTaxInformation(additionalTaxInformation);
return this;
}
/**
*
* The email address to receive VAT invoices.
*
*
* @param certifiedEmailId
* The email address to receive VAT invoices.
*/
public void setCertifiedEmailId(String certifiedEmailId) {
this.certifiedEmailId = certifiedEmailId;
}
/**
*
* The email address to receive VAT invoices.
*
*
* @return The email address to receive VAT invoices.
*/
public String getCertifiedEmailId() {
return this.certifiedEmailId;
}
/**
*
* The email address to receive VAT invoices.
*
*
* @param certifiedEmailId
* The email address to receive VAT invoices.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withCertifiedEmailId(String certifiedEmailId) {
setCertifiedEmailId(certifiedEmailId);
return this;
}
/**
*
* The legal address associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*
*
* @param legalAddress
* The legal address associated with your TRN.
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*/
public void setLegalAddress(Address legalAddress) {
this.legalAddress = legalAddress;
}
/**
*
* The legal address associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*
*
* @return The legal address associated with your TRN.
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*/
public Address getLegalAddress() {
return this.legalAddress;
}
/**
*
* The legal address associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
*
*
* @param legalAddress
* The legal address associated with your TRN.
*
* If you're setting a TRN in Brazil for the CNPJ tax type, you don't need to specify the legal address.
*
*
* For TRNs in other countries and for CPF tax types Brazil, you must specify the legal address.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withLegalAddress(Address legalAddress) {
setLegalAddress(legalAddress);
return this;
}
/**
*
* The legal name associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries, you
* must specify the legal name.
*
*
*
* @param legalName
* The legal name associated with your TRN.
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries,
* you must specify the legal name.
*
*/
public void setLegalName(String legalName) {
this.legalName = legalName;
}
/**
*
* The legal name associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries, you
* must specify the legal name.
*
*
*
* @return The legal name associated with your TRN.
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries,
* you must specify the legal name.
*
*/
public String getLegalName() {
return this.legalName;
}
/**
*
* The legal name associated with your TRN.
*
*
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries, you
* must specify the legal name.
*
*
*
* @param legalName
* The legal name associated with your TRN.
*
* If you're setting a TRN in Brazil, you don't need to specify the legal name. For TRNs in other countries,
* you must specify the legal name.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withLegalName(String legalName) {
setLegalName(legalName);
return this;
}
/**
*
* Your tax registration unique identifier.
*
*
* @param registrationId
* Your tax registration unique identifier.
*/
public void setRegistrationId(String registrationId) {
this.registrationId = registrationId;
}
/**
*
* Your tax registration unique identifier.
*
*
* @return Your tax registration unique identifier.
*/
public String getRegistrationId() {
return this.registrationId;
}
/**
*
* Your tax registration unique identifier.
*
*
* @param registrationId
* Your tax registration unique identifier.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withRegistrationId(String registrationId) {
setRegistrationId(registrationId);
return this;
}
/**
*
* Your tax registration type. This can be either VAT
or GST
.
*
*
* @param registrationType
* Your tax registration type. This can be either VAT
or GST
.
* @see TaxRegistrationType
*/
public void setRegistrationType(String registrationType) {
this.registrationType = registrationType;
}
/**
*
* Your tax registration type. This can be either VAT
or GST
.
*
*
* @return Your tax registration type. This can be either VAT
or GST
.
* @see TaxRegistrationType
*/
public String getRegistrationType() {
return this.registrationType;
}
/**
*
* Your tax registration type. This can be either VAT
or GST
.
*
*
* @param registrationType
* Your tax registration type. This can be either VAT
or GST
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see TaxRegistrationType
*/
public TaxRegistrationEntry withRegistrationType(String registrationType) {
setRegistrationType(registrationType);
return this;
}
/**
*
* Your tax registration type. This can be either VAT
or GST
.
*
*
* @param registrationType
* Your tax registration type. This can be either VAT
or GST
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see TaxRegistrationType
*/
public TaxRegistrationEntry withRegistrationType(TaxRegistrationType registrationType) {
this.registrationType = registrationType.toString();
return this;
}
/**
*
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country specific
* information in API document.
*
*
* @param sector
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country
* specific information in API document.
* @see Sector
*/
public void setSector(String sector) {
this.sector = sector;
}
/**
*
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country specific
* information in API document.
*
*
* @return The industry that describes your business. For business-to-business (B2B) customers, specify Business.
* For business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country
* specific information in API document.
* @see Sector
*/
public String getSector() {
return this.sector;
}
/**
*
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country specific
* information in API document.
*
*
* @param sector
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country
* specific information in API document.
* @return Returns a reference to this object so that method calls can be chained together.
* @see Sector
*/
public TaxRegistrationEntry withSector(String sector) {
setSector(sector);
return this;
}
/**
*
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country specific
* information in API document.
*
*
* @param sector
* The industry that describes your business. For business-to-business (B2B) customers, specify Business. For
* business-to-consumer (B2C) customers, specify Individual. For business-to-government (B2G), specify
* Government.Note that certain values may not applicable for the request country. Please refer to country
* specific information in API document.
* @return Returns a reference to this object so that method calls can be chained together.
* @see Sector
*/
public TaxRegistrationEntry withSector(Sector sector) {
this.sector = sector.toString();
return this;
}
/**
*
* Additional details needed to verify your TRN information in Brazil. You only need to specify this parameter when
* you set a TRN in Brazil that is the CPF tax type.
*
*
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another country.
*
*
*
* @param verificationDetails
* Additional details needed to verify your TRN information in Brazil. You only need to specify this
* parameter when you set a TRN in Brazil that is the CPF tax type.
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another
* country.
*
*/
public void setVerificationDetails(VerificationDetails verificationDetails) {
this.verificationDetails = verificationDetails;
}
/**
*
* Additional details needed to verify your TRN information in Brazil. You only need to specify this parameter when
* you set a TRN in Brazil that is the CPF tax type.
*
*
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another country.
*
*
*
* @return Additional details needed to verify your TRN information in Brazil. You only need to specify this
* parameter when you set a TRN in Brazil that is the CPF tax type.
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another
* country.
*
*/
public VerificationDetails getVerificationDetails() {
return this.verificationDetails;
}
/**
*
* Additional details needed to verify your TRN information in Brazil. You only need to specify this parameter when
* you set a TRN in Brazil that is the CPF tax type.
*
*
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another country.
*
*
*
* @param verificationDetails
* Additional details needed to verify your TRN information in Brazil. You only need to specify this
* parameter when you set a TRN in Brazil that is the CPF tax type.
*
* Don't specify this parameter to set a TRN in Brazil of the CNPJ tax type or to set a TRN for another
* country.
*
* @return Returns a reference to this object so that method calls can be chained together.
*/
public TaxRegistrationEntry withVerificationDetails(VerificationDetails verificationDetails) {
setVerificationDetails(verificationDetails);
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 (getAdditionalTaxInformation() != null)
sb.append("AdditionalTaxInformation: ").append(getAdditionalTaxInformation()).append(",");
if (getCertifiedEmailId() != null)
sb.append("CertifiedEmailId: ").append(getCertifiedEmailId()).append(",");
if (getLegalAddress() != null)
sb.append("LegalAddress: ").append(getLegalAddress()).append(",");
if (getLegalName() != null)
sb.append("LegalName: ").append(getLegalName()).append(",");
if (getRegistrationId() != null)
sb.append("RegistrationId: ").append(getRegistrationId()).append(",");
if (getRegistrationType() != null)
sb.append("RegistrationType: ").append(getRegistrationType()).append(",");
if (getSector() != null)
sb.append("Sector: ").append(getSector()).append(",");
if (getVerificationDetails() != null)
sb.append("VerificationDetails: ").append(getVerificationDetails());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof TaxRegistrationEntry == false)
return false;
TaxRegistrationEntry other = (TaxRegistrationEntry) obj;
if (other.getAdditionalTaxInformation() == null ^ this.getAdditionalTaxInformation() == null)
return false;
if (other.getAdditionalTaxInformation() != null && other.getAdditionalTaxInformation().equals(this.getAdditionalTaxInformation()) == false)
return false;
if (other.getCertifiedEmailId() == null ^ this.getCertifiedEmailId() == null)
return false;
if (other.getCertifiedEmailId() != null && other.getCertifiedEmailId().equals(this.getCertifiedEmailId()) == false)
return false;
if (other.getLegalAddress() == null ^ this.getLegalAddress() == null)
return false;
if (other.getLegalAddress() != null && other.getLegalAddress().equals(this.getLegalAddress()) == false)
return false;
if (other.getLegalName() == null ^ this.getLegalName() == null)
return false;
if (other.getLegalName() != null && other.getLegalName().equals(this.getLegalName()) == false)
return false;
if (other.getRegistrationId() == null ^ this.getRegistrationId() == null)
return false;
if (other.getRegistrationId() != null && other.getRegistrationId().equals(this.getRegistrationId()) == false)
return false;
if (other.getRegistrationType() == null ^ this.getRegistrationType() == null)
return false;
if (other.getRegistrationType() != null && other.getRegistrationType().equals(this.getRegistrationType()) == false)
return false;
if (other.getSector() == null ^ this.getSector() == null)
return false;
if (other.getSector() != null && other.getSector().equals(this.getSector()) == false)
return false;
if (other.getVerificationDetails() == null ^ this.getVerificationDetails() == null)
return false;
if (other.getVerificationDetails() != null && other.getVerificationDetails().equals(this.getVerificationDetails()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getAdditionalTaxInformation() == null) ? 0 : getAdditionalTaxInformation().hashCode());
hashCode = prime * hashCode + ((getCertifiedEmailId() == null) ? 0 : getCertifiedEmailId().hashCode());
hashCode = prime * hashCode + ((getLegalAddress() == null) ? 0 : getLegalAddress().hashCode());
hashCode = prime * hashCode + ((getLegalName() == null) ? 0 : getLegalName().hashCode());
hashCode = prime * hashCode + ((getRegistrationId() == null) ? 0 : getRegistrationId().hashCode());
hashCode = prime * hashCode + ((getRegistrationType() == null) ? 0 : getRegistrationType().hashCode());
hashCode = prime * hashCode + ((getSector() == null) ? 0 : getSector().hashCode());
hashCode = prime * hashCode + ((getVerificationDetails() == null) ? 0 : getVerificationDetails().hashCode());
return hashCode;
}
@Override
public TaxRegistrationEntry clone() {
try {
return (TaxRegistrationEntry) 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.taxsettings.model.transform.TaxRegistrationEntryMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}