Symbian.org/Login.js
changeset 0 54498df70f5d
child 2 99bc8e56b756
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Symbian.org/Login.js	Fri Jun 05 16:18:05 2009 +0100
@@ -0,0 +1,76 @@
+// ////////////////////////////////////////////////////////////////////////////
+// (c)2009 Symbian Foundation
+// ////////////////////////////////////////////////////////////////////////////
+
+
+// Login to the developer site
+
+var loginUrlContent = null;
+var loginUrlHttpReq = null;
+var loginCallback = null;
+
+function login(callback){
+	if ( forumUsername == null || forumPassword == null ) {
+		loginInitiated = true;
+		loginInitiatedCallback = callback;
+		promptForPassword();
+		return;
+	}
+	loginCallback = callback;
+	loginInitiated = false;
+	loginInitiatedCallback = null;
+	uiManager.showNotification(-1, "wait", "Please wait...", -1);	
+	
+	var parameters =  symbianOrgLoginUsernameField + "=" + forumUsername
+	          + "&" + symbianOrgLoginPasswordField + "=" + forumPassword
+			  + "&submit=Login&image_submit.x=0&image_submit.y=0&image_submit=submit"
+			  + "&referrer="+symbianOrgBaseUrl;
+	loginUrlHttpReq = new Ajax();
+    loginUrlHttpReq.onreadystatechange = loginComplete;
+	
+    // initiate the request
+	loginUrlHttpReq.open('POST', symbianOrgLoginUrl +"?referer="+symbianOrgBaseUrl, true);
+	loginUrlHttpReq.setRequestHeader("Referer", symbianOrgBaseUrl);
+	loginUrlHttpReq.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
+	loginUrlHttpReq.setRequestHeader("Content-length", parameters.length);
+	loginUrlHttpReq.setRequestHeader("Connection", "close");
+	loginUrlHttpReq.send(parameters);
+}
+
+function loginComplete(){
+	if ( loginUrlHttpReq == null ) {
+		return;
+	}
+    // complete request?
+	var readyState = loginUrlHttpReq.readyState;
+    // attempt to get response status
+    var responseStatus = null;
+    try {
+        responseStatus = loginUrlHttpReq.status;
+    } catch (noStatusException) {}
+    if (readyState == 4) {
+
+		if (responseStatus < 300) {
+			
+			var content = loginUrlHttpReq.responseText;
+			if (content.indexOf("LoginWelcome") == -1) {
+				uiManager.showNotification(3000, "warning", "Login failed.");
+				promptForPassword();
+			}
+			else {
+				uiManager.hideNotification();
+				if (loginCallback != null) {
+					loginCallback.call();
+				}
+				checkForSecurityToken("loginComplete", content);
+			}
+		} else if (responseStatus < 400) {
+			// do nothing, this must be a redirect
+		} else {
+			uiManager.hideNotification();
+			uiManager.showNotification(3000, "warning", "Login failed.");
+			promptForPassword();
+		}
+    }
+}
+