using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; using Microsoft.EntityFrameworkCore; namespace Iceshrimp.Backend.Core.Database.Tables; [Table("channel")] [Index("UsersCount")] [Index("NotesCount")] [Index("LastNotedAt")] [Index("CreatedAt")] [Index("UserId")] public class Channel { [Key] [Column("id")] [StringLength(32)] public string Id { get; set; } = null!; /// /// The created date of the Channel. /// [Column("createdAt")] public DateTime CreatedAt { get; set; } [Column("lastNotedAt")] public DateTime? LastNotedAt { get; set; } /// /// The owner ID. /// [Column("userId")] [StringLength(32)] public string? UserId { get; set; } /// /// The name of the Channel. /// [Column("name")] [StringLength(128)] public string Name { get; set; } = null!; /// /// The description of the Channel. /// [Column("description")] [StringLength(2048)] public string? Description { get; set; } /// /// The ID of banner Channel. /// [Column("bannerId")] [StringLength(32)] public string? BannerId { get; set; } /// /// The count of notes. /// [Column("notesCount")] public int NotesCount { get; set; } /// /// The count of users. /// [Column("usersCount")] public int UsersCount { get; set; } [ForeignKey("BannerId")] [InverseProperty(nameof(DriveFile.Channels))] public virtual DriveFile? Banner { get; set; } [InverseProperty(nameof(ChannelFollowing.Followee))] public virtual ICollection ChannelFollowings { get; set; } = new List(); [InverseProperty(nameof(ChannelNotePin.Channel))] public virtual ICollection ChannelNotePins { get; set; } = new List(); [InverseProperty(nameof(Note.Channel))] public virtual ICollection Notes { get; set; } = new List(); [ForeignKey("UserId")] [InverseProperty(nameof(Tables.User.Channels))] public virtual User? User { get; set; } }