summaryrefslogtreecommitdiffstats
path: root/src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs
diff options
context:
space:
mode:
authorAndrew Arnott <andrewarnott@gmail.com>2008-09-25 08:31:40 -0700
committerAndrew <andrewarnott@gmail.com>2008-09-25 08:31:40 -0700
commita9fb696c40441e06ef817d7e28bae74c6a6cb6e4 (patch)
treee78f45395a2cee9592bceed86f3cbf2aba7c9022 /src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs
parente99268dcde5f942a2577a2d4d271febf991b6fa1 (diff)
downloadDotNetOpenAuth-a9fb696c40441e06ef817d7e28bae74c6a6cb6e4.zip
DotNetOpenAuth-a9fb696c40441e06ef817d7e28bae74c6a6cb6e4.tar.gz
DotNetOpenAuth-a9fb696c40441e06ef817d7e28bae74c6a6cb6e4.tar.bz2
Added enough token management that the Appendix A scenario test is passing again.
Diffstat (limited to 'src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs')
-rw-r--r--src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs b/src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs
new file mode 100644
index 0000000..b54da20
--- /dev/null
+++ b/src/DotNetOAuth/ChannelElements/StandardTokenGenerator.cs
@@ -0,0 +1,39 @@
+//-----------------------------------------------------------------------
+// <copyright file="StandardTokenGenerator.cs" company="Andrew Arnott">
+// Copyright (c) Andrew Arnott. All rights reserved.
+// </copyright>
+//-----------------------------------------------------------------------
+
+namespace DotNetOAuth.ChannelElements {
+ using System;
+ using System.Collections.Generic;
+ using System.Linq;
+ using System.Text;
+ using System.Security.Cryptography;
+
+ internal class StandardTokenGenerator : ITokenGenerator {
+ RandomNumberGenerator cryptoProvider = new RNGCryptoServiceProvider();
+
+ #region ITokenGenerator Members
+
+ public string GenerateRequestToken(string consumerKey) {
+ return GenerateCryptographicallyStrongString();
+ }
+
+ public string GenerateAccessToken(string consumerKey) {
+ return GenerateCryptographicallyStrongString();
+ }
+
+ public string GenerateSecret() {
+ return GenerateCryptographicallyStrongString();
+ }
+
+ #endregion
+
+ private string GenerateCryptographicallyStrongString() {
+ byte[] buffer = new byte[20];
+ cryptoProvider.GetBytes(buffer);
+ return Convert.ToBase64String(buffer);
+ }
+ }
+}