using System;
using System.Text;
using System.Linq;
using System.Threading.Tasks;
using System.Collections.Generic;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Logging;
using AyaNova.Models;
using AyaNova.Util;
namespace AyaNova.Biz
{
internal static class EventLogProcessor
{
private static ILogger log = AyaNova.Util.ApplicationLogging.CreateLogger("EventLogProcessor");
///
/// Add an entry to the log
///
///
///
///
internal static void AddEntry(Event newEvent, AyContext ct)
{
ct.Event.Add(newEvent);
ct.SaveChanges();
}
///
/// Handle delete
/// remove all prior entries for object, add one deleted entry
///
///
///
///
///
///
internal static void DeleteObject(long userId, AyaType ayType, long ayId, string textra, AyContext ct)
{
ct.Database.ExecuteSqlCommand($"delete from aevent where aytype = {ayType} and ayid={ayId}");
ct.Event.Add(new Event(userId, ayId, ayType, AyaEvent.Deleted, textra));
ct.SaveChanges();
}
///
/// Get the event log for a specified object
///
internal static async Task GetLogForObject(long ayId, DateTime StartDate, DateTime EndDate, AyContext ct)
{
var items = await ct.Event
.Where(m => m.AyId == ayId)
.OrderBy(m => m.Created)
.ToListAsync();
if (items.Count == 0)
{
return "";
}
}
internal static Task GetLogForUser(long ayId, long userLocaleId, AyContext ct)
{
throw new NotImplementedException();
}
internal static string BuildLogEntry(bool userFormat, Event ev, List> lt)
{
StringBuilder S=new StringBuilder();
//Object format:
//DateTime, UserId, ActionNumber, Textra
//User format:
//DateTime, ObjectType, ObjectId, ActionNumber, Textra
ev
switch(ev.AyEvent){
case AyaEvent.Created:
break;
}
return ":";
}
/////////////////////////////////////////////////////////////////////
}//eoc
}//eons