private async Task AddCommentToCacheAsync(LiveChatData chat) { using (var releaser = await _CommentRecievingLock.LockAsync()) { var keyVpos = VposToCacheDictTime(chat.Vpos); if (_TimeToCommentsDict.TryGetValue(keyVpos, out var alreadList)) { alreadList.Add(chat); } else { var list = new List <LiveChatData>() { chat }; _TimeToCommentsDict.Add(keyVpos, list); } } }
private void ParseChatXml(string xml) { var xmlDoc = XDocument.Parse(xml); var xmlRoot = xmlDoc.Root; var elementName = xmlRoot.Name.LocalName; Debug.Write(elementName); Debug.Write(" -> "); if (elementName == "thread") { Debug.Write("connect success"); IsConnected = true; // <thread ticket="{チケット}" server_time="{サーバー時刻}" last_res="{送信される過去のコメント数?(NECOで使用してないので不明)}"> var serverTimeText = xmlRoot.Attribute(XName.Get("server_time")).Value; long serverTime; if (long.TryParse(serverTimeText, out serverTime)) { _ServerTime = serverTime; } var ticketText = xmlRoot.Attribute(XName.Get("ticket")).Value; _Ticket = ticketText; Connected?.Invoke(this, new CommentServerConnectedEventArgs() { Ticket = _Ticket, ServerTime = (int)_ServerTime, Thread = this.ThreadId }); } else if (elementName == "chat_result") { // <chat_result status="{コメント投稿要求の返答}" /> var result = xmlRoot.Attribute(XName.Get("status")).Value; /* * 0 = 投稿に成功した * 1 = 投稿に失敗した(短時間に同じ内容のコメントを投稿しようとした、パラメータが間違っている、他) * 4 = 投稿に失敗した(ごく短時間にコメントを連投しようとした、パラメータが間違っている、他) */ Debug.Write(result); Debug.Write(result == "0" ? " (success)" : " (failed)"); CommentPosted?.Invoke(this, new CommentPostedEventArgs() { ChatResult = (ChatResult)int.Parse(result), }); _LastPostChat = null; } else if (elementName == "chat") { // _LiveComments.Add(chat); // <chat anonymity="{184か}" no="{コメントの番号}" date="{コメントが投稿されたリアル時間?}" mail="{コマンド}" premium="{プレミアムID}" thread="{スレッドID}" user_id="{ユーザーID}" vpos="{コメントが投稿された生放送の時間}" score="{NGスコア}">{コメント}</chat>\0 try { var chatSerializer = new XmlSerializer(typeof(Chat)); using (var readerStream = new StringReader(xml)) { var chat = chatSerializer.Deserialize(readerStream) as Chat; if (chat != null) { Debug.Write(chat.Text); OperationCommnad officialCommand = null; string[] officialCommandArguments = null; if (ChcekOfficialOperationComment(chat, out officialCommand, out officialCommandArguments)) { var args = new NicoLiveOperationCommandEventArgs() { CommandType = officialCommand.CommandType, Arguments = officialCommandArguments, Chat = chat }; // OperationCommandRecieved?.Invoke(this, args); } else { var liveChatData = new LiveChatData() { No = (int)chat.GetCommentNo(), Thread = chat.Thread, IsAnonymity = chat.GetAnonymity(), Content = chat.Text, Mail = chat.Mail, UserId = chat.User_id, Vpos = (int)chat.GetVpos(), Date = int.Parse(chat.Date), }; CommentRecieved?.Invoke(this, new CommentRecievedEventArgs() { Chat = liveChatData }); } } } } catch { } } else { Debug.WriteLine($"not supproted"); Debug.Write(" -> "); Debug.Write(xml); } }