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

Unified Diff: Src/GoogleApis.WP81/Apis/Util/Store/PasswordVaultDataStore.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, 8 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
« no previous file with comments | « Src/GoogleApis.WP/packages.config ('k') | Src/GoogleApis.WP81/GoogleApis.WP81.csproj » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Src/GoogleApis.WP81/Apis/Util/Store/PasswordVaultDataStore.cs
===================================================================
new file mode 100644
--- /dev/null
b/Src/GoogleApis.WP81/Apis/Util/Store/PasswordVaultDataStore.cs
@@ -0,0 1,101 @@
/*
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.Threading.Tasks;
using Windows.Security.Credentials;
using Google.Apis.Json;
using Google.Apis.Util.Store;
namespace Google.Apis.Util.Store
{
/// <summary>
/// Credentials store that implements <see cref="IDataStore"/>.
/// This store saves all keys encrypted in a <see cref="PasswordVault"/>
/// </summary>
public class PasswordVaultDataStore : IDataStore
{
public static PasswordVaultDataStore Default = new PasswordVaultDataStore();
PasswordVault passwordVault = new PasswordVault();
/// <summary>Adds a new key to the password vault.</summary>
public Task StoreAsync<T>(string key, T value)
{
passwordVault.Add(new PasswordCredential(
typeof(T).ToString(),
key,
NewtonsoftJsonSerializer.Instance.Serialize(value)));
return TaskEx.Delay(0);
}
/// <summary>Deletes a given key from the password vault.</summary>
public Task DeleteAsync<T>(string key)
{
try
{
PasswordCredential credential = passwordVault.Retrieve(typeof(T).ToString(), key);
passwordVault.Remove(credential);
}
// PasswordVault.Retrieve might throw a general exception. DO NOTHING, there is no value for this key.
catch (Exception) { }
return TaskEx.Delay(0);
}
/// <summary>
/// Gets a specific key from the password vault. Returns <c>default(T)</c> if there is no matching entry.
/// </summary>
public Task<T> GetAsync<T>(string key)
{
TaskCompletionSource<T> tcs = new TaskCompletionSource<T>();
try
{
PasswordCredential credential = passwordVault.Retrieve(typeof(T).ToString(), key);
// No matching entry.
if (credential == null)
{
tcs.SetResult(default(T));
}
else
{
credential.RetrievePassword();
tcs.SetResult(NewtonsoftJsonSerializer.Instance.Deserialize<T>(credential.Password));
}
}
// PasswordVault.Retrieve might throw a general exception, which mean there isn't a matching entry.
catch (Exception)
{
tcs.SetResult(default(T));
}
return tcs.Task;
}
/// <summary>Removes all values from the password vault.</summary>
public Task ClearAsync()
{
try
{
foreach (var credential in passwordVault.RetrieveAll())
{
passwordVault.Remove(credential);
}
}
// PasswordVault.RetrieveAll might throw a general exception - DO NOTHING, there are no values to remove.
catch (Exception) { }
return TaskEx.Delay(0);
}
}
}
« no previous file with comments | « Src/GoogleApis.WP/packages.config ('k') | Src/GoogleApis.WP81/GoogleApis.WP81.csproj » ('j') | no next file with comments »

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