aboutsummaryrefslogtreecommitdiff
path: root/BackEnd/Timeline/Entities/DatabaseContext.cs
blob: cb776e72fd59bc140fe73a2780dc3cd53f4e681b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
using Microsoft.EntityFrameworkCore;

namespace Timeline.Entities
{
    public class DatabaseContext : DbContext
    {
        public DatabaseContext(DbContextOptions<DatabaseContext> options)
            : base(options)
        {
        }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.Entity<UserEntity>().Property(e => e.Version).HasDefaultValue(0);
            modelBuilder.Entity<UserEntity>().HasIndex(e => e.Username).IsUnique();
            modelBuilder.Entity<UserEntity>().Property(e => e.UniqueId).HasDefaultValueSql("lower(hex(randomblob(16)))");
            modelBuilder.Entity<UserEntity>().Property(e => e.UsernameChangeTime).HasDefaultValueSql("datetime('now', 'utc')");
            modelBuilder.Entity<UserEntity>().Property(e => e.CreateTime).HasDefaultValueSql("datetime('now', 'utc')");
            modelBuilder.Entity<UserEntity>().Property(e => e.LastModified).HasDefaultValueSql("datetime('now', 'utc')");
            modelBuilder.Entity<DataEntity>().HasIndex(e => e.Tag).IsUnique();
            modelBuilder.Entity<TimelineEntity>().Property(e => e.UniqueId).HasDefaultValueSql("lower(hex(randomblob(16)))");
            modelBuilder.Entity<UserTokenEntity>().HasIndex(e => e.Token).IsUnique();

            modelBuilder.ApplyUtcDateTimeConverter();
        }

        public DbSet<UserEntity> Users { get; set; } = default!;
        public DbSet<UserAvatarEntity> UserAvatars { get; set; } = default!;
        public DbSet<UserPermissionEntity> UserPermission { get; set; } = default!;
        public DbSet<TimelineEntity> Timelines { get; set; } = default!;
        public DbSet<TimelinePostEntity> TimelinePosts { get; set; } = default!;
        public DbSet<TimelinePostDataEntity> TimelinePostData { get; set; } = default!;
        public DbSet<TimelineMemberEntity> TimelineMembers { get; set; } = default!;
        public DbSet<HighlightTimelineEntity> HighlightTimelines { get; set; } = default!;
        public DbSet<BookmarkTimelineEntity> BookmarkTimelines { get; set; } = default!;

        public DbSet<UserConfigurationEntity> UserConfigurations { get; set; } = default!;

        public DbSet<JwtTokenEntity> JwtToken { get; set; } = default!;
        public DbSet<UserTokenEntity> UserTokens { get; set; } = default!;
        public DbSet<DataEntity> Data { get; set; } = default!;

        public DbSet<MigrationEntity> Migrations { get; set; } = default!;
    }
}