http-api/src/Persistence/PostgreSql/Configurations/TicketGroupConfiguration.cs

94 lines
3.1 KiB
C#

using cuqmbr.TravelGuide.Domain.Entities;
using cuqmbr.TravelGuide.Domain.Enums;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
namespace cuqmbr.TravelGuide.Persistence.PostgreSql.Configurations;
public class TicketGroupConfiguration : BaseConfiguration<TicketGroup>
{
public override void Configure(EntityTypeBuilder<TicketGroup> builder)
{
builder
.Property(tg => tg.PassangerSex)
.HasColumnName("passanger_sex")
.IsRequired(true);
builder
.Property(tg => tg.Status)
.HasColumnName("status")
.IsRequired(true);
builder
.ToTable(
"ticket_groups",
tg =>
{
tg.HasCheckConstraint(
"ck_" +
$"{builder.Metadata.GetTableName()}_" +
$"{builder.Property(tg => tg.PassangerSex)
.Metadata.GetColumnName()}",
$"{builder.Property(g => g.PassangerSex)
.Metadata.GetColumnName()} IN ('{String
.Join("', '", Sex.Enumerations
.Values.Select(v => v.Name))}')");
tg.HasCheckConstraint(
"ck_" +
$"{builder.Metadata.GetTableName()}_" +
$"{builder.Property(tg => tg.Status)
.Metadata.GetColumnName()}",
$"{builder.Property(g => g.Status)
.Metadata.GetColumnName()} IN ('{String
.Join("', '", TicketStatus.Enumerations
.Values.Select(v => v.Name))}')");
});
base.Configure(builder);
builder
.Property(tg => tg.PassangerFirstName)
.HasColumnName("passanger_first_name")
.HasColumnType("varchar(32)")
.IsRequired(true);
builder
.Property(tg => tg.PassangerLastName)
.HasColumnName("passanger_last_name")
.HasColumnType("varchar(32)")
.IsRequired(true);
builder
.Property(tg => tg.PassangerPatronymic)
.HasColumnName("passanger_patronymic")
.HasColumnType("varchar(32)")
.IsRequired(true);
builder
.Property(tg => tg.PassangerBirthDate)
.HasColumnName("passanger_birth_date")
.HasColumnType("date")
.IsRequired(true);
builder
.Property(tg => tg.PassangerEmail)
.HasColumnName("passanger_email")
.HasColumnType("varchar(256)")
.IsRequired(false);
builder
.Property(tg => tg.PurchaseTime)
.HasColumnName("purchase_time")
.HasColumnType("timestamptz")
.IsRequired(true);
builder
.Property(tg => tg.TravelTime)
.HasColumnName("travel_time")
.HasColumnType("interval")
.IsRequired(true);
}
}