diff options
| author | Simon Robertshaw <simon@hardwired.org.uk> | 2013-03-24 12:24:17 (GMT) |
|---|---|---|
| committer | Simon Robertshaw <simon@hardwired.org.uk> | 2013-03-24 12:24:17 (GMT) |
| commit | 9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d (patch) | |
| tree | ac7d040253b459ce102e476cb19ab59e3cfa90d7 /src/gui/login/LoginController.cpp | |
| parent | 6bf98ccdca39936a3c51367862eed7c49f8786ec (diff) | |
| parent | bdc69f31c0be94191015838886bdcc2bc67f1acb (diff) | |
| download | powder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.zip powder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.tar.gz | |
Merge branch 'reorganisation' of github.com:FacialTurd/The-Powder-Toy
Diffstat (limited to 'src/gui/login/LoginController.cpp')
| -rw-r--r-- | src/gui/login/LoginController.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/gui/login/LoginController.cpp b/src/gui/login/LoginController.cpp new file mode 100644 index 0000000..fd8e576 --- /dev/null +++ b/src/gui/login/LoginController.cpp @@ -0,0 +1,51 @@ +#include "LoginController.h" +#include "client/User.h" +#include "client/Client.h" + +LoginController::LoginController(ControllerCallback * callback): + HasExited(false) +{ + loginView = new LoginView(); + loginModel = new LoginModel(); + + loginView->AttachController(this); + loginModel->AddObserver(loginView); + + this->callback = callback; + +} + +void LoginController::Login(string username, string password) +{ + loginModel->Login(username, password); +} + +User LoginController::GetUser() +{ + return loginModel->GetUser(); +} + +void LoginController::Exit() +{ + if(ui::Engine::Ref().GetWindow() == loginView) + { + ui::Engine::Ref().CloseWindow(); + } + if(callback) + callback->ControllerExit(); + else + { + Client::Ref().SetAuthUser(loginModel->GetUser()); + } + HasExited = true; +} + +LoginController::~LoginController() { + if(ui::Engine::Ref().GetWindow() == loginView) + { + ui::Engine::Ref().CloseWindow(); + } + delete loginModel; + delete loginView; +} + |
