blob: 23358408fc21424d22460b88e5819b1ffab687ae [file] [log] [blame]
cocoon.load("resource://org/apache/cocoon/webapps/authentication/flow/javascript/auth.js");
function isLoggedIn() {
var handler = cocoon.parameters["handler"];
if (auth_isAuthenticated(handler)) {
success();
} else {
failure();
}
}
function protect() {
var handler = cocoon.parameters["handler"];
if (auth_checkAuthentication(handler,"")) {
success();
} else {
// already redirected by auth_checkAuthentication
}
}
function login() {
var handler = cocoon.parameters["handler"];
if (auth_isAuthenticated(handler)) {
success();
} else if (auth_login(handler, null, cocoon.parameters)) {
success();
} else {
failure();
}
}
function logout() {
var handler = cocoon.parameters["handler"];
auth_logout(handler);
failure();
}
function success() {
var internal = cocoon.parameters["protected-internal"];
var redirect = cocoon.parameters["protected-redirect"];
if (internal != null) {
cocoon.sendPage(internal);
} else if (redirect != null) {
cocoon.redirectTo(redirect);
} else {
throw new Error("No protected redirection parameter given");
}
}
function failure() {
var internal = cocoon.parameters["failure-internal"];
var redirect = cocoon.parameters["failure-redirect"];
if (internal != null) {
cocoon.sendPage(internal);
} else if (redirect != null) {
cocoon.redirectTo(redirect);
} else {
// Why does this throw cause an error?
throw new Error("No failure redirection parameter given");
}
}