Bridging AjaXplorer Authentication

This section will describe how to use the auth.remote plugin to create a bridge with an existing CMS. At first we’ll assume that the cms has it’s own authentification mechanism, and one just want to « inform » AjaXplorer that a user is logged indeed. Then, we’ll see how to create an external login page and still use AjaXplorer’s own mechanism to check the users credentials (for example on a simple website that does not have users management at all).
One of the best way to see the auth.remote plugin work in real life is to download and inspect the existing bridges with external cms : wordpress, drupal, joomla and cmsms. They all do exactly what is described here.

Auth.remote plugin basics

Master / Slave modes

We won’t go here through the plugins basics, please see if you don’t know what we are talking about here. Auth.remote plugin is an authentication plugin that is designed to create bridges between application. It can be configured to work either as master : logging is done via AjaXplorer interface, but the credentials check is calling a remote url; or as slave : logging is done through another interface, but when a user is logged in in the external system, he is automatically logged in AjaXplorer also. Thus in slave mode, there is no more « Login / Logout » action in the GUI, but it’s replaced by a « Back » button that can be configured to redirect the user to any page of the external system, usually the home page. Only the slave mode will be used in this tutorial.

Slave mode

The base of the slave mode will be to call in your external cms a little piece of code called glueCode to trigger AjaXplorer authentication events (the process is detailed below). When calling this code, we want to make sure that the code is really called by the CMS, not by another code on the same server, so there is a basic security implemented by a « secret » key that is shared by both the CMS and by AjaXplorer.

One of the interest of using auth.remote with another CMS can be to avoid duplicating users management on both parts of the system (ajaxplorer & cms) : for this, there is an autoCreate option that will trigger automatic creation of a user account in AjaXplorer when logged in by auth.remote : that way, users creation/deletion is managed only on the CMS side, and if the CMS tells a user is valid, AjaXplorer will create automatically its account, even if it’s not already registered on the AjaXplorer side. This option is passed programmatically when calling the glueCode.

Note: autoCreate would probablye be useless if not used in conjunction with the « DEFAULT_RIGHTS » option of the repositories. Setting a non-empty value for this option in a given repository « Repo » (value can be r or rw as read or read/write), and setting auth.remote auto create option to true, any user identified by the external CMS will be automatically created in AjaXplorer AND have directly access to « Repo » with read or read/write access.

Auth.remote configuration

Now we can have a closer look at the AUTH_DRIVER configuration to set inside ajaxplorer conf.php file :

 1"AUTH_DRIVER" = array(
 2        "NAME"          => "remote",
 3        "OPTIONS"       => array(
 4            "SLAVE_MODE"  => true,
 5            "USERS_FILEPATH" => "AJXP_INSTALL_PATH/server/users/users.ser",
 6            "LOGIN_URL" => "/your_cms/login.php",  // The URL to redirect to if a non-logged user tries to access AjaXplorer
 7            "LOGOUT_URL" => "/your_cms/homepage.php",  // The URL to redirect upon login out
 8            "SECRET" => "myprivatesecret",// the secret key that you will pass to the glueCode when communicating with it (see below)
 9            "TRANSMIT_CLEAR_PASS"   => false ) // Don't touch this. It's unsafe (and useless here) to transmit clear password.
10    )

Communicating between the two apps

The glueCode API

Let’s digg how the glueCode works : its role is to be inserted inside an already existing system (cms or not, but assuming they are written in PHP of course) and be able to let this system « call » AjaXplorer authentication functions (login, logout, create/delete users, etc).

Necessarily, if you want to call a function of such a framework as AjaXplorer, you can’t just « require() » a file and call the function : you have to initialize the framework first, by requiring all necessary dependencies, starting the right PHP session, etc, etc. This can be very tedious, it’s a lot of work to learn the given framework, what classes are needed etc. That’s why all this code is in fact performed directly by the glueCode! It can be seen as a parenthesis in your code, injecting and initializing all the AjaXplorer framework, executing one instruction, and going out. The glueCode is located inside auth.remote plugin, in the file glueCode.php (good choice no?). So all you’ll have to do is to know the absolute (ore relative) path on your server to this file, and you’ll be ok!

How can we pass parameters to this piece of code, like the name of a user? We use the PHP global scope to communicate between the two applications : before including the glueCode, you just have to declare a global array() named $AJXP_GLUE_GLOBALS that will contain all necessary arguments : the target function and its arguments, but also the secret key, the auth.remote plugin configuration, etc.

Calling glueCode sample

So as an example, let’s take the simplest action logout : when a user disconnects from the CMS, we want to be sure that he will also be disconnected from ajaXplorer, so we add the following lines in the CMS. Please note the AJXP_EXEC constant : it’s important, otherwise you’ll have an « Access not allowed » error when including glueCode.php to your code.

 1   $glueCode = "path/to/ajaxplorer/plugins/auth.remote/glueCode.php";
 2    $secret = "secret_key_passed_to_auth.remote_by_configuration";
 3    define('AJXP_EXEC', true);
 5    global $AJXP_GLUE_GLOBALS;
 6    $AJXP_GLUE_GLOBALS = array();
 7    $AJXP_GLUE_GLOBALS["secret"] = $secret;
 8    $AJXP_GLUE_GLOBALS["plugInAction"] = "logout";
 9       include($glueCode);

