aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Web/Tango.MachineService/Security/TokenManager.cs
blob: abd6156860aa9f494ffd9eea7ca60156696f85d9 (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
42
43
44
45
46
47
48
49
50
51
52
53
using Microsoft.WindowsAzure.Storage;
using Microsoft.WindowsAzure.Storage.Table;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Authentication;
using System.Web;

namespace Tango.MachineService.Security
{
    public class TokenManager
    {
        private CloudTable GetTokensTable()
        {
            CloudStorageAccount storageAccount = CloudStorageAccount.Parse(MachineServiceConfig.STORAGE_ACCOUNT);
            var client = storageAccount.CreateCloudTableClient();
            var table = client.GetTableReference("Tokens");
            table.CreateIfNotExists();
            return table;
        }

        public void AddToken(String token, String identity, DateTime expiration)
        {
            var table = GetTokensTable();

            table.Execute(TableOperation.InsertOrReplace(new TokenEntity()
            {
                PartitionKey = MachineServiceConfig.REFRESH_TOKENS_TABLE_PARTITION,
                RowKey = Guid.NewGuid().ToString(),
                AccessToken = token,
                Identity = identity,
                Expiration = expiration,
            }));
        }

        public void UpdateToken(String oldToken, String newToken, DateTime expiration)
        {
            var table = GetTokensTable();

            var existingToken = table.CreateQuery<TokenEntity>().AsQueryable().Where(x => x.AccessToken == oldToken).ToList().FirstOrDefault();

            if (existingToken == null)
            {
                throw new AuthenticationException("Invalid token.");
            }

            existingToken.AccessToken = newToken;
            existingToken.Expiration = expiration;

            table.Execute(TableOperation.InsertOrMerge(existingToken));
        }
    }
}