refactoring of site groups
This commit is contained in:
@@ -1,94 +0,0 @@
|
||||
using Oqtane.Models;
|
||||
using System.Threading.Tasks;
|
||||
using System.Net.Http;
|
||||
using System.Collections.Generic;
|
||||
using Oqtane.Documentation;
|
||||
using Oqtane.Shared;
|
||||
using System.Linq;
|
||||
|
||||
namespace Oqtane.Services
|
||||
{
|
||||
/// <summary>
|
||||
/// Service to manage <see cref="Role"/>s on a <see cref="Site"/>
|
||||
/// </summary>
|
||||
public interface ISiteGroupDefinitionService
|
||||
{
|
||||
/// <summary>
|
||||
/// Get all <see cref="SiteGroupDefinition"/>s
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
Task<List<SiteGroupDefinition>> GetSiteGroupDefinitionsAsync();
|
||||
|
||||
/// <summary>
|
||||
/// Get all <see cref="SiteGroupDefinition"/>s
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
Task<List<SiteGroupDefinition>> GetSiteGroupDefinitionsAsync(int primarySiteId);
|
||||
|
||||
/// <summary>
|
||||
/// Get one specific <see cref="SiteGroupDefinition"/>
|
||||
/// </summary>
|
||||
/// <param name="siteGroupDefinitionId">ID-reference of a <see cref="SiteGroupDefinition"/></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupDefinition> GetSiteGroupDefinitionAsync(int siteGroupDefinitionId);
|
||||
|
||||
/// <summary>
|
||||
/// Add / save a new <see cref="SiteGroupDefinition"/> to the database.
|
||||
/// </summary>
|
||||
/// <param name="group"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupDefinition> AddSiteGroupDefinitionAsync(SiteGroupDefinition siteGroupDefinition);
|
||||
|
||||
/// <summary>
|
||||
/// Update a <see cref="SiteGroupDefinition"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="group"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupDefinition> UpdateSiteGroupDefinitionAsync(SiteGroupDefinition siteGroupDefinition);
|
||||
|
||||
/// <summary>
|
||||
/// Delete a <see cref="SiteGroupDefinition"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroupDefinitionId">ID-reference of a <see cref="SiteGroupDefinition"/></param>
|
||||
/// <returns></returns>
|
||||
Task DeleteSiteGroupDefinitionAsync(int siteGroupDefinitionId);
|
||||
}
|
||||
|
||||
[PrivateApi("Don't show in the documentation, as everything should use the Interface")]
|
||||
public class SiteGroupDefinitionService : ServiceBase, ISiteGroupDefinitionService
|
||||
{
|
||||
public SiteGroupDefinitionService(HttpClient http, SiteState siteState) : base(http, siteState) { }
|
||||
|
||||
private string Apiurl => CreateApiUrl("SiteGroupDefinition");
|
||||
|
||||
public async Task<List<SiteGroupDefinition>> GetSiteGroupDefinitionsAsync()
|
||||
{
|
||||
return await GetSiteGroupDefinitionsAsync(-1);
|
||||
}
|
||||
|
||||
public async Task<List<SiteGroupDefinition>> GetSiteGroupDefinitionsAsync(int primarySiteId)
|
||||
{
|
||||
return await GetJsonAsync<List<SiteGroupDefinition>>($"{Apiurl}?siteid={primarySiteId}", Enumerable.Empty<SiteGroupDefinition>().ToList());
|
||||
}
|
||||
|
||||
public async Task<SiteGroupDefinition> GetSiteGroupDefinitionAsync(int siteGroupDefinitionId)
|
||||
{
|
||||
return await GetJsonAsync<SiteGroupDefinition>($"{Apiurl}/{siteGroupDefinitionId}");
|
||||
}
|
||||
|
||||
public async Task<SiteGroupDefinition> AddSiteGroupDefinitionAsync(SiteGroupDefinition siteGroupDefinition)
|
||||
{
|
||||
return await PostJsonAsync<SiteGroupDefinition>(Apiurl, siteGroupDefinition);
|
||||
}
|
||||
|
||||
public async Task<SiteGroupDefinition> UpdateSiteGroupDefinitionAsync(SiteGroupDefinition siteGroupDefinition)
|
||||
{
|
||||
return await PutJsonAsync<SiteGroupDefinition>($"{Apiurl}/{siteGroupDefinition.SiteGroupDefinitionId}", siteGroupDefinition);
|
||||
}
|
||||
|
||||
public async Task DeleteSiteGroupDefinitionAsync(int siteGroupDefinitionId)
|
||||
{
|
||||
await DeleteAsync($"{Apiurl}/{siteGroupDefinitionId}");
|
||||
}
|
||||
}
|
||||
}
|
||||
104
Oqtane.Client/Services/SiteGroupMemberService.cs
Normal file
104
Oqtane.Client/Services/SiteGroupMemberService.cs
Normal file
@@ -0,0 +1,104 @@
|
||||
using Oqtane.Models;
|
||||
using System.Threading.Tasks;
|
||||
using System.Net.Http;
|
||||
using System.Collections.Generic;
|
||||
using Oqtane.Documentation;
|
||||
using Oqtane.Shared;
|
||||
using System.Linq;
|
||||
|
||||
namespace Oqtane.Services
|
||||
{
|
||||
/// <summary>
|
||||
/// Service to manage <see cref="Role"/>s on a <see cref="Site"/>
|
||||
/// </summary>
|
||||
public interface ISiteGroupMemberService
|
||||
{
|
||||
/// <summary>
|
||||
/// Get all <see cref="SiteGroupMember"/>s
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
Task<List<SiteGroupMember>> GetSiteGroupMembersAsync(int siteId, int siteGroupId);
|
||||
|
||||
/// <summary>
|
||||
/// Get one specific <see cref="SiteGroupMember"/>
|
||||
/// </summary>
|
||||
/// <param name="siteGroupMemberId">ID-reference of a <see cref="SiteGroupMember"/></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupMember> GetSiteGroupMemberAsync(int siteGroupMemberId);
|
||||
|
||||
/// <summary>
|
||||
/// Get one specific <see cref="SiteGroupMember"/>
|
||||
/// </summary>
|
||||
/// <param name="siteId">ID-reference of a <see cref="Site"/></param>
|
||||
/// <param name="siteGroupId">ID-reference of a <see cref="SiteGroup"/></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupMember> GetSiteGroupMemberAsync(int siteId, int siteGroupId);
|
||||
|
||||
/// <summary>
|
||||
/// Add / save a new <see cref="SiteGroupMember"/> to the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroupMember"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupMember> AddSiteGroupMemberAsync(SiteGroupMember siteGroupMember);
|
||||
|
||||
/// <summary>
|
||||
/// Update a <see cref="SiteGroupMember"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroupMember"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroupMember> UpdateSiteGroupMemberAsync(SiteGroupMember siteGroupMember);
|
||||
|
||||
/// <summary>
|
||||
/// Delete a <see cref="SiteGroupMember"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroupMemberId">ID-reference of a <see cref="SiteGroupMember"/></param>
|
||||
/// <returns></returns>
|
||||
Task DeleteSiteGroupMemberAsync(int siteGroupMemberId);
|
||||
}
|
||||
|
||||
[PrivateApi("Don't show in the documentation, as everything should use the Interface")]
|
||||
public class SiteGroupMemberService : ServiceBase, ISiteGroupMemberService
|
||||
{
|
||||
public SiteGroupMemberService(HttpClient http, SiteState siteState) : base(http, siteState) { }
|
||||
|
||||
private string Apiurl => CreateApiUrl("SiteGroupMember");
|
||||
|
||||
public async Task<List<SiteGroupMember>> GetSiteGroupMembersAsync(int siteId, int siteGroupId)
|
||||
{
|
||||
return await GetJsonAsync<List<SiteGroupMember>>($"{Apiurl}?siteid={siteId}&groupid={siteGroupId}", Enumerable.Empty<SiteGroupMember>().ToList());
|
||||
}
|
||||
|
||||
public async Task<SiteGroupMember> GetSiteGroupMemberAsync(int siteGroupMemberId)
|
||||
{
|
||||
return await GetJsonAsync<SiteGroupMember>($"{Apiurl}/{siteGroupMemberId}");
|
||||
}
|
||||
|
||||
public async Task<SiteGroupMember> GetSiteGroupMemberAsync(int siteId, int siteGroupId)
|
||||
{
|
||||
var siteGroupMembers = await GetSiteGroupMembersAsync(siteId, siteGroupId);
|
||||
if (siteGroupMembers != null && siteGroupMembers.Count > 0)
|
||||
{
|
||||
return siteGroupMembers[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public async Task<SiteGroupMember> AddSiteGroupMemberAsync(SiteGroupMember siteGroupMember)
|
||||
{
|
||||
return await PostJsonAsync<SiteGroupMember>(Apiurl, siteGroupMember);
|
||||
}
|
||||
|
||||
public async Task<SiteGroupMember> UpdateSiteGroupMemberAsync(SiteGroupMember siteGroupMember)
|
||||
{
|
||||
return await PutJsonAsync<SiteGroupMember>($"{Apiurl}/{siteGroupMember.SiteGroupId}", siteGroupMember);
|
||||
}
|
||||
|
||||
public async Task DeleteSiteGroupMemberAsync(int siteGroupMemberId)
|
||||
{
|
||||
await DeleteAsync($"{Apiurl}/{siteGroupMemberId}");
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -17,43 +17,41 @@ namespace Oqtane.Services
|
||||
/// Get all <see cref="SiteGroup"/>s
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
Task<List<SiteGroup>> GetSiteGroupsAsync(int siteId, int siteGroupDefinitionId);
|
||||
Task<List<SiteGroup>> GetSiteGroupsAsync();
|
||||
|
||||
/// <summary>
|
||||
/// Get all <see cref="SiteGroup"/>s
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
Task<List<SiteGroup>> GetSiteGroupsAsync(int primarySiteId);
|
||||
|
||||
/// <summary>
|
||||
/// Get one specific <see cref="SiteGroup"/>
|
||||
/// </summary>
|
||||
/// <param name="siteSiteGroupDefinitionId">ID-reference of a <see cref="SiteGroup"/></param>
|
||||
/// <param name="siteGroupId">ID-reference of a <see cref="SiteGroup"/></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroup> GetSiteGroupAsync(int siteSiteGroupDefinitionId);
|
||||
|
||||
/// <summary>
|
||||
/// Get one specific <see cref="SiteGroup"/>
|
||||
/// </summary>
|
||||
/// <param name="siteId">ID-reference of a <see cref="Site"/></param>
|
||||
/// <param name="siteGroupDefinitionId">ID-reference of a <see cref="SiteGroupDefinition"/></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroup> GetSiteGroupAsync(int siteId, int siteGroupDefinitionId);
|
||||
Task<SiteGroup> GetSiteGroupAsync(int siteGroupId);
|
||||
|
||||
/// <summary>
|
||||
/// Add / save a new <see cref="SiteGroup"/> to the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroup"></param>
|
||||
/// <param name="group"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroup> AddSiteGroupAsync(SiteGroup siteGroup);
|
||||
|
||||
/// <summary>
|
||||
/// Update a <see cref="SiteGroup"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="siteGroup"></param>
|
||||
/// <param name="group"></param>
|
||||
/// <returns></returns>
|
||||
Task<SiteGroup> UpdateSiteGroupAsync(SiteGroup siteGroup);
|
||||
|
||||
/// <summary>
|
||||
/// Delete a <see cref="SiteGroup"/> in the database.
|
||||
/// </summary>
|
||||
/// <param name="siteSiteGroupDefinitionId">ID-reference of a <see cref="SiteGroup"/></param>
|
||||
/// <param name="siteGroupId">ID-reference of a <see cref="SiteGroup"/></param>
|
||||
/// <returns></returns>
|
||||
Task DeleteSiteGroupAsync(int siteSiteGroupDefinitionId);
|
||||
Task DeleteSiteGroupAsync(int siteGroupId);
|
||||
}
|
||||
|
||||
[PrivateApi("Don't show in the documentation, as everything should use the Interface")]
|
||||
@@ -63,27 +61,19 @@ namespace Oqtane.Services
|
||||
|
||||
private string Apiurl => CreateApiUrl("SiteGroup");
|
||||
|
||||
public async Task<List<SiteGroup>> GetSiteGroupsAsync(int siteId, int siteGroupDefinitionId)
|
||||
public async Task<List<SiteGroup>> GetSiteGroupsAsync()
|
||||
{
|
||||
return await GetJsonAsync<List<SiteGroup>>($"{Apiurl}?siteid={siteId}&groupid={siteGroupDefinitionId}", Enumerable.Empty<SiteGroup>().ToList());
|
||||
return await GetSiteGroupsAsync(-1);
|
||||
}
|
||||
|
||||
public async Task<SiteGroup> GetSiteGroupAsync(int siteSiteGroupDefinitionId)
|
||||
public async Task<List<SiteGroup>> GetSiteGroupsAsync(int primarySiteId)
|
||||
{
|
||||
return await GetJsonAsync<SiteGroup>($"{Apiurl}/{siteSiteGroupDefinitionId}");
|
||||
return await GetJsonAsync<List<SiteGroup>>($"{Apiurl}?siteid={primarySiteId}", Enumerable.Empty<SiteGroup>().ToList());
|
||||
}
|
||||
|
||||
public async Task<SiteGroup> GetSiteGroupAsync(int siteId, int siteGroupDefinitionId)
|
||||
public async Task<SiteGroup> GetSiteGroupAsync(int siteGroupId)
|
||||
{
|
||||
var siteGroups = await GetSiteGroupsAsync(siteId, siteGroupDefinitionId);
|
||||
if (siteGroups != null && siteGroups.Count > 0)
|
||||
{
|
||||
return siteGroups[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
return null;
|
||||
}
|
||||
return await GetJsonAsync<SiteGroup>($"{Apiurl}/{siteGroupId}");
|
||||
}
|
||||
|
||||
public async Task<SiteGroup> AddSiteGroupAsync(SiteGroup siteGroup)
|
||||
@@ -93,12 +83,12 @@ namespace Oqtane.Services
|
||||
|
||||
public async Task<SiteGroup> UpdateSiteGroupAsync(SiteGroup siteGroup)
|
||||
{
|
||||
return await PutJsonAsync<SiteGroup>($"{Apiurl}/{siteGroup.SiteGroupDefinitionId}", siteGroup);
|
||||
return await PutJsonAsync<SiteGroup>($"{Apiurl}/{siteGroup.SiteGroupId}", siteGroup);
|
||||
}
|
||||
|
||||
public async Task DeleteSiteGroupAsync(int siteSiteGroupDefinitionId)
|
||||
public async Task DeleteSiteGroupAsync(int siteGroupId)
|
||||
{
|
||||
await DeleteAsync($"{Apiurl}/{siteSiteGroupDefinitionId}");
|
||||
await DeleteAsync($"{Apiurl}/{siteGroupId}");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user