Auth.remote actions reference

We’ll list here the available actions made available by the glueCode.php file. Of course, it’s up to you to extend and write your own glueCode.php if you need more interactions with AjaXplorer. As described in the previous section, the array $AJXP_GLUE_GLOBALS defined in the PHP global scope is used to pass both the action name (key « plugInAction ») and the action paramaters (other keys described). The output of each action is set by the glueCode as a boolean inside AJXP_GLUE_GLOBALS["result"].

  • login
    • This will log a user in AjaXplorer. At the moment, the password check is bypassed, assuming the CMS is responsible for the credentials. See the next section if you still want to rely on AjaXplorer user/password checks. If autoCreate is true, the user will be created anyway, even if it’s not already existing on the AjaXplorer side. If the admin right is passed, the user is automatically assigned « admin » right. A SessionSwitcher is used to temporary close the current php session, open the AjaXplorer session and log the user.
    • Parameters
      • « plugInAction » : « login »
      • « login » : array(« name » => user_name, « password » => user_password, [optional] « right » => « admin »)
      • « autoCreate » : boolean true or false
  • logout
    • Destroy the AjaXplorer session (disconnecting any logged user)
    • Parameters
      • « plugInAction » : « logout »
  • addUser
    • Adds a user inside AjaXplorer. Can specify whether the new user is admin or not.
    • Parameters
      • « plugInAction » : « addUser »
      • « user » : array(« name » => username, « password » => userpassword », [optional] « right » => « admin »)
  • delUser
    • Deletes an AjaXplorer user
    • Parameters
      • « plugInAction » : « delUser »
      • « userName » : the user name.
  • updateUser
    • Updates an existing user, can be used to update both password and admin right.
    • Parameters
      • « plugInAction » : « addUser »
      • « user » : array(« name » => username, « password » => userpassword », [optional] « right » => « admin »)

If not already done, please download the ajaxplorer « External Bridges » distribution and have a look for example at the wordrpress WpAjxp.php class : you’ll now be able to understand what’s happening : beside all the pure WordPress work necessary to hook a given function inside the available wordpress extensions points, the functions are all really simple and just make use of this API to trigger the necessary actions inside AjaXplorer.

So if either your CMS implement extension points, or you can easily determine where to place the calls in your code (just after successfull login, just after successfull logout, etc, etc), include the glueCode.php having set the right arguments and it should work.

Create your own login page but still using AjaXplorer users management

Now we will describe how to create a custom login page, but that will still rely on AjaXplorer users/password checks. You don’t use a specific CMS and still want to use AjaXplorer full-featured auth system. We’ll have to hack some part of the glueCode.php, so you must have some basic PHP knowledge to understand what you are doing when editing the files!

Auth.remote necessary changes

The main problem is that in the standard glueCode.php, when authenticating a password with the credentials passed by an external CMS, we in fact assume that the user has legitimity, and bypass the password check. So we’ll have to change this to make sure that the password is indeed checked. This can be done by changing the AuthService::logUser call inside plugins/auth.remote/glueCode.php, line 99 :

Replace : $result = AuthService::logUser($login["name"], $login["password"], true); // the true here specify « bypass password check ».

By : $result = AuthService::logUser($login["name"], $login["password"], false, false, -1); // Note the last arguments they are important

[NOTE : i'll probably add a parameter to the standard glueCode.php to avoid this hack, but as for now it's necessary (release 3.1.1)]

Also since there is a kind of challenge/response using a seed mechanism to encode the password between AjaXplorer GUI and AjaXplorer server, and since you won’t use this feature, we’ll first have to switch the TRANSMIT_CLEAR_PASS option to TRUE.

Creating a form and submitting it to a php script

Now, assuming you have configured your AjaXplorer installation to use auth.remote, with TRANSMIT_CLEAR_PASS to TRUE, and the hack of glueCode at line 99, how would your login form look like? Well, like this !

 2// Here the PHP code for handling the form and the HTML code
 3// for displaying it are in the same file "login.php" 
 4// but it's not necessary!
 6if(isSet($_POST["login"]) && isSEt($_POST["password"])){
 8    // Necessary to make "connection" with the glueCode
 9    define("AJXP_EXEC", true);
10    $glueCode = "absolute/path/to/ajxp/plugins/auth.remote/glueCode.php";
11    $secret = "my_secret_key";
13    // Initialize the "parameters holder" 
14    global $AJXP_GLUE_GLOBALS;
15    $AJXP_GLUE_GLOBALS = array();
16    $AJXP_GLUE_GLOBALS["secret"] = $secret;
17    $AJXP_GLUE_GLOBALS["plugInAction"] = "login";
18    $AJXP_GLUE_GLOBALS["autoCreate"] = false;
20    // NOTE THE md5() call on the password field.
21    $AJXP_GLUE_GLOBALS["login"] = array("name" => $_POST["login"], "password" => md5($_POST["password"]));
23    // NOW call glueCode!
24       include($glueCode);
28    <body>
29        <form action="login.php" method="POST">
30            Login : <input name="login"><br>
31            Password : <input name="password" type="password"><br>
32            <input type="submit" value="SUBMIT">
33        </form>
34    </body>

Well, that’s all for today folks!

Updated over 8 years ago by Charles du Jeu Admin