261 lines
No EOL
9.2 KiB
C#
261 lines
No EOL
9.2 KiB
C#
using Microsoft.AspNetCore.Authentication;
|
|
using Microsoft.AspNetCore.Authentication.Cookies;
|
|
using Microsoft.AspNetCore.DataProtection;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using System.Text.RegularExpressions;
|
|
using Lieb.Data;
|
|
using Lieb.Models.GuildWars2.Raid;
|
|
using Lieb.Models.GuildWars2;
|
|
using Lieb.Models;
|
|
using SharedClasses.SharedModels;
|
|
|
|
namespace Lieb.Controllers
|
|
{
|
|
[ApiController]
|
|
[Route("[controller]")]
|
|
public class DiscordBotController : ControllerBase
|
|
{
|
|
RaidService _raidService;
|
|
UserService _userService;
|
|
GuildWars2AccountService _gw2AccountService;
|
|
DiscordService _discordService;
|
|
|
|
public DiscordBotController(RaidService raidService, UserService userService, GuildWars2AccountService gw2AccountService, DiscordService discordService)
|
|
{
|
|
_raidService = raidService;
|
|
_userService = userService;
|
|
_gw2AccountService = gw2AccountService;
|
|
_discordService = discordService;
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{userId}")]
|
|
public ActionResult<bool> DoesUserExist(ulong userId)
|
|
{
|
|
LiebUser user = _userService.GetLiebUserGW2AccountOnly(userId);
|
|
return user != null && user.GuildWars2Accounts.Count() > 0;
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{raidId}/{userId}/{ignoreRole}")]
|
|
public ActionResult IsSignUpAllowed(int raidId, ulong userId, bool ignoreRole)
|
|
{
|
|
if(!_raidService.IsRaidSignUpAllowed(userId, raidId, out string errorMessage, ignoreRole))
|
|
{
|
|
return Problem(errorMessage);
|
|
}
|
|
return Ok();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{raidId}/{userId}")]
|
|
public bool IsUserSignedUp(int raidId, ulong userId)
|
|
{
|
|
Raid raid = _raidService.GetRaid(raidId);
|
|
return raid.SignUps.Where(s => s.LiebUserId == userId && s.SignUpType != SignUpType.Flex && s.SignUpType != SignUpType.SignedOff).Any();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{raidId}")]
|
|
public ActionResult IsExternalSignUpAllowed(int raidId)
|
|
{
|
|
if(!_raidService.IsExternalSignUpAllowed(raidId, out string errorMessage))
|
|
{
|
|
return Problem(errorMessage);
|
|
}
|
|
return Ok();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{raidId}/{userId}")]
|
|
public ActionResult<List<ApiRole>> GetRoles(int raidId, ulong userId)
|
|
{
|
|
Raid raid = _raidService.GetRaid(raidId);
|
|
|
|
List<ApiRole> apiRoles = new List<ApiRole>();
|
|
foreach(RaidRole role in raid.Roles)
|
|
{
|
|
apiRoles.Add(new ApiRole(){
|
|
Name = role.Name,
|
|
Description = role.Description,
|
|
IsSignUpAllowed = _raidService.IsRoleSignUpAllowed(userId, role.RaidRoleId, SignUpType.SignedUp),
|
|
roleId = role.RaidRoleId
|
|
});
|
|
}
|
|
return apiRoles;
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<bool> SignUp(ApiSignUp signUp)
|
|
{
|
|
if(signUp.userId != 0)
|
|
{
|
|
int accountId = _userService.GetSignUpAccount(signUp.userId, signUp.raidId, signUp.gw2AccountId);
|
|
return await _raidService.SignUp(signUp.raidId, signUp.userId, accountId, signUp.roleId, SignUpType.SignedUp, signUp.signedUpByUserId);
|
|
}
|
|
else
|
|
{
|
|
return await _raidService.SignUpExternalUser(signUp.raidId, signUp.userName, signUp.roleId, SignUpType.SignedUp, signUp.signedUpByUserId);
|
|
}
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<bool> SignUpMaybe(ApiSignUp signUp)
|
|
{
|
|
if(signUp.userId != 0)
|
|
{
|
|
int accountId = _userService.GetSignUpAccount(signUp.userId, signUp.raidId, signUp.gw2AccountId);
|
|
return await _raidService.SignUp(signUp.raidId, signUp.userId, accountId, signUp.roleId, SignUpType.Maybe, signUp.signedUpByUserId);
|
|
}
|
|
else
|
|
{
|
|
return await _raidService.SignUpExternalUser(signUp.raidId, signUp.userName, signUp.roleId, SignUpType.Maybe, signUp.signedUpByUserId);
|
|
}
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<bool> SignUpBackup(ApiSignUp signUp)
|
|
{
|
|
if(signUp.userId != 0)
|
|
{
|
|
int accountId = _userService.GetSignUpAccount(signUp.userId, signUp.raidId, signUp.gw2AccountId);
|
|
return await _raidService.SignUp(signUp.raidId, signUp.userId, accountId, signUp.roleId, SignUpType.Backup, signUp.signedUpByUserId);
|
|
}
|
|
else
|
|
{
|
|
return await _raidService.SignUpExternalUser(signUp.raidId, signUp.userName, signUp.roleId, SignUpType.Backup, signUp.signedUpByUserId);
|
|
}
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<bool> SignUpFlex(ApiSignUp signUp)
|
|
{
|
|
if(signUp.userId != 0)
|
|
{
|
|
int accountId = _userService.GetSignUpAccount(signUp.userId, signUp.raidId, signUp.gw2AccountId);
|
|
return await _raidService.SignUp(signUp.raidId, signUp.userId, accountId, signUp.roleId, SignUpType.Flex, signUp.signedUpByUserId);
|
|
}
|
|
else
|
|
{
|
|
return await _raidService.SignUpExternalUser(signUp.raidId, signUp.userName, signUp.roleId, SignUpType.Flex, signUp.signedUpByUserId);
|
|
}
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<bool> SignOff(ApiSignUp signUp)
|
|
{
|
|
if(signUp.userId != 0)
|
|
{
|
|
await _raidService.SignOff(signUp.raidId, signUp.userId, signUp.signedUpByUserId);
|
|
}
|
|
else
|
|
{
|
|
await _raidService.SignOffExternalUser(signUp.raidId, signUp.userName, signUp.signedUpByUserId);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("[action]")]
|
|
public async Task<ActionResult> CreateAccount(ApiRaid.Role.User user)
|
|
{
|
|
if(!Regex.IsMatch(user.AccountName, Constants.GW2_ACCOUNT_REGEX))
|
|
{
|
|
return Problem("Invalid Account Name");
|
|
}
|
|
|
|
GuildWars2Account gw2Account = new GuildWars2Account()
|
|
{
|
|
AccountName = user.AccountName
|
|
};
|
|
if(_userService.GetLiebUserGW2AccountOnly(user.UserId) == null)
|
|
{
|
|
await _userService.CreateUser(user.UserId, user.UserName);
|
|
}
|
|
await _gw2AccountService.AddOrEditAccount(gw2Account, user.UserId);
|
|
return Ok();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{raidId}")]
|
|
public ActionResult<ApiRaid> GetRaid(int raidId)
|
|
{
|
|
Raid raid = _raidService.GetRaid(raidId);
|
|
|
|
return DiscordService.ConvertRaid(raid);
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]")]
|
|
public List<ulong> GetUserRenameServers()
|
|
{
|
|
return _discordService.GetUserRenameServers();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{userId}")]
|
|
public ActionResult<ApiRaid.Role.User> GetUser(ulong userId)
|
|
{
|
|
LiebUser user = _userService.GetLiebUser(userId);
|
|
|
|
if(user != null)
|
|
{
|
|
return Ok(new ApiRaid.Role.User(){
|
|
UserId = user.Id,
|
|
UserName = user.Name,
|
|
AccountName = user.GuildWars2Accounts.FirstOrDefault(a => a.GuildWars2AccountId == user.MainGW2Account, new GuildWars2Account()).AccountName
|
|
});
|
|
}
|
|
|
|
return Problem("user not found");
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{userId}/{raidId}")]
|
|
public ActionResult<List<ApiGuildWars2Account>> GetSignUpAccounts(ulong userId, int raidId)
|
|
{
|
|
List<GuildWars2Account> accounts = _userService.GetDiscordSignUpAccounts(userId, raidId);
|
|
List<ApiGuildWars2Account> apiAccounts = new List<ApiGuildWars2Account>();
|
|
|
|
foreach(GuildWars2Account account in accounts)
|
|
{
|
|
apiAccounts.Add(new ApiGuildWars2Account(){
|
|
AccountName = account.AccountName,
|
|
GuildWars2AccountId = account.GuildWars2AccountId
|
|
});
|
|
}
|
|
return Ok(apiAccounts);
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{userId}/{command}")]
|
|
public ActionResult IsSlashCommandAllowed(ulong userId, string command)
|
|
{
|
|
switch(command)
|
|
{
|
|
case SharedConstants.SlashCommands.RAID:
|
|
if(!_raidService.IsRaidSlashCommandAllowed(userId, out string errorMessage))
|
|
{
|
|
return Problem(errorMessage);
|
|
}
|
|
break;
|
|
default:
|
|
return Problem("command not found on server");
|
|
break;
|
|
}
|
|
return Ok();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Route("[action]/{userId}")]
|
|
public async Task<ActionResult> ReminderOptOut(ulong userId)
|
|
{
|
|
return Ok(await _userService.ReminderOptOut(userId));
|
|
}
|
|
}
|
|
} |