mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-31 10:37:04 -04:00 
			
		
		
		
	* Added some basic OPDS implementation * Fixed an issue with feed href * More changes * Added library routes and moved user code to a method so we can hack in fixed code without authentication * Images now load on the OPDS reusing our existing Image infrastructure. * Added the ability to download and moved some download code to a dedicated service * Download is working, pagination is implemented. * Refactored libraries to use pagination * Laid foundation for OpenSearch implementation * Fixed up some serialization issues and some old code that wasn't referencing helper methods * Ensure chapters are sorted when we send them over OPDS * OpenSearch implemented * Removed any support for OPDS-PS due to lack of apps supporting it. * Don't distribute development.json nor stats directory on build. * Implemented In Progress feed as well. * Ability to enable OPDS for server. OPDS now accepts initial call as POST in case app uses username/password. * UI now properly renders state for OPDS enablement. Added Collections routes. * Fixed pagination startIndex on OPDS feeds when there is less than 1 page. * Chunky Reader now works. It only accepts UTF-8 encodings * More Chunky fixes * More chunky changes, such a fussy client. * Implemented the ability to have a custom api key assigned to a user and use that api key as your authentication token against OPDS routing. * Implemented the ability to reset your API Key * Fixed favicon not being sent back correctly * Fixed an issue where images wouldn't send on OPDS feed. * Implemented Page streaming and fixed a pagination bug * Hooked in the ability to save progress in Kavita when Page Streaming
		
			
				
	
	
		
			91 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Collections.Generic;
 | |
| using System.IO;
 | |
| using System.Linq;
 | |
| using System.Reflection;
 | |
| using System.Threading.Tasks;
 | |
| using API.Constants;
 | |
| using API.Entities;
 | |
| using API.Entities.Enums;
 | |
| using API.Services;
 | |
| using Kavita.Common;
 | |
| using Microsoft.AspNetCore.Identity;
 | |
| using Microsoft.EntityFrameworkCore;
 | |
| 
 | |
| namespace API.Data
 | |
| {
 | |
|     public static class Seed
 | |
|     {
 | |
|         public static async Task SeedRoles(RoleManager<AppRole> roleManager)
 | |
|         {
 | |
|             var roles = typeof(PolicyConstants)
 | |
|                 .GetFields(BindingFlags.Public | BindingFlags.Static)
 | |
|                 .Where(f => f.FieldType == typeof(string))
 | |
|                 .ToDictionary(f => f.Name,
 | |
|                     f => (string) f.GetValue(null)).Values
 | |
|                 .Select(policyName => new AppRole() {Name = policyName})
 | |
|                 .ToList();
 | |
| 
 | |
|             foreach (var role in roles)
 | |
|             {
 | |
|                 var exists = await roleManager.RoleExistsAsync(role.Name);
 | |
|                 if (!exists)
 | |
|                 {
 | |
|                     await roleManager.CreateAsync(role);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public static async Task SeedSettings(DataContext context)
 | |
|         {
 | |
|             await context.Database.EnsureCreatedAsync();
 | |
| 
 | |
|             IList<ServerSetting> defaultSettings = new List<ServerSetting>()
 | |
|             {
 | |
|                 new() {Key = ServerSettingKey.CacheDirectory, Value = CacheService.CacheDirectory},
 | |
|                 new () {Key = ServerSettingKey.TaskScan, Value = "daily"},
 | |
|                 new () {Key = ServerSettingKey.LoggingLevel, Value = "Information"}, // Not used from DB, but DB is sync with appSettings.json
 | |
|                 new () {Key = ServerSettingKey.TaskBackup, Value = "weekly"},
 | |
|                 new () {Key = ServerSettingKey.BackupDirectory, Value = Path.GetFullPath(Path.Join(Directory.GetCurrentDirectory(), "backups/"))},
 | |
|                 new () {Key = ServerSettingKey.Port, Value = "5000"}, // Not used from DB, but DB is sync with appSettings.json
 | |
|                 new () {Key = ServerSettingKey.AllowStatCollection, Value = "true"},
 | |
|                 new () {Key = ServerSettingKey.EnableOpds, Value = "false"},
 | |
|             };
 | |
| 
 | |
|             foreach (var defaultSetting in defaultSettings)
 | |
|             {
 | |
|                 var existing = context.ServerSetting.FirstOrDefault(s => s.Key == defaultSetting.Key);
 | |
|                 if (existing == null)
 | |
|                 {
 | |
|                     await context.ServerSetting.AddAsync(defaultSetting);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             await context.SaveChangesAsync();
 | |
| 
 | |
|             // Port and LoggingLevel are managed in appSettings.json. Update the DB values to match
 | |
|             context.ServerSetting.First(s => s.Key == ServerSettingKey.Port).Value =
 | |
|                 Configuration.Port + string.Empty;
 | |
|             context.ServerSetting.First(s => s.Key == ServerSettingKey.LoggingLevel).Value =
 | |
|                 Configuration.LogLevel + string.Empty;
 | |
| 
 | |
|             await context.SaveChangesAsync();
 | |
| 
 | |
|         }
 | |
| 
 | |
|         public static async Task SeedUserApiKeys(DataContext context)
 | |
|         {
 | |
|             await context.Database.EnsureCreatedAsync();
 | |
| 
 | |
|             var users = await context.AppUser.ToListAsync();
 | |
|             foreach (var user in users)
 | |
|             {
 | |
|                 if (string.IsNullOrEmpty(user.ApiKey))
 | |
|                 {
 | |
|                     user.ApiKey = HashUtil.ApiKey();
 | |
|                 }
 | |
|             }
 | |
|             await context.SaveChangesAsync();
 | |
|         }
 | |
|     }
 | |
| }
 |