180 lines
6.4 KiB
C#
180 lines
6.4 KiB
C#
using Longbow;
|
|
using Longbow.Caching;
|
|
using Longbow.ExceptionManagement;
|
|
using System;
|
|
using System.Collections.Concurrent;
|
|
using System.Collections.Generic;
|
|
using System.Data;
|
|
using System.Data.Common;
|
|
using System.Linq;
|
|
using System.Net.WebSockets;
|
|
using System.Threading;
|
|
|
|
namespace Bootstrap.DataAccess
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public static class NotificationHelper
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
internal const string RetrieveNotificationsDataKey = "NotificationHelper-RetrieveNotifications";
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public static readonly ConcurrentBag<MessageBody> MessagePool = new ConcurrentBag<MessageBody>();
|
|
/// <summary>
|
|
/// 新用户注册的通知的面板显示
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public static IEnumerable<Notification> RetrieveNotifications()
|
|
{
|
|
var notifies = CacheManager.GetOrAdd(RetrieveNotificationsDataKey, key =>
|
|
{
|
|
string sql = "select * from Notifications";
|
|
List<Notification> notifications = new List<Notification>();
|
|
DbCommand cmd = DBAccessManager.SqlDBAccess.CreateCommand(CommandType.Text, sql);
|
|
try
|
|
{
|
|
using (DbDataReader reader = DBAccessManager.SqlDBAccess.ExecuteReader(cmd))
|
|
{
|
|
while (reader.Read())
|
|
{
|
|
notifications.Add(new Notification()
|
|
{
|
|
Id = (int)reader[0],
|
|
Category = (string)reader[1],
|
|
Title = (string)reader[2],
|
|
Content = (string)reader[3],
|
|
RegisterTime = (DateTime)reader[4],
|
|
ProcessTime = LgbConvert.ReadValue(reader[5], DateTime.MinValue),
|
|
ProcessBy = LgbConvert.ReadValue(reader[6], string.Empty),
|
|
ProcessResult = LgbConvert.ReadValue(reader[7], string.Empty),
|
|
Status = (string)reader[8]
|
|
});
|
|
}
|
|
}
|
|
}
|
|
catch (Exception ex) { ExceptionManager.Publish(ex); }
|
|
return notifications;
|
|
|
|
});
|
|
notifies.AsParallel().ForAll(n =>
|
|
{
|
|
var ts = DateTime.Now - n.RegisterTime;
|
|
if (ts.TotalMinutes < 5) n.Period = "刚刚";
|
|
else if (ts.Days > 0) n.Period = string.Format("{0}天", ts.Days);
|
|
else if (ts.Hours > 0) n.Period = string.Format("{0}小时", ts.Hours);
|
|
else if (ts.Minutes > 0) n.Period = string.Format("{0}分钟", ts.Minutes);
|
|
});
|
|
return notifies.OrderByDescending(n => n.RegisterTime);
|
|
}
|
|
/// <summary>
|
|
/// 点击某一行用户注册通知的处理成功操作
|
|
/// </summary>
|
|
/// <param name="id"></param>
|
|
/// <returns></returns>
|
|
public static bool ProcessRegisterUser(string id)
|
|
{
|
|
if (string.IsNullOrEmpty(id)) return false;
|
|
bool ret = false;
|
|
try
|
|
{
|
|
using (DbCommand cmd = DBAccessManager.SqlDBAccess.CreateCommand(CommandType.StoredProcedure, "Proc_ProcessRegisterUser"))
|
|
{
|
|
cmd.Parameters.Add(DBAccessManager.SqlDBAccess.CreateParameter("@id", id));
|
|
DBAccessManager.SqlDBAccess.ExecuteNonQuery(cmd);
|
|
}
|
|
CacheCleanUtility.ClearCache(notifyIds: id);
|
|
ret = true;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
ExceptionManager.Publish(ex);
|
|
}
|
|
return ret;
|
|
}
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <param name="noti"></param>
|
|
/// <returns></returns>
|
|
public static bool SaveNotification(Notification noti)
|
|
{
|
|
if (string.IsNullOrEmpty(noti.Title) || string.IsNullOrEmpty(noti.Content)) return false;
|
|
bool ret = false;
|
|
try
|
|
{
|
|
using (DbCommand cmd = DBAccessManager.SqlDBAccess.CreateCommand(CommandType.Text, "Insert into Notifications (Category, Title, Content, RegisterTime) values (N'2', @Title, @Content, GetDate())"))
|
|
{
|
|
cmd.Parameters.Add(DBAccessManager.SqlDBAccess.CreateParameter("@Title", noti.Title));
|
|
cmd.Parameters.Add(DBAccessManager.SqlDBAccess.CreateParameter("@Content", noti.Content));
|
|
DBAccessManager.SqlDBAccess.ExecuteNonQuery(cmd);
|
|
}
|
|
CacheCleanUtility.ClearCache(notifyIds: string.Empty);
|
|
ret = true;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
ExceptionManager.Publish(ex);
|
|
}
|
|
return ret;
|
|
}
|
|
}
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public class MessageBody : IDisposable
|
|
{
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public MessageBody()
|
|
{
|
|
timer = new Timer(state =>
|
|
{
|
|
var msg = this;
|
|
NotificationHelper.MessagePool.TryTake(out msg);
|
|
}, null, 5000, Timeout.Infinite);
|
|
}
|
|
private Timer timer = null;
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public string Message { get; set; }
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public string Category { get; set; }
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public override string ToString()
|
|
{
|
|
return string.Format("{0};{1}-{2}", Category, Message);
|
|
}
|
|
private void Dispose(bool disposing)
|
|
{
|
|
if (disposing)
|
|
{
|
|
if (timer != null)
|
|
{
|
|
timer.Dispose();
|
|
timer = null;
|
|
}
|
|
}
|
|
}
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
public void Dispose()
|
|
{
|
|
Dispose(true);
|
|
GC.SuppressFinalize(this);
|
|
}
|
|
}
|
|
}
|