Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(1274)

Unified Diff: Src/GoogleApis.Auth.WP81/OAuth2/GoogleWebAuthorizationBroker.cs

Issue 176220043: Issue 471: Support WP8.1 (Closed) Base URL: https://google-api-dotnet-client.googlecode.com/hg/
Patch Set: minor Created 9 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Please Sign in to add in-line comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Src/GoogleApis.Auth.WP81/OAuth2/GoogleWebAuthorizationBroker.cs
===================================================================
new file mode 100644
--- /dev/null
+++ b/Src/GoogleApis.Auth.WP81/OAuth2/GoogleWebAuthorizationBroker.cs
@@ -0,0 +1,107 @@
+/*
+Copyright 2014 Google Inc
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+*/
+
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Text;
+using System.Threading;
+using System.Threading.Tasks;
+using Windows.Storage;
+
+using Google.Apis.Auth.OAuth2.Flows;
+using Google.Apis.Util.Store;
+
+namespace Google.Apis.Auth.OAuth2
+{
+ /// <summary>A helper utility to manage the authorization code flow.</summary>
+ public class GoogleWebAuthorizationBroker
+ {
+ /// <summary>Asynchronously authorizes the specified user.</summary>
+ /// <remarks>
+ /// It uses <see cref="Google.Apis.Util.Store.PasswordVaultDataStore"/> as the flow's data store by default.
+ /// </remarks>
+ /// <param name="clientSecretsUri">The client secrets URI.</param>
+ /// <param name="scopes">
+ /// The scopes which indicate the Google API access your application is requesting.
+ /// </param>
+ /// <param name="user">The user to authorize.</param>
+ /// <param name="taskCancellationToken">Cancellation token to cancel an operation.</param>
+ /// <returns>User credential.</returns>
+ public static async Task<UserCredential> AuthorizeAsync(Uri clientSecretsUri, IEnumerable<string> scopes,
+ string user, CancellationToken taskCancellationToken)
+ {
+ var clientSecrets = await LoadClientSecrets(clientSecretsUri).ConfigureAwait(false);
+ return await AuthorizeAsync(clientSecrets, scopes, user, taskCancellationToken).ConfigureAwait(false);
+ }
+
+ /// <summary>
+ /// Asynchronously reauthorizes the user. This method should be called if the users want to authorize after
+ /// they revoked the token.
+ /// </summary>
+ /// <param name="userCredential">The current user credential. Its <see cref="UserCredential.Token"/> will be
+ /// updated. </param>
+ /// <param name="taskCancellationToken">Cancellation token to cancel an operation.</param>
+ public static async Task ReauthorizeAsync(UserCredential userCredential,
+ CancellationToken taskCancellationToken)
+ {
+ var installedApp = new AuthorizationCodeWPInstalledApp(userCredential.Flow);
+ // Create an authorization code installed app instance and authorize the user.
+ UserCredential newUserCredential = await installedApp.AuthorizeAsync(
+ userCredential.UserId, taskCancellationToken).ConfigureAwait(false);
+ userCredential.Token = newUserCredential.Token;
+ }
+
+ /// <summary>Asynchronously authorizes the specified user.</summary>
+ /// <remarks>
+ /// It uses <see cref="Google.Apis.Util.Store.PasswordVaultDataStore"/> as the flow's data store by default.
+ /// </remarks>
+ /// <param name="clientSecrets">The client secrets URI.</param>
+ /// <param name="scopes">
+ /// The scopes which indicate the Google API access your application is requesting.
+ /// </param>
+ /// <param name="user">The user to authorize.</param>
+ /// <param name="taskCancellationToken">Cancellation token to cancel an operation.</param>
+ /// <returns>User credential.</returns>
+ private static async Task<UserCredential> AuthorizeAsync(ClientSecrets clientSecrets,
+ IEnumerable<string> scopes, string user, CancellationToken taskCancellationToken)
+ {
+ var initializer = new GoogleAuthorizationCodeFlow.Initializer
+ {
+ ClientSecrets = clientSecrets,
+ Scopes = scopes,
+ DataStore = new PasswordVaultDataStore()
+ };
+
+ var installedApp = new AuthorizationCodeWPInstalledApp(new GoogleAuthorizationCodeFlow(initializer));
+ return await installedApp.AuthorizeAsync(user, taskCancellationToken).ConfigureAwait(false);
+ }
+
+ /// <summary>Loads the client secrets from the given URI.</summary>
+ /// <param name="clientSecretsUri">The client secrets URI.</param>
+ /// <returns>Client secrets.</returns>
+ private static async Task<ClientSecrets> LoadClientSecrets(Uri clientSecretsUri)
+ {
+ var file = await StorageFile.GetFileFromApplicationUriAsync(clientSecretsUri);
+ var content = await FileIO.ReadTextAsync(file);
+
+ using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(content)))
+ {
+ return GoogleClientSecrets.Load(stream).Secrets;
+ }
+ }
+ }
+}

Powered by Google App Engine
RSS Feeds Recent Issues | This issue
This is Rietveld f62528b