Add language repository & controller

This commit is contained in:
hishamco
2021-01-10 20:09:04 +03:00
parent 047fa9ac4e
commit aa19a35834
6 changed files with 132 additions and 1 deletions

View File

@ -1,4 +1,4 @@
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.EntityFrameworkCore;
using Oqtane.Models;
@ -21,6 +21,8 @@ namespace Oqtane.Repository
public virtual DbSet<Folder> Folder { get; set; }
public virtual DbSet<File> File { get; set; }
public virtual DbSet<Language> Languages { get; set; }
public TenantDBContext(ITenantResolver tenantResolver, IHttpContextAccessor accessor) : base(tenantResolver, accessor)
{
// DBContextBase handles multi-tenant database connections

View File

@ -0,0 +1,16 @@
using System.Collections.Generic;
using Oqtane.Models;
namespace Oqtane.Repository
{
public interface ILanguageRepository
{
IEnumerable<Language> GetLanguages(int siteId);
Language AddLanguage(Language language);
Language GetLanguage(int languageId);
void DeleteLanguage(int languageId);
}
}

View File

@ -0,0 +1,35 @@
using System.Collections.Generic;
using System.Linq;
using Oqtane.Models;
namespace Oqtane.Repository
{
public class LanguageRepository : ILanguageRepository
{
private TenantDBContext _db;
public LanguageRepository(TenantDBContext context)
{
_db = context;
}
public IEnumerable<Language> GetLanguages(int siteId) => _db.Languages.Where(l => l.SiteId == siteId);
public Language AddLanguage(Language language)
{
_db.Languages.Add(language);
_db.SaveChanges();
return language;
}
public Language GetLanguage(int languageId) => _db.Languages.Find(languageId);
public void DeleteLanguage(int languageId)
{
var language = _db.Languages.Find(languageId);
_db.Languages.Remove(language);
_db.SaveChanges();
}
}
}