From 9090c5094cec5b4cc2cd7f1f48c38ee0b36e09bf Mon Sep 17 00:00:00 2001 From: Executor Date: Mon, 24 Jul 2023 09:45:06 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=B8=BB=E6=92=AD=E7=94=A8?= =?UTF-8?q?=E6=88=B7Id=E8=B6=85=E5=87=BAInt32=E8=8C=83=E5=9B=B4=E5=AF=BC?= =?UTF-8?q?=E8=87=B4=E6=88=BF=E9=97=B4=E6=97=A0=E6=B3=95=E8=A2=AB=E6=B7=BB?= =?UTF-8?q?=E5=8A=A0=E7=9A=84=E9=97=AE=E9=A2=98=20GUI=E7=95=8C=E9=9D=A2?= =?UTF-8?q?=E5=B0=86=E5=B0=9D=E8=AF=95=E6=98=BE=E7=A4=BA=E4=B8=BB=E6=92=AD?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E5=90=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Directory.Build.props | 8 +++--- .../Apis/BiliApis.GetRoomInfo.cs | 4 +-- .../Apis/BiliApis.GetUserInfo.cs | 2 +- src/BililiveNotification/MainWindow.xaml | 1 + src/BililiveNotification/Models/RoomInfo.cs | 6 ++--- src/BililiveNotification/Models/UserInfo.cs | 6 ++--- src/BililiveNotification/RoomMonitor.cs | 26 ++++++++++++++++++- 7 files changed, 39 insertions(+), 14 deletions(-) diff --git a/Directory.Build.props b/Directory.Build.props index 9448230..5eb1c24 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -7,9 +7,9 @@ true true - 1.0.4.0 - 1.0.4.0 - 1.0.4.0 - 1.0.4.0 + 1.0.5.0 + 1.0.5.0 + 1.0.5.0 + 1.0.5.0 diff --git a/src/BililiveNotification/Apis/BiliApis.GetRoomInfo.cs b/src/BililiveNotification/Apis/BiliApis.GetRoomInfo.cs index d44092b..80ade23 100644 --- a/src/BililiveNotification/Apis/BiliApis.GetRoomInfo.cs +++ b/src/BililiveNotification/Apis/BiliApis.GetRoomInfo.cs @@ -1,4 +1,4 @@ -using BililiveNotification.Models; +using BililiveNotification.Models; using Executorlibs.Shared.Exceptions; using Executorlibs.Shared.Extensions; using System; @@ -24,7 +24,7 @@ public static async Task GetRoomInfoAsync(HttpClient client, int roomI throw new UnknownResponseException(in root); } JsonElement data = root.GetProperty("data"); - int userId = data.GetProperty("uid").GetInt32(); + long userId = data.GetProperty("uid").GetInt64(); UserInfo userInfo = await GetUserInfoAsync(client, userId, token); string? cover = data.GetProperty("user_cover").GetString(); if (cover == "") diff --git a/src/BililiveNotification/Apis/BiliApis.GetUserInfo.cs b/src/BililiveNotification/Apis/BiliApis.GetUserInfo.cs index 80be26c..dda87e3 100644 --- a/src/BililiveNotification/Apis/BiliApis.GetUserInfo.cs +++ b/src/BililiveNotification/Apis/BiliApis.GetUserInfo.cs @@ -11,7 +11,7 @@ namespace BililiveNotification.Apis { public static partial class BiliApis { - public static async Task GetUserInfoAsync(HttpClient client, int userId, CancellationToken token = default) + public static async Task GetUserInfoAsync(HttpClient client, long userId, CancellationToken token = default) { HttpRequestMessage req = new HttpRequestMessage(HttpMethod.Get, $"https://api.bilibili.com/x/web-interface/card?mid={userId}"); req.Headers.Accept.ParseAdd("*/*"); diff --git a/src/BililiveNotification/MainWindow.xaml b/src/BililiveNotification/MainWindow.xaml index 0468544..ad6f532 100644 --- a/src/BililiveNotification/MainWindow.xaml +++ b/src/BililiveNotification/MainWindow.xaml @@ -19,6 +19,7 @@ + diff --git a/src/BililiveNotification/Models/RoomInfo.cs b/src/BililiveNotification/Models/RoomInfo.cs index f60eda2..b4d74df 100644 --- a/src/BililiveNotification/Models/RoomInfo.cs +++ b/src/BililiveNotification/Models/RoomInfo.cs @@ -1,16 +1,16 @@ -namespace BililiveNotification.Models +namespace BililiveNotification.Models { public class RoomInfo { public string UserName { get; } - public int UserId { get; } + public long UserId { get; } public string FaceUrl { get; } public string? CoverUrl { get; } - public RoomInfo(string userName, int userId, string faceUrl, string? coverUrl) + public RoomInfo(string userName, long userId, string faceUrl, string? coverUrl) { UserName = userName; UserId = userId; diff --git a/src/BililiveNotification/Models/UserInfo.cs b/src/BililiveNotification/Models/UserInfo.cs index 01270d6..725d03c 100644 --- a/src/BililiveNotification/Models/UserInfo.cs +++ b/src/BililiveNotification/Models/UserInfo.cs @@ -1,14 +1,14 @@ -namespace BililiveNotification.Models +namespace BililiveNotification.Models { public class UserInfo { public string UserName { get; } - public int UserId { get; } + public long UserId { get; } public string FaceUrl { get; } - public UserInfo(string userName, int userId, string faceUrl) + public UserInfo(string userName, long userId, string faceUrl) { UserName = userName; UserId = userId; diff --git a/src/BililiveNotification/RoomMonitor.cs b/src/BililiveNotification/RoomMonitor.cs index a032836..d02a059 100644 --- a/src/BililiveNotification/RoomMonitor.cs +++ b/src/BililiveNotification/RoomMonitor.cs @@ -1,4 +1,4 @@ -using BililiveNotification.Apis; +using BililiveNotification.Apis; using BililiveNotification.Models; using Executorlibs.Bilibili.Protocol.Clients; using Executorlibs.Bilibili.Protocol.Handlers; @@ -40,6 +40,8 @@ public sealed class RoomMonitor : IDisposable, public event PropertyChangedEventHandler? PropertyChanged; + private string? _masterName; + private DateTime _lastTime; private bool _status; @@ -67,6 +69,19 @@ public bool LiveStatus } } + public string? MasterName + { + get => _masterName; + set + { + if (_masterName != value) + { + _masterName = value; + OnPropertyChanged(); + } + } + } + public int RoomId { get; } public string StatusDisplay => _status ? "启用" : "禁用"; @@ -159,6 +174,15 @@ public async Task InitializeAsync() _lastTime = time.Value; OnPropertyChanged(nameof(LiveStatusDisplay)); } + try + { + var roomInfo = await BiliApis.GetRoomInfoAsync(_httpClient, RoomId); + MasterName = roomInfo.UserName; + } + catch (Exception) + { + MasterName = "<获取失败>"; + } await StartAsync(); }