Skip to content

Commit

Permalink
Create a more sensible way to load/save login creds
Browse files Browse the repository at this point in the history
  • Loading branch information
anaisbetts committed Apr 10, 2012
1 parent 4df71bc commit b606d6d
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 11 deletions.
50 changes: 42 additions & 8 deletions Play/ViewModels/AppBootstrapper.cs
@@ -1,6 +1,7 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reactive;
using System.Reactive.Linq;
using System.Reactive.Threading.Tasks;
using System.Text;
Expand All @@ -17,8 +18,11 @@ namespace Play.ViewModels
{
public interface ILoginMethods : IReactiveNotifyPropertyChanged
{
void EraseCredentialsAndNavigateToLogin();
IPlayApi CurrentAuthenticatedClient { get; set; }

void EraseCredentialsAndNavigateToLogin();
void SaveCredentials(string baseUrl, string username);
IObservable<IPlayApi> LoadCredentials();
}

public interface IAppBootstrapper : IScreen, ILoginMethods { }
Expand All @@ -42,7 +46,14 @@ public AppBootstrapper(IKernel testKernel = null, IRoutingState router = null)
(type, contract) => Kernel.Get(type, contract),
(type, contract) => Kernel.GetAll(type, contract));

Router.Navigate.Execute(Kernel.Get<IPlayViewModel>());
LoadCredentials().Subscribe(
x => {
CurrentAuthenticatedClient = x;
Router.Navigate.Execute(Kernel.Get<IPlayViewModel>());
}, ex => {
this.Log().WarnException("Failed to load credentials, going to login screen", ex);
Router.Navigate.Execute(Kernel.Get<IPlayViewModel>());
});
}

public static IKernel Kernel { get; protected set; }
Expand All @@ -52,6 +63,10 @@ public AppBootstrapper(IKernel testKernel = null, IRoutingState router = null)
get { return _CurrentAuthenticatedClient; }
set { this.RaiseAndSetIfChanged(x => x.CurrentAuthenticatedClient, value); }
}

/*
* ILoginMethods
*/

public void EraseCredentialsAndNavigateToLogin()
{
Expand All @@ -63,17 +78,36 @@ public void EraseCredentialsAndNavigateToLogin()
Router.Navigate.Execute(Kernel.Get<IWelcomeViewModel>());
}

public IObservable<IPlayApi> GetPlayApi() { return apiFactory != null ? apiFactory() : getPlayApi().ToObservable(); }
async Task<IPlayApi> getPlayApi()
public void SaveCredentials(string baseUrl, string username)
{
var blobCache = Kernel.Get<ISecureBlobCache>();

blobCache.InsertObject("BaseUrl", baseUrl);
blobCache.InsertObject("Username", username);

CurrentAuthenticatedClient = createPlayApiFromCreds(baseUrl, username);
}

public IObservable<IPlayApi> LoadCredentials() { return apiFactory != null ? apiFactory() : loadCredentials().ToObservable(); }
async Task<IPlayApi> loadCredentials()
{
var blobCache = Kernel.Get<ISecureBlobCache>();
var localMachine = Kernel.Get<IBlobCache>("LocalMachine");
var baseUrl = await blobCache.GetObjectAsync<string>("BaseUrl");
var userName = await blobCache.GetObjectAsync<string>("Username");

var ret = new RestClient(baseUrl);
ret.AddDefaultParameter("login", userName);
return new PlayApi(ret, localMachine);
var ret = createPlayApiFromCreds(baseUrl, userName);
CurrentAuthenticatedClient = ret;
return ret;
}

PlayApi createPlayApiFromCreds(string baseUrl, string userName)
{
var localMachine = Kernel.Get<IBlobCache>("LocalMachine");
var rc = new RestClient(baseUrl);
rc.AddDefaultParameter("login", userName);

var ret = new PlayApi(rc, localMachine);
return ret;
}

IKernel createDefaultKernel()
Expand Down
5 changes: 2 additions & 3 deletions Play/ViewModels/WelcomeViewModel.cs
Expand Up @@ -54,7 +54,7 @@ public class WelcomeViewModel : ReactiveObject, IWelcomeViewModel
[Inject]
public WelcomeViewModel(
IScreen screen,
ISecureBlobCache credCache,
ILoginMethods loginMethods,
[Named("connectToServer")] [Optional] Func<string, string, IObservable<Unit>> connectToServerMock)
{
HostScreen = screen;
Expand All @@ -75,8 +75,7 @@ public class WelcomeViewModel : ReactiveObject, IWelcomeViewModel
return;
}
credCache.InsertObject("BaseUrl", BaseUrl);
credCache.InsertObject("Username", Username);
loginMethods.SaveCredentials(BaseUrl, Username);
screen.Router.NavigateBack.Execute(null);
});

Expand Down

0 comments on commit b606d6d

Please sign in to comment.