diff options
| author | ivarlovlie <git@ivarlovlie.no> | 2022-11-27 08:56:52 +0100 |
|---|---|---|
| committer | ivarlovlie <git@ivarlovlie.no> | 2022-11-27 08:56:52 +0100 |
| commit | 804e984156230dac2f3c81f9fe0d52682245ee91 (patch) | |
| tree | f166c19b5f389d8c4e9cd7f74d63039943b11931 /code/api | |
| parent | ff2fa0b21d327c1a1d76fa4ae8be8516b6d6171b (diff) | |
| download | greatoffice-804e984156230dac2f3c81f9fe0d52682245ee91.tar.xz greatoffice-804e984156230dac2f3c81f9fe0d52682245ee91.zip | |
refactor: Saneify order of validation checks
--Weird
_database.Users.Any() gave me a NRE on the source argument, which is DbSet<User>, but does not complain with FirstOrDefault...
Diffstat (limited to 'code/api')
| -rw-r--r-- | code/api/src/Endpoints/Internal/Account/CreateAccountRoute.cs | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/code/api/src/Endpoints/Internal/Account/CreateAccountRoute.cs b/code/api/src/Endpoints/Internal/Account/CreateAccountRoute.cs index 81c507d..44b8376 100644 --- a/code/api/src/Endpoints/Internal/Account/CreateAccountRoute.cs +++ b/code/api/src/Endpoints/Internal/Account/CreateAccountRoute.cs @@ -24,19 +24,17 @@ public class CreateAccountRoute : RouteBaseAsync.WithRequest<CreateAccountRoute. [HttpPost("~/_/account/create")] public override async Task<ActionResult> HandleAsync(Payload request, CancellationToken cancellationToken = default) { var problem = new KnownProblemModel(); - if (request.Username.IsValidEmailAddress() == false) { - problem.AddError("username", _localizer["{0} does not look like a valid email", request.Username]); + var username = request.Username.Trim(); + if (username.IsValidEmailAddress() == false) { + problem.AddError("username", _localizer["{0} does not look like a valid email", username]); + } else if (_database.Users.FirstOrDefault(c => c.Username == username) != default) { + problem.AddError("username", _localizer["There is already a user registered with username: {0}", username]); } if (request.Password.Length < 6) { problem.AddError("password", _localizer["The password requires 6 or more characters."]); } - var username = request.Username.Trim(); - if (problem.Errors.All(p => p.Key != "username") && _database.Users.Any(c => c.Username == username)) { - problem.AddError("username", _localizer["There is already a user registered with username: {0}", username]); - } - if (problem.Errors.Any()) { problem.Title = _localizer["Invalid form"]; problem.Subtitle = _localizer["One or more fields is invalid"]; |
