summaryrefslogtreecommitdiff
path: root/Logics/RefreshTokenLogic.cs
blob: 3493f476ba767543072a76ba9294a0f8291d82b4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
using Microsoft.AspNetCore.Identity;
using BackendPIA.Services;
using BackendPIA.Models;
using BackendPIA.Forms;

namespace BackendPIA.Logics {
    public class RefreshTokenLogic : BaseUserAccountLogic {
        private readonly AuthenticationToken _form;

        public RefreshTokenLogic(ITokenGenerator token_generator, UserManager<UserAccount> manager, AuthenticationToken form) : base(token_generator, manager) {
            _form = form;
        }

        public async Task<bool> Call() {
            var email = _token_generator.GetPrincipalFromToken(_form.Token);

            if(email == null)
                return false;
            // Checks.
            var user = await _manager.FindByEmailAsync(email);

            if(user == null)
                return false;

            if(user.SessionTokenExpiryTime == null || user.SessionTokenExpiryTime < DateTime.UtcNow 
               || user.SessionToken == null || user.SessionToken != _form.RefreshToken) {
                user.SessionToken = null;
                user.SessionTokenExpiryTime = null;
                user.CurrentToken = null;
                _manager.UpdateAsync(user);

                return false;
            }
            
            await SetAuthenticationToken(user);
            _token.RefreshToken = user.SessionToken;

            return true;
        }
    }
}