Iceshrimp.NET/Iceshrimp.Backend/Core/Database/Tables/UserProfile.cs
Laura Hausmann 09cda1a89e
[backend/database] Move user_profile columns that only concern local users to user_settings
This commit also removes a bunch of obsolete user_profile columns.
2024-07-10 02:55:57 +02:00

95 lines
No EOL
2.6 KiB
C#

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Microsoft.EntityFrameworkCore;
using NpgsqlTypes;
using J = System.Text.Json.Serialization.JsonPropertyNameAttribute;
namespace Iceshrimp.Backend.Core.Database.Tables;
[Table("user_profile")]
[Index(nameof(UserHost))]
[Index(nameof(PinnedPageId), IsUnique = true)]
public class UserProfile
{
[Column("mentionsResolved")] public bool MentionsResolved;
[Key]
[Column("userId")]
[StringLength(32)]
public string UserId { get; set; } = null!;
/// <summary>
/// The location of the User.
/// </summary>
[Column("location")]
[StringLength(128)]
public string? Location { get; set; }
/// <summary>
/// The birthday (YYYY-MM-DD) of the User.
/// </summary>
[Column("birthday")]
[StringLength(10)]
public string? Birthday { get; set; }
/// <summary>
/// The description (bio) of the User.
/// </summary>
[Column("description")]
[StringLength(2048)]
public string? Description { get; set; }
[Column("fields", TypeName = "jsonb")] public Field[] Fields { get; set; } = null!;
/// <summary>
/// Remote URL of the user.
/// </summary>
[Column("url")]
[StringLength(512)]
public string? Url { get; set; }
[Column("ffVisibility")] public UserProfileFFVisibility FFVisibility { get; set; }
/// <summary>
/// [Denormalized]
/// </summary>
[Column("userHost")]
[StringLength(512)]
public string? UserHost { get; set; }
[Column("pinnedPageId")]
[StringLength(32)]
public string? PinnedPageId { get; set; }
[Column("lang")] [StringLength(32)] public string? Lang { get; set; }
[Column("moderationNote")]
[StringLength(8192)]
public string ModerationNote { get; set; } = null!;
[Column("mentions", TypeName = "jsonb")]
public List<Note.MentionedUser> Mentions { get; set; } = null!;
[ForeignKey(nameof(PinnedPageId))]
[InverseProperty(nameof(Page.UserProfile))]
public virtual Page? PinnedPage { get; set; }
[ForeignKey(nameof(UserId))]
[InverseProperty(nameof(Tables.User.UserProfile))]
public virtual User User { get; set; } = null!;
public class Field
{
[J("name")] public required string Name { get; set; }
[J("value")] public required string Value { get; set; }
[J("verified")] public bool? IsVerified { get; set; }
}
[PgName("user_profile_ffvisibility_enum")]
public enum UserProfileFFVisibility
{
[PgName("public")] Public = 0,
[PgName("followers")] Followers = 1,
[PgName("private")] Private = 2
}
}