summaryrefslogtreecommitdiffstats
path: root/samples/OAuthServiceProvider/Code/OAuthToken.cs
blob: 182a3e37f58da52e004e90f12dd211db55072f72 (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
54
55
56
57
58
59
60
61
62
63
64
65
66
//-----------------------------------------------------------------------
// <copyright file="OAuthToken.cs" company="Andrew Arnott">
//     Copyright (c) Andrew Arnott. All rights reserved.
// </copyright>
//-----------------------------------------------------------------------

namespace OAuthServiceProvider.Code {
	using System;
	using System.Collections.Generic;
	using System.Linq;
	using System.Web;
	using DotNetOpenAuth.OAuth.ChannelElements;

	public partial class OAuthToken : IServiceProviderRequestToken, IServiceProviderAccessToken {
		#region IServiceProviderRequestToken Members

		string IServiceProviderRequestToken.Token {
			get { return this.Token; }
		}

		string IServiceProviderRequestToken.ConsumerKey {
			get { return this.OAuthConsumer.ConsumerKey; }
		}

		DateTime IServiceProviderRequestToken.CreatedOn {
			get { return this.IssueDate; }
		}

		Uri IServiceProviderRequestToken.Callback {
			get { return string.IsNullOrEmpty(this.RequestTokenCallback) ? null : new Uri(this.RequestTokenCallback); }
			set { this.RequestTokenCallback = value.AbsoluteUri; }
		}

		string IServiceProviderRequestToken.VerificationCode {
			get { return this.RequestTokenVerifier; }
			set { this.RequestTokenVerifier = value; }
		}

		Version IServiceProviderRequestToken.ConsumerVersion {
			get { return new Version(this.ConsumerVersion); }
			set { this.ConsumerVersion = value.ToString(); }
		}

		#endregion

		#region IServiceProviderAccessToken Members

		string IServiceProviderAccessToken.Token {
			get { return this.Token; }
		}

		DateTime? IServiceProviderAccessToken.ExpirationDate {
			get { return null; }
		}

		string IServiceProviderAccessToken.Username {
			get { return this.User.OpenIDClaimedIdentifier; }
		}

		string[] IServiceProviderAccessToken.Roles {
			get { return this.Scope.Split('|'); }
		}

		#endregion
	}
}