summaryrefslogtreecommitdiff
path: root/src/gui/login/LoginModel.cpp
diff options
context:
space:
mode:
authorSimon 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)
commit9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d (patch)
treeac7d040253b459ce102e476cb19ab59e3cfa90d7 /src/gui/login/LoginModel.cpp
parent6bf98ccdca39936a3c51367862eed7c49f8786ec (diff)
parentbdc69f31c0be94191015838886bdcc2bc67f1acb (diff)
downloadpowder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.zip
powder-9b5b85f9b01cbda7ef9a7ec2a15b2a35630a5b9d.tar.gz
Merge branch 'reorganisation' of github.com:FacialTurd/The-Powder-Toy
Diffstat (limited to 'src/gui/login/LoginModel.cpp')
-rw-r--r--src/gui/login/LoginModel.cpp58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/gui/login/LoginModel.cpp b/src/gui/login/LoginModel.cpp
new file mode 100644
index 0000000..5b70c2c
--- /dev/null
+++ b/src/gui/login/LoginModel.cpp
@@ -0,0 +1,58 @@
+#include "LoginModel.h"
+
+LoginModel::LoginModel():
+ currentUser(0, "")
+{
+
+}
+
+void LoginModel::Login(string username, string password)
+{
+ statusText = "Logging in...";
+ loginStatus = false;
+ notifyStatusChanged();
+ LoginStatus status = Client::Ref().Login(username, password, currentUser);
+ switch(status)
+ {
+ case LoginOkay:
+ statusText = "Logged in";
+ loginStatus = true;
+ break;
+ case LoginError:
+ statusText = "Error: " + Client::Ref().GetLastError();
+ break;
+ }
+ notifyStatusChanged();
+}
+
+void LoginModel::AddObserver(LoginView * observer)
+{
+ observers.push_back(observer);
+}
+
+string LoginModel::GetStatusText()
+{
+ return statusText;
+}
+
+User LoginModel::GetUser()
+{
+ return currentUser;
+}
+
+bool LoginModel::GetStatus()
+{
+ return loginStatus;
+}
+
+void LoginModel::notifyStatusChanged()
+{
+ for(int i = 0; i < observers.size(); i++)
+ {
+ observers[i]->NotifyStatusChanged(this);
+ }
+}
+
+LoginModel::~LoginModel() {
+}
+