private string EnforceBannedWord(WinterBot bot, TwitchUser user, string word) { int timeout = m_banWordOptions.TimeOut; string msg = m_banWordOptions.Message; if (!string.IsNullOrWhiteSpace(msg)) { msg = msg.Replace("$word", word); } if (timeout <= 0) { return(msg); } if (!m_chatOptions.ShouldTimeout(user)) { timeout = 1; } ClearChat(bot, user, null, timeout); if (!string.IsNullOrWhiteSpace(msg)) { if (timeout == 1) { bot.Send(MessageType.Timeout, Importance.Med, "{0}: {1} (This is not a timeout.)", user.Name, msg); } else { bot.Send(MessageType.Timeout, Importance.Med, "{0}: {1} ({2} second timeout.)", user.Name, msg, timeout); } } return(null); }
private string EnforceBannedWord(WinterBot bot, TwitchUser user, string word) { int timeout = m_banWordOptions.TimeOut; string msg = m_banWordOptions.Message; if (!string.IsNullOrWhiteSpace(msg)) msg = msg.Replace("$word", word); if (timeout <= 0) return msg; if (!m_chatOptions.ShouldTimeout(user)) timeout = 1; ClearChat(bot, user, null, timeout); if (!string.IsNullOrWhiteSpace(msg)) { if (timeout == 1) bot.Send(MessageType.Timeout, Importance.Med, "{0}: {1} (This is not a timeout.)", user.Name, msg); else bot.Send(MessageType.Timeout, Importance.Med, "{0}: {1} ({2} second timeout.)", user.Name, msg, timeout); } return null; }
private void ClearChat(WinterBot sender, TwitchUser user, string clearReason, int minTimeout=1) { bool shouldMessage = !string.IsNullOrEmpty(clearReason); var now = DateTime.Now; TimeoutCount timeout; if (!m_timeouts.TryGetValue(user, out timeout)) { timeout = m_timeouts[user] = new TimeoutCount(now); } else { shouldMessage &= (DateTime.Now > timeout.LastTimeout) && (DateTime.Now - timeout.LastTimeout).TotalMinutes > 60; timeout.Count = GetEffectiveCount(timeout) + 1; } timeout.LastTimeout = now; if (!m_chatOptions.ShouldTimeout(user)) timeout.Count = 1; if (minTimeout < 1) minTimeout = 1; int duration = 0; switch (timeout.Count) { case 1: case 2: duration = 1; break; case 3: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 5 * 60; break; case 4: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 10 * 60; break; case 5: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 8 * 60 * 60; break; } if (duration < minTimeout) duration = minTimeout; if (shouldMessage) { if (duration == 1) sender.Send(MessageType.Timeout, Importance.Med, "{0}: {1} (This is not a timeout.)", user.Name, clearReason); else if (duration < 60) sender.Send(MessageType.Timeout, Importance.High, "{0}: {1}", user.Name, clearReason); else if (duration < 3600) sender.Send(MessageType.Timeout, Importance.High, "{0}: {1} ({2} minute timeout.)", user.Name, clearReason, duration / 60); else sender.Send(MessageType.Timeout, Importance.High, "{0}: {1} ({2} hour timeout.)", user.Name, clearReason, duration / 3600); } sender.Timeout(user, duration); timeout.LastTimeout = now.AddSeconds(duration); }
private void ClearChat(WinterBot sender, TwitchUser user, string clearReason) { bool shouldMessage = !string.IsNullOrEmpty(clearReason); var now = DateTime.Now; TimeoutCount timeout; if (!m_timeouts.TryGetValue(user, out timeout)) { timeout = m_timeouts[user] = new TimeoutCount(now); } else { shouldMessage &= (DateTime.Now > timeout.LastTimeout) && (DateTime.Now - timeout.LastTimeout).TotalMinutes > 60; int curr = timeout.Count; int diff = (int)(now - timeout.LastTimeout).TotalMinutes / 15; if (diff > 0) curr -= diff; if (curr < 0) curr = 0; timeout.Count = curr + 1; } timeout.LastTimeout = now; if (!m_chatOptions.ShouldTimeout(user)) timeout.Count = 1; int duration = 0; switch (timeout.Count) { case 1: case 2: if (shouldMessage) sender.Send(MessageType.Timeout, "{0}: {1} (This is not a timeout.)", user.Name, clearReason); sender.ClearChat(user); break; case 3: duration = 5; sender.Send(MessageType.Timeout, "{0}: {1} ({2} minute timeout.)", user.Name, clearReason, duration); sender.Timeout(user, duration * 60); timeout.LastTimeout = now.AddMinutes(duration); break; case 4: duration = 10; sender.Send(MessageType.Timeout, "{0}: {1} ({2} minute timeout.)", user.Name, clearReason, duration); sender.Timeout(user, duration * 60); timeout.LastTimeout = now.AddMinutes(duration); break; default: Debug.Assert(timeout.Count > 0); sender.Send(MessageType.Timeout, "{0}: {1} (8 hour timeout.)", user.Name, clearReason); sender.Timeout(user, 8 * 60 * 60); timeout.LastTimeout = now.AddHours(8); break; } }
private void ClearChat(WinterBot sender, TwitchUser user, string clearReason, int minTimeout = 1) { bool shouldMessage = !string.IsNullOrEmpty(clearReason); var now = DateTime.Now; TimeoutCount timeout; if (!m_timeouts.TryGetValue(user, out timeout)) { timeout = m_timeouts[user] = new TimeoutCount(now); } else { shouldMessage &= (DateTime.Now > timeout.LastTimeout) && (DateTime.Now - timeout.LastTimeout).TotalMinutes > 60; timeout.Count = GetEffectiveCount(timeout) + 1; } timeout.LastTimeout = now; if (!m_chatOptions.ShouldTimeout(user)) { timeout.Count = 1; } if (minTimeout < 1) { minTimeout = 1; } int duration = 0; switch (timeout.Count) { case 1: case 2: duration = 1; break; case 3: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 5 * 60; break; case 4: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 10 * 60; break; case 5: shouldMessage = !string.IsNullOrEmpty(clearReason); duration = 8 * 60 * 60; break; } if (duration < minTimeout) { duration = minTimeout; } if (shouldMessage) { if (duration == 1) { sender.Send(MessageType.Timeout, Importance.Med, "{0}: {1} (This is not a timeout.)", user.Name, clearReason); } else if (duration < 60) { sender.Send(MessageType.Timeout, Importance.High, "{0}: {1}", user.Name, clearReason); } else if (duration < 3600) { sender.Send(MessageType.Timeout, Importance.High, "{0}: {1} ({2} minute timeout.)", user.Name, clearReason, duration / 60); } else { sender.Send(MessageType.Timeout, Importance.High, "{0}: {1} ({2} hour timeout.)", user.Name, clearReason, duration / 3600); } } sender.Timeout(user, duration); timeout.LastTimeout = now.AddSeconds(duration); }