com.brihaspathee.zeus.domain.entity.EnrollmentSpan Maven / Gradle / Ivy
The newest version!
package com.brihaspathee.zeus.domain.entity;
import jakarta.persistence.*;
import lombok.*;
import org.hibernate.annotations.CreationTimestamp;
import org.hibernate.annotations.GenericGenerator;
import org.hibernate.annotations.JdbcTypeCode;
import org.hibernate.annotations.UpdateTimestamp;
import java.sql.Types;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.List;
import java.util.UUID;
/**
* Created in Intellij IDEA
* User: Balaji Varadharajan
* Date: 27, April 2024
* Time: 5:38 AM
* Project: Zeus
* Package Name: com.brihaspathee.zeus.domain.entity
* To change this template use File | Settings | File and Code Template
*/
@Getter
@Setter
@Builder
@Entity
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "ENROLLMENT_SPAN")
public class EnrollmentSpan {
/**
* Primary key of the table
*/
@Id
@GeneratedValue(generator = "UUID")
@JdbcTypeCode(Types.LONGVARCHAR)
@GenericGenerator(name="UUID", strategy = "org.hibernate.id.UUIDGenerator")
@Column(name = "enrollment_span_sk", length = 36, columnDefinition = "varchar", updatable = false, nullable = false)
private UUID enrollmentSpanSK;
/**
* Unique enrollment span code that is assigned to the enrollment span
*/
@Column(name = "enrollment_span_code", length = 50, columnDefinition = "varchar", nullable = false, updatable = false)
private String enrollmentSpanCode;
/**
* The enrollment type of the enrollment span
*/
@Column(name = "enrollment_type", length = 20, columnDefinition = "varchar", nullable = true)
private String enrollmentType;
/**
* The state that is associated with the enrollment span
*/
@Column(name = "state_type_code", length = 50, columnDefinition = "varchar", nullable = false)
private String stateTypeCode;
/**
* The marketplace that is associated with the enrollment span
*/
@Column(name = "marketplace_type_code", length = 50, columnDefinition = "varchar", nullable = false)
private String marketplaceTypeCode;
/**
* The business unit of the enrollment span
*/
@Column(name = "business_unit_type_code", length = 50, columnDefinition = "varchar", nullable = false)
private String businessUnitTypeCode;
/**
* Identifies the coverage type of the enrollment span
*/
@Column(name = "coverage_type_code", length = 50, columnDefinition = "varchar", nullable = false)
private String coverageTypeCode;
/**
* The start date of the enrollment span
*/
@Column(name = "start_date", nullable = false)
private LocalDate startDate;
/**
* The end date of the enrollment span
*/
@Column(name = "end_date", nullable = false)
private LocalDate endDate;
/**
* The exchange subscriber id associated with the enrollment span
*/
@Column(name = "exchange_subscriber_id", columnDefinition = "varchar", length = 50, nullable = false)
private String exchangeSubscriberId;
/**
* The effectuation date of the enrollment span
*/
@Column(name = "effectuation_date", nullable = true)
private LocalDate effectuationDate;
/**
* The plan id associated with the enrollment span
*/
@Column(name = "plan_id", columnDefinition = "varchar", nullable = false, length = 100)
private String planId;
/**
* The product type associated with the plan of the enrollment span
*/
@Column(name = "product_type_code", columnDefinition = "varchar", length = 100, nullable = false)
private String productTypeCode;
/**
* The group policy id associated with the enrollment span
*/
@Column(name = "group_policy_id", columnDefinition = "varchar", length = 100, nullable = false)
private String groupPolicyId;
/**
* The status of the enrollment span
*/
@Column(name = "status_type_code", columnDefinition = "varchar", length = 50, nullable = false)
private String statusTypeCode;
/**
* The effective reason that is associated with the enrollment span
*/
@Column(name = "effective_reason", length = 150, columnDefinition = "varchar", nullable = true)
private String effectiveReason;
/**
* The term reason that is associated with the enrollment span
*/
@Column(name = "term_reason", length = 150, columnDefinition = "varchar", nullable = true)
private String termReason;
/**
* Identifies if the enrollment span is delinquent or not
*/
@Column(name="delinq_ind")
private boolean delinqInd;
/**
* The paid through date of the enrollment span
*/
@Column(name = "paid_through_date", nullable = true)
private LocalDate paidThroughDate;
/**
* The claim paid through date of the enrollment span
*/
@Column(name = "claim_paid_through_date", nullable = true)
private LocalDate claimPaidThroughDate;
/**
* The list of premium spans that are associated with the enrollment span
*/
@OneToMany(mappedBy = "enrollmentSpan", fetch = FetchType.EAGER, cascade = CascadeType.REMOVE)
private List premiumSpans;
/**
* The list of premium payments that are associated with the enrollment span
*/
@OneToMany(mappedBy = "enrollmentSpan", fetch = FetchType.EAGER, cascade = CascadeType.REMOVE)
private List premiumPayments;
/**
* The account to which the enrollment span is associated
*/
@ManyToOne
@JoinColumn(name = "account_sk")
private Account account;
/**
* The date when the record was created
*/
@CreationTimestamp
@Column(name = "created_date")
private LocalDateTime createdDate;
/**
* The date when the record was updated
*/
@UpdateTimestamp
@Column(name = "updated_date")
private LocalDateTime updatedDate;
}