eu.europa.esig.dss.model.SignerLocation Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dss-model Show documentation
Show all versions of dss-model Show documentation
DSS Model contains the data model representation for DSS
/**
* DSS - Digital Signature Services
* Copyright (C) 2015 European Commission, provided under the CEF programme
*
* This file is part of the "DSS - Digital Signature Services" project.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
package eu.europa.esig.dss.model;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
/**
* This class represents the information concerning
* the signature production place.
*
*/
@SuppressWarnings("serial")
public class SignerLocation implements Serializable {
/**
* A sequence defined a Postal Address
*
* NOTE: used in CAdES
*/
private List postalAddress = new ArrayList<>();
/**
* The post office box number for PO box addresses.
*
* NOTE: used in JAdES
*/
private String postOfficeBoxNumber;
/**
* The postal code (ZIP-code). For example, 94043.
*/
private String postalCode;
/**
* The locality (city) in which the street address is, and which is in the
* region.
*/
private String locality;
/**
* State or province. The region in which the locality is, and which is in the
* country.
*/
private String stateOrProvince;
/**
* The country. For example, USA. You can also provide the two-letter ISO 3166-1
* alpha-2 country code.
*/
private String country;
/**
* The street address. For example, 1600 Amphitheatre Pkwy.
*
* NOTE: used in XAdES and JAdES
*/
private String streetAddress;
/**
* The default constructor
*/
public SignerLocation() {
// empty
}
/**
* Gets the country
*
* @return {@link String}
*/
public String getCountry() {
return country;
}
/**
* Sets the country Can be a country name or its two-letter ISO 3166-1 alpha-2
* country code
*
* @param country {@link String}
*/
public void setCountry(final String country) {
this.country = country;
}
/**
* Gets the locality (city)
*
* @return {@link String}
*/
public String getLocality() {
return locality;
}
/**
* Sets the locality (city)
*
* @param locality {@link String}
*/
public void setLocality(final String locality) {
this.locality = locality;
}
/**
* Gets the postal address
*
* @return a list of {@link String}s
*/
public List getPostalAddress() {
return postalAddress;
}
/**
* Sets the postal address
* NOTE: used in CAdES
*
* @param postalAddress a list of {@link String}s
*/
public void setPostalAddress(final List postalAddress) {
this.postalAddress = postalAddress;
}
/**
* Adds an address item to the complete address.
* NOTE: used in CAdES
*
* @param addressItem
* an address line
*/
public void addPostalAddress(final String addressItem) {
if (postalAddress == null) {
postalAddress = new ArrayList<>();
}
postalAddress.add(addressItem);
}
/**
* Gets the postal code
*
* @return {@link String}
*/
public String getPostalCode() {
return postalCode;
}
/**
* Sets the postal code
*
* @param postalCode {@link String}
*/
public void setPostalCode(String postalCode) {
this.postalCode = postalCode;
}
/**
* Gets the post office box number
*
* @return {@link String}
*/
public String getPostOfficeBoxNumber() {
return postOfficeBoxNumber;
}
/**
* Sets the post office box number
* NOTE: used in JAdES
*
* @param postOfficeBoxNumber {@link String}
*/
public void setPostOfficeBoxNumber(String postOfficeBoxNumber) {
this.postOfficeBoxNumber = postOfficeBoxNumber;
}
/**
* Gets the state or province
*
* @return {@link String}
*/
public String getStateOrProvince() {
return stateOrProvince;
}
/**
* Sets the state or province (the region where the locality is)
*
* @param stateOrProvince {@link String}
*/
public void setStateOrProvince(String stateOrProvince) {
this.stateOrProvince = stateOrProvince;
}
/**
* Gets the street address
*
* @return {@link String}
*/
public String getStreetAddress() {
return streetAddress;
}
/**
* Sets the street address
* NOTE: used in XAdES and JAdES
*
* @param streetAddress {@link String}
*/
public void setStreetAddress(String streetAddress) {
this.streetAddress = streetAddress;
}
/**
* Checks if the SignerLocation instance is empty
*
* @return TRUE if none of the fields are filled in, FALSE otherwise
*/
public boolean isEmpty() {
if (postalAddress != null && !postalAddress.isEmpty()) {
return false;
}
if (postalCode != null && !postalCode.isEmpty()) {
return false;
}
if (postOfficeBoxNumber != null && !postOfficeBoxNumber.isEmpty()) {
return false;
}
if (locality != null && !locality.isEmpty()) {
return false;
}
if (stateOrProvince != null && !stateOrProvince.isEmpty()) {
return false;
}
if (country != null && !country.isEmpty()) {
return false;
}
if (streetAddress != null && !streetAddress.isEmpty()) {
return false;
}
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((country == null) ? 0 : country.hashCode());
result = prime * result + ((locality == null) ? 0 : locality.hashCode());
result = prime * result + ((postOfficeBoxNumber == null) ? 0 : postOfficeBoxNumber.hashCode());
result = prime * result + ((postalAddress == null) ? 0 : postalAddress.hashCode());
result = prime * result + ((postalCode == null) ? 0 : postalCode.hashCode());
result = prime * result + ((stateOrProvince == null) ? 0 : stateOrProvince.hashCode());
result = prime * result + ((streetAddress == null) ? 0 : streetAddress.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
SignerLocation other = (SignerLocation) obj;
if (!Objects.equals(country, other.country)) {
return false;
}
if (!Objects.equals(locality, other.locality)) {
return false;
}
if (!Objects.equals(postOfficeBoxNumber, other.postOfficeBoxNumber)) {
return false;
}
if (!Objects.equals(postalAddress, other.postalAddress)) {
return false;
}
if (!Objects.equals(postalCode, other.postalCode)) {
return false;
}
if (!Objects.equals(stateOrProvince, other.stateOrProvince)) {
return false;
}
if (!Objects.equals(streetAddress, other.streetAddress)) {
return false;
}
return true;
}
@Override
public String toString() {
return "SignerLocation [postalAddress=" + postalAddress + ", postOfficeBoxNumber=" + postOfficeBoxNumber
+ ", postalCode=" + postalCode + ", locality=" + locality + ", stateOrProvince=" + stateOrProvince
+ ", country=" + country + ", street=" + streetAddress + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy