/* * 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 + '}'; } }