include purge job for maintaining event logs and visitor logs
This commit is contained in:
		
							
								
								
									
										76
									
								
								Oqtane.Server/Infrastructure/Jobs/PurgeJob.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								Oqtane.Server/Infrastructure/Jobs/PurgeJob.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,76 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using Microsoft.Extensions.DependencyInjection; | ||||
| using Oqtane.Models; | ||||
| using Oqtane.Repository; | ||||
| using Oqtane.Shared; | ||||
|  | ||||
| namespace Oqtane.Infrastructure | ||||
| { | ||||
|     public class PurgeJob : HostedServiceBase | ||||
|     { | ||||
|         // JobType = "Oqtane.Infrastructure.PurgeJob, Oqtane.Server" | ||||
|  | ||||
|         public PurgeJob(IServiceScopeFactory serviceScopeFactory) : base(serviceScopeFactory) | ||||
|         { | ||||
|             Name = "Purge Job"; | ||||
|             Frequency = "d"; // daily | ||||
|             Interval = 1; | ||||
|             StartDate = DateTime.ParseExact("03:00", "H:mm", null, System.Globalization.DateTimeStyles.None); // 3 AM | ||||
|             IsEnabled = true; | ||||
|         } | ||||
|  | ||||
|         // job is executed for each tenant in installation | ||||
|         public override string ExecuteJob(IServiceProvider provider) | ||||
|         { | ||||
|             string log = ""; | ||||
|  | ||||
|             // get services | ||||
|             var siteRepository = provider.GetRequiredService<ISiteRepository>(); | ||||
|             var settingRepository = provider.GetRequiredService<ISettingRepository>(); | ||||
|             var logRepository = provider.GetRequiredService<ILogRepository>(); | ||||
|             var visitorRepository = provider.GetRequiredService<IVisitorRepository>(); | ||||
|  | ||||
|             // iterate through sites for current tenant | ||||
|             List<Site> sites = siteRepository.GetSites().ToList(); | ||||
|             foreach (Site site in sites) | ||||
|             { | ||||
|                 log += "Processing Site: " + site.Name + "<br />"; | ||||
|  | ||||
|                 // get site settings | ||||
|                 Dictionary<string, string> settings = GetSettings(settingRepository.GetSettings(EntityNames.Site, site.SiteId).ToList()); | ||||
|  | ||||
|                 // purge event log | ||||
|                 int logretention = 30; | ||||
|                 if (settings.ContainsKey("LogRetention") && settings["LogRetention"] != "") | ||||
|                 { | ||||
|                     logretention = int.Parse(settings["LogRetention"]); | ||||
|                 } | ||||
|                 int count = logRepository.DeleteLogs(logretention); | ||||
|                 log += count.ToString() + " Event Logs Purged<br />"; | ||||
|  | ||||
|                 // purge visitors | ||||
|                 int visitorrention = 30; | ||||
|                 if (settings.ContainsKey("VisitorRetention") && settings["VisitorRetention"] != "") | ||||
|                 { | ||||
|                     visitorrention = int.Parse(settings["VisitorRetention"]); | ||||
|                 } | ||||
|                 count = visitorRepository.DeleteVisitors(visitorrention); | ||||
|                 log += count.ToString() + " Visitors Purged<br />"; | ||||
|             } | ||||
|  | ||||
|             return log; | ||||
|         } | ||||
|  | ||||
|         private Dictionary<string, string> GetSettings(List<Setting> settings) | ||||
|         { | ||||
|             Dictionary<string, string> dictionary = new Dictionary<string, string>(); | ||||
|             foreach (Setting setting in settings.OrderBy(item => item.SettingName).ToList()) | ||||
|             { | ||||
|                 dictionary.Add(setting.SettingName, setting.SettingValue); | ||||
|             } | ||||
|             return dictionary; | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker