forked from CrustyJew/RedditSharp-DEPRECATED-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBotWebAgent.cs
More file actions
70 lines (63 loc) · 2.43 KB
/
BotWebAgent.cs
File metadata and controls
70 lines (63 loc) · 2.43 KB
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
67
68
69
70
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Text;
using System.Threading.Tasks;
namespace RedditSharp
{
public class BotWebAgent : WebAgent
{
//private so it doesn't leak app secret to other code
private AuthProvider TokenProvider;
private string Username;
private string Password;
/// <summary>
/// Date and time the token expires.
/// </summary>
public DateTimeOffset TokenValidTo { get; set; }
/// <summary>
/// A web agent using reddit's OAuth interface.
/// </summary>
/// <param name="username">The username.</param>
/// <param name="password">The user's password.</param>
/// <param name="clientId">Granted by reddit as part of app.</param>
/// <param name="clientSecret">Granted by reddit as part of app.</param>
/// <param name="redirectUri">Selected as part of app. Reddit will send users back here.</param>
public BotWebAgent(string username, string password, string clientID, string clientSecret, string redirectURI)
{
Username = username;
Password = password;
EnableRateLimit = true;
RateLimit = RateLimitMode.Burst;
RootDomain = "oauth.reddit.com";
TokenProvider = new AuthProvider(clientID, clientSecret, redirectURI, this);
GetNewToken();
}
/// <inheritdoc/>
public override HttpWebRequest CreateRequest(string url, string method)
{
//add 5 minutes for clock skew to ensure requests succeed
if (url != AuthProvider.AccessUrl && DateTimeOffset.UtcNow.AddMinutes(5) > TokenValidTo)
{
GetNewToken();
}
return base.CreateRequest(url, method);
}
/// <inheritdoc/>
protected override HttpWebRequest CreateRequest(Uri uri, string method)
{
//add 5 minutes for clock skew to ensure requests succeed
if (uri.ToString() != AuthProvider.AccessUrl && DateTimeOffset.UtcNow.AddMinutes(5) > TokenValidTo)
{
GetNewToken();
}
return base.CreateRequest(uri, method);
}
private void GetNewToken()
{
AccessToken = TokenProvider.GetOAuthToken(Username, Password);
TokenValidTo = DateTimeOffset.UtcNow.AddHours(1);
}
}
}