summaryrefslogtreecommitdiff
path: root/share/www/script/couch.js
diff options
context:
space:
mode:
authorDamien F. Katz <damien@apache.org>2009-08-04 19:50:46 +0000
committerDamien F. Katz <damien@apache.org>2009-08-04 19:50:46 +0000
commit8e2215ee6306b0f4c13553796d401e9f5f93bcb6 (patch)
tree948b9179887e73379bc445b9ad058de3a0bbe870 /share/www/script/couch.js
parentfd72a9bc48ebab76976f538c28459a0e26aa1750 (diff)
Initial check-in of OAuth and cookie authentication.
git-svn-id: https://svn.apache.org/repos/asf/couchdb/trunk@800938 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'share/www/script/couch.js')
-rw-r--r--share/www/script/couch.js61
1 files changed, 61 insertions, 0 deletions
diff --git a/share/www/script/couch.js b/share/www/script/couch.js
index bd1d49dd..f354f52a 100644
--- a/share/www/script/couch.js
+++ b/share/www/script/couch.js
@@ -299,6 +299,67 @@ function CouchDB(name, httpHeaders) {
// Use this from callers to check HTTP status or header values of requests.
CouchDB.last_req = null;
+CouchDB.login = function(username, password) {
+ CouchDB.last_req = CouchDB.request("POST", "/_session", {
+ headers: {"Content-Type": "application/x-www-form-urlencoded",
+ "X-CouchDB-WWW-Authenticate": "Cookie"},
+ body: "username=" + encodeURIComponent(username) + "&password=" + encodeURIComponent(password)
+ });
+ return JSON.parse(CouchDB.last_req.responseText);
+}
+
+CouchDB.logout = function() {
+ CouchDB.last_req = CouchDB.request("DELETE", "/_session", {
+ headers: {"Content-Type": "application/x-www-form-urlencoded",
+ "X-CouchDB-WWW-Authenticate": "Cookie"}
+ });
+ return JSON.parse(CouchDB.last_req.responseText);
+}
+
+CouchDB.createUser = function(username, password, email, roles, basicAuth) {
+ var roles_str = ""
+ if (roles) {
+ for (var i=0; i< roles.length; i++) {
+ roles_str += "&roles=" + encodeURIComponent(roles[i]);
+ }
+ }
+ var headers = {"Content-Type": "application/x-www-form-urlencoded"};
+ if (!basicAuth) {
+ headers['X-CouchDB-WWW-Authenticate'] = 'Cookie';
+ }
+
+ CouchDB.last_req = CouchDB.request("POST", "/_user/", {
+ headers: headers,
+ body: "username=" + encodeURIComponent(username) + "&password=" + encodeURIComponent(password)
+ + "&email="+ encodeURIComponent(email)+ roles_str
+
+ });
+ return JSON.parse(CouchDB.last_req.responseText);
+}
+
+CouchDB.updateUser = function(username, email, roles, password, old_password) {
+ var roles_str = ""
+ if (roles) {
+ for (var i=0; i< roles.length; i++) {
+ roles_str += "&roles=" + encodeURIComponent(roles[i]);
+ }
+ }
+
+ var body = "email="+ encodeURIComponent(email)+ roles_str;
+
+ if (typeof(password) != "undefined" && password)
+ body += "&password=" + password;
+
+ if (typeof(old_password) != "undefined" && old_password)
+ body += "&old_password=" + old_password;
+
+ CouchDB.last_req = CouchDB.request("PUT", "/_user/"+encodeURIComponent(username), {
+ headers: {"Content-Type": "application/x-www-form-urlencoded",
+ "X-CouchDB-WWW-Authenticate": "Cookie"},
+ body: body
+ });
+ return JSON.parse(CouchDB.last_req.responseText);
+}
CouchDB.allDbs = function() {
CouchDB.last_req = CouchDB.request("GET", "/_all_dbs");