CCM NG: Some enhancements in the JPA mapping
git-svn-id: https://svn.libreccm.org/ccm/jpa@3390 8810af33-2d31-482b-a856-94f89814c4dfpull/2/head
parent
985579e224
commit
fe957e93a5
|
|
@ -32,6 +32,8 @@ import org.libreccm.core.CcmObject;
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import javax.persistence.JoinColumn;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Association class describing the association between a category and an
|
* Association class describing the association between a category and an
|
||||||
* object. Instances of these class should not created manually.
|
* object. Instances of these class should not created manually.
|
||||||
|
|
@ -59,19 +61,21 @@ public class Categorization implements Serializable {
|
||||||
* The category to which this {@code Categorization} object belongs.
|
* The category to which this {@code Categorization} object belongs.
|
||||||
*/
|
*/
|
||||||
@ManyToOne
|
@ManyToOne
|
||||||
|
@JoinColumn(name = "category_id")
|
||||||
private Category category;
|
private Category category;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The categorised object.
|
* The categorised object.
|
||||||
*/
|
*/
|
||||||
@ManyToOne
|
@ManyToOne
|
||||||
|
@JoinColumn(name = "object_id")
|
||||||
private CcmObject categorizedObject;
|
private CcmObject categorizedObject;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If the categorised object is the index object of the category this
|
* If the categorised object is the index object of the category this
|
||||||
* property is set to {@code true}.
|
* property is set to {@code true}.
|
||||||
*/
|
*/
|
||||||
@Column(name = "index")
|
@Column(name = "category_index")
|
||||||
private boolean index;
|
private boolean index;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,6 @@ import org.hibernate.validator.constraints.NotBlank;
|
||||||
import org.libreccm.core.CcmObject;
|
import org.libreccm.core.CcmObject;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.AbstractList;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -21,6 +21,7 @@ package org.libreccm.categorization;
|
||||||
import org.hibernate.validator.constraints.NotBlank;
|
import org.hibernate.validator.constraints.NotBlank;
|
||||||
import org.hibernate.validator.constraints.URL;
|
import org.hibernate.validator.constraints.URL;
|
||||||
import org.libreccm.core.CcmObject;
|
import org.libreccm.core.CcmObject;
|
||||||
|
import org.libreccm.jpautils.UriConverter;
|
||||||
import org.libreccm.l10n.LocalizedString;
|
import org.libreccm.l10n.LocalizedString;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
@ -33,6 +34,8 @@ import java.util.Objects;
|
||||||
|
|
||||||
import javax.persistence.AssociationOverride;
|
import javax.persistence.AssociationOverride;
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
|
import javax.persistence.Convert;
|
||||||
|
import javax.persistence.Converter;
|
||||||
import javax.persistence.Embedded;
|
import javax.persistence.Embedded;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.JoinColumn;
|
import javax.persistence.JoinColumn;
|
||||||
|
|
@ -86,6 +89,7 @@ public class Domain extends CcmObject implements Serializable {
|
||||||
* </pre>
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@Column(name = "uri", nullable = false, unique = true, length = 2048)
|
@Column(name = "uri", nullable = false, unique = true, length = 2048)
|
||||||
|
@Convert(converter = UriConverter.class)
|
||||||
@NotBlank
|
@NotBlank
|
||||||
@URL
|
@URL
|
||||||
private URI uri;
|
private URI uri;
|
||||||
|
|
|
||||||
|
|
@ -38,7 +38,7 @@ import org.libreccm.core.CcmObject;
|
||||||
* @author <a href="jens.pelzetter@googlemail.com">Jens Pelzetter</a>
|
* @author <a href="jens.pelzetter@googlemail.com">Jens Pelzetter</a>
|
||||||
*/
|
*/
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "domain_ownerships;")
|
@Table(name = "domain_ownerships")
|
||||||
public class DomainOwnership implements Serializable {
|
public class DomainOwnership implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = 201504301305L;
|
private static final long serialVersionUID = 201504301305L;
|
||||||
|
|
|
||||||
|
|
@ -90,6 +90,12 @@ public class CcmObject implements Serializable {
|
||||||
@OneToMany(mappedBy = "categorizedObject")
|
@OneToMany(mappedBy = "categorizedObject")
|
||||||
private List<Categorization> categories;
|
private List<Categorization> categories;
|
||||||
|
|
||||||
|
public CcmObject() {
|
||||||
|
super();
|
||||||
|
|
||||||
|
domains = new ArrayList<>();
|
||||||
|
categories = new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
public long getObjectId() {
|
public long getObjectId() {
|
||||||
return objectId;
|
return objectId;
|
||||||
|
|
@ -107,11 +113,6 @@ public class CcmObject implements Serializable {
|
||||||
this.displayName = displayName;
|
this.displayName = displayName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public CcmObject() {
|
|
||||||
domains = new ArrayList<>();
|
|
||||||
categories = new ArrayList<>();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets an <strong>unmodifiable</strong> list of the domains which are owned
|
* Gets an <strong>unmodifiable</strong> list of the domains which are owned
|
||||||
* by the {@code CcmObject}.
|
* by the {@code CcmObject}.
|
||||||
|
|
|
||||||
|
|
@ -24,8 +24,10 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import javax.persistence.CollectionTable;
|
||||||
import javax.persistence.ElementCollection;
|
import javax.persistence.ElementCollection;
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.JoinColumn;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
import javax.validation.constraints.Size;
|
import javax.validation.constraints.Size;
|
||||||
|
|
||||||
|
|
@ -41,6 +43,9 @@ public class Party extends CcmObject implements Serializable {
|
||||||
private static final long serialVersionUID = 6303836654273293979L;
|
private static final long serialVersionUID = 6303836654273293979L;
|
||||||
|
|
||||||
@ElementCollection
|
@ElementCollection
|
||||||
|
@CollectionTable(name = "party_email_addresses",
|
||||||
|
joinColumns = {
|
||||||
|
@JoinColumn(name = "party_id")})
|
||||||
@Size(min = 1)
|
@Size(min = 1)
|
||||||
private List<EmailAddress> eMailAddresses;
|
private List<EmailAddress> eMailAddresses;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -20,6 +20,7 @@ package org.libreccm.core;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import javax.persistence.AssociationOverride;
|
import javax.persistence.AssociationOverride;
|
||||||
import javax.persistence.Column;
|
import javax.persistence.Column;
|
||||||
import javax.persistence.Embedded;
|
import javax.persistence.Embedded;
|
||||||
|
|
@ -28,8 +29,15 @@ import javax.persistence.Entity;
|
||||||
import javax.persistence.JoinColumn;
|
import javax.persistence.JoinColumn;
|
||||||
import javax.persistence.JoinTable;
|
import javax.persistence.JoinTable;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
|
|
||||||
import org.hibernate.validator.constraints.NotBlank;
|
import org.hibernate.validator.constraints.NotBlank;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.persistence.OneToMany;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
|
* @author <a href="mailto:jens.pelzetter@googlemail.com">Jens Pelzetter</a>
|
||||||
|
|
@ -70,6 +78,15 @@ public class User extends Party implements Serializable {
|
||||||
@Column(name = "password_answer", length = 2048)
|
@Column(name = "password_answer", length = 2048)
|
||||||
private String passwordAnswer;
|
private String passwordAnswer;
|
||||||
|
|
||||||
|
@OneToMany(mappedBy = "user")
|
||||||
|
private List<GroupMembership> groupMemberships;
|
||||||
|
|
||||||
|
public User() {
|
||||||
|
super();
|
||||||
|
|
||||||
|
this.groupMemberships = new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
public PersonName getName() {
|
public PersonName getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
@ -134,6 +151,24 @@ public class User extends Party implements Serializable {
|
||||||
this.passwordAnswer = passwordAnswer;
|
this.passwordAnswer = passwordAnswer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<GroupMembership> getGroupMemberships() {
|
||||||
|
return Collections.unmodifiableList(groupMemberships);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setGroupMemberships(
|
||||||
|
final List<GroupMembership> groupMemberships) {
|
||||||
|
this.groupMemberships = groupMemberships;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addGroupMembership(final GroupMembership groupMembership) {
|
||||||
|
groupMemberships.add(groupMembership);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void removeGroupMembership(
|
||||||
|
final GroupMembership groupMembership) {
|
||||||
|
groupMemberships.remove(groupMembership);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
int hash = super.hashCode();
|
int hash = super.hashCode();
|
||||||
|
|
|
||||||
|
|
@ -48,13 +48,13 @@ public class UserGroup extends Party implements Serializable {
|
||||||
private List<Role> roles;
|
private List<Role> roles;
|
||||||
|
|
||||||
@OneToMany(mappedBy = "group")
|
@OneToMany(mappedBy = "group")
|
||||||
private List<GroupMembership> groupMemberships;
|
private List<GroupMembership> members;
|
||||||
|
|
||||||
public UserGroup() {
|
public UserGroup() {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
roles = new ArrayList<>();
|
roles = new ArrayList<>();
|
||||||
groupMemberships = new ArrayList<>();
|
members = new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
|
|
@ -81,8 +81,20 @@ public class UserGroup extends Party implements Serializable {
|
||||||
roles.remove(role);
|
roles.remove(role);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<GroupMembership> getGroupMembership() {
|
public List<GroupMembership> getMembers() {
|
||||||
return Collections.unmodifiableList(groupMemberships);
|
return Collections.unmodifiableList(members);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setMembers(final List<GroupMembership> members) {
|
||||||
|
this.members = members;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void addMember(final GroupMembership member) {
|
||||||
|
members.add(member);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void removeMember(final GroupMembership member) {
|
||||||
|
members.remove(member);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -110,10 +122,10 @@ public class UserGroup extends Party implements Serializable {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Objects.equals(this.name, other.name)) {
|
if (!Objects.equals(this.name, other.getName())) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return Objects.equals(this.roles, other.roles);
|
return Objects.equals(this.roles, other.getRoles());
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canEquals(final Object obj) {
|
public boolean canEquals(final Object obj) {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue