 14575a4a6b
			
		
	
	14575a4a6b
	
	
	
		
			
			* add jwt expiry * start of 0.9 api impl * some stuff idk * some more impl * some cleanup * remove grouppair, add configuration, rework some pair drawing stuff * do some stuff * rework some ui * I don't even know anymore * add cancellationtoken * token bla * ui fixes etc * probably individual adding/removing now working fully as expected * add working report popup * I guess it's more syncshell shit or so * popup shit idk * work out most of the syncshell bullshit I guess * delete some old crap * are we actually getting closer to the end * update pair info stuff * more fixes/adjustments, idk * refactor some things * some rework * some more cleanup * cleanup * make menu buttons w i d e * better icon text buttons * add all syncshell folder and ordering fixes --------- Co-authored-by: rootdarkarchon <root.darkarchon@outlook.com>
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using MareSynchronos.API.Dto.Group;
 | |
| using MareSynchronos.WebAPI.SignalR.Utils;
 | |
| using Microsoft.AspNetCore.SignalR.Client;
 | |
| 
 | |
| namespace MareSynchronos.WebAPI;
 | |
| 
 | |
| public partial class ApiController
 | |
| {
 | |
|     public async Task GroupBanUser(GroupPairDto dto, string reason)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupBanUser), dto, reason).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupChangeGroupPermissionState(GroupPermissionDto dto)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupChangeGroupPermissionState), dto).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupChangeIndividualPermissionState(GroupPairUserPermissionDto dto)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupChangeIndividualPermissionState), dto).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupChangeOwnership(GroupPairDto groupPair)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupChangeOwnership), groupPair).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<bool> GroupChangePassword(GroupPasswordDto groupPassword)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<bool>(nameof(GroupChangePassword), groupPassword).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupClear(GroupDto group)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupClear), group).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<GroupJoinDto> GroupCreate()
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<GroupJoinDto>(nameof(GroupCreate)).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<List<string>> GroupCreateTempInvite(GroupDto group, int amount)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<List<string>>(nameof(GroupCreateTempInvite), group, amount).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupDelete(GroupDto group)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupDelete), group).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<List<BannedGroupUserDto>> GroupGetBannedUsers(GroupDto group)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<List<BannedGroupUserDto>>(nameof(GroupGetBannedUsers), group).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<GroupJoinInfoDto> GroupJoin(GroupPasswordDto passwordedGroup)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<GroupJoinInfoDto>(nameof(GroupJoin), passwordedGroup).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<bool> GroupJoinFinalize(GroupJoinDto passwordedGroup)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<bool>(nameof(GroupJoinFinalize), passwordedGroup).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupLeave(GroupDto group)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupLeave), group).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupRemoveUser(GroupPairDto groupPair)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupRemoveUser), groupPair).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupSetUserInfo(GroupPairUserInfoDto groupPair)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupSetUserInfo), groupPair).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task<List<GroupFullInfoDto>> GroupsGetAll()
 | |
|     {
 | |
|         CheckConnection();
 | |
|         return await _mareHub!.InvokeAsync<List<GroupFullInfoDto>>(nameof(GroupsGetAll)).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     public async Task GroupUnbanUser(GroupPairDto groupPair)
 | |
|     {
 | |
|         CheckConnection();
 | |
|         await _mareHub!.SendAsync(nameof(GroupUnbanUser), groupPair).ConfigureAwait(false);
 | |
|     }
 | |
| 
 | |
|     private void CheckConnection()
 | |
|     {
 | |
|         if (ServerState is not (ServerState.Connected or ServerState.Connecting or ServerState.Reconnecting)) throw new InvalidDataException("Not connected");
 | |
|     }
 | |
| } |