1 package dst.ass1.jpa.model.impl;
3 import dst.ass1.jpa.model.IEnrollment;
4 import dst.ass1.jpa.model.IMembership;
5 import dst.ass1.jpa.model.IParticipant;
6 import dst.ass1.jpa.util.Constants;
8 import javax.persistence.*;
9 import java.util.ArrayList;
10 import java.util.Collection;
13 @Table(name = Constants.T_PARTICIPANT, uniqueConstraints = {@UniqueConstraint(columnNames = {Constants.M_PARTICIPANT_ACCOUNT, Constants.M_PARTICIPANT_BANK_CODE})})
14 @NamedQuery(name = Constants.Q_PARTICIPANT_BY_EMAIL, query =
15 "SELECT p FROM " + Constants.T_PARTICIPANT + " as p where p." + Constants.M_PERSON_EMAIL + " = :email")
16 public class Participant extends Person implements IParticipant {
17 @Column(nullable = false, unique = true)
20 @Column(name = Constants.M_PERSON_PASSWORD, columnDefinition = "VARBINARY(20)")
21 private byte[] password;
24 private String accountNo;
27 private String bankCode;
29 @OneToMany(targetEntity = Enrollment.class)
30 private Collection<IEnrollment> enrollments = new ArrayList<>();
32 @OneToMany(targetEntity = Membership.class)
33 private Collection<IMembership> memberships = new ArrayList<>();
37 public String getEmail() {
42 public void setEmail(String email) {
47 public byte[] getPassword() {
52 public void setPassword(byte[] password) {
53 this.password = password;
57 public String getAccountNo() {
62 public void setAccountNo(String accountNo) {
63 this.accountNo = accountNo;
67 public String getBankCode() {
72 public void setBankCode(String bankCode) {
73 this.bankCode = bankCode;
77 public Collection<IEnrollment> getEnrollments() {
82 public void setEnrollments(Collection<IEnrollment> enrollments) {
83 this.enrollments = enrollments;
87 public void addEnrollment(IEnrollment enrollment) {
88 this.enrollments.add(enrollment);
92 public Collection<IMembership> getMemberships() {
97 public void setMemberships(Collection<IMembership> memberships) {
98 this.memberships = memberships;
102 public void addMembership(IMembership membership) {
103 this.memberships.add(membership);