/*
* The MIT License
*
* Copyright 2015 DNAstack.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package com.dnastack.bob.persistence.entity;
import java.util.List;
import java.util.Objects;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
/**
* Organization owning a beacon.
*
* @author Miroslav Cupak (mirocupak@gmail.com)
* @version 1.0
*/
@Entity
@NamedQueries({
@NamedQuery(name = "findOrganizationByName", query = "SELECT b FROM Organization b WHERE b.name=:name")
})
public class Organization implements BasicEntity {
private static final long serialVersionUID = -2628422425515576512L;
@Id
@NotNull
@Size(min = 1)
@Column(nullable = false, unique = true)
private String id;
@NotNull
@Size(min = 1)
@Column(nullable = false, unique = true)
private String name;
private String description;
private String url;
private String address;
@OneToMany(mappedBy = "organization", cascade = {CascadeType.REMOVE, CascadeType.DETACH})
private List<Beacon> beacons;
public Organization() {
}
public Organization(String id, String name, String description, String url, String address) {
this.id = id;
this.name = name;
this.description = description;
this.url = url;
this.address = address;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public List<Beacon> getBeacons() {
return beacons;
}
public void setBeacons(List<Beacon> beacons) {
this.beacons = beacons;
}
@Override
public int hashCode() {
int hash = 5;
hash = 83 * hash + Objects.hashCode(this.id);
return hash;
}
@Override
public boolean equals(Object obj) {
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
final Organization other = (Organization) obj;
if (!Objects.equals(this.id, other.id)) {
return false;
}
return true;
}
@Override
public String toString() {
return "Organization{" + "id=" + id + ", name=" + name + ", description=" + description + ", url=" + url + ", address=" + address + '}';
}
}