Login.Using Pre and Post Hooks
Last updated Dec 8th, 2019 | Page history | Improve this page | Report an issue
Support the team building MODX with a monthly donation.
The budget raised through OpenCollective is transparent, including payouts, and any contributor can apply to be paid for their work on MODX.
Backers
Budget
$294 per month—let's make that $500!
Learn moreHooking it Up with Login¶
The Register, UpdateProfile and Login snippets have properties named 'preHooks' and 'postHooks'. These properties allow you to attach custom functionality to both before and after each one of those Snippets executes its main actions.
Using Custom Hooks¶
Hooks are basically Snippets that run after the form is validated. Hooks can be chained; the first hook will execute, and if succeeds, will proceed onto the next hook. The snippet should return true on success and either false or an error message on failure. If the snippet returns false, hooks listed after the snippet in the respective hooks parameter will not execute. However, if the specified snippet is not found, the hooks following it in the list will still execute.
Your custom Snippets must return true when used as a hook. Returning "false" indicates failure, and execution of the process stops (e.g. Login or Register).
- Pre-Hooks in Login are fired before the action occurs, but after field validation. If a preHook fails, the snippet wont proceed with its normal action.
- Post-Hooks in Login are fired after the action occurs. The User is already saved at this point. However, note that getUser() will not necessarily return the active user object!
Coding Hooks¶
To create a custom hook, create a Snippet and reference its name in the &preHooks or &postHooks property in the Register and/or UpdateProfile snippets.
Accessing the fields in the hook¶
The fields in the form are available in the snippet in the 'fields' via the Hooks API. Example:
$email = $hook->getValue('email');
You can also grab all the values of the form:
$formFields = $hook->getValues();
$email = $formFields['email'];
Post-Hooks have special fields in addition to the ones passed in the form that can be accessed for each Snippet:
Register¶
// A reference to the modUser object
$user = $hook->getValue('register.user');
// A reference to the modUserProfile object
$profile = $hook->getValue('register.profile');
// An array of usergroup names that the User joined
$usergroups = $hook->getValue('register.usergroups');
UpdateProfile¶
// A reference to the modUser object
$user = $hook->getValue('updateprofile.user');
// A reference to the modUserProfile object
$profile = $hook->getValue('updateprofile.profile');
// A boolean stating if the username was changed
$changed = $hook->getValue('updateprofile.usernameChanged');
Accessing Snippet Properties¶
You can access properties passed to Snippets like Register and Login, like this:
$properties = $hook->login->controller->config;
Custom preHook return values¶
Snippets should return true on success. On failure, the snippet can set error messages in the preHook object's errors variable and return false. In either case, hooks listed after the custom hook in the &preHooks parameter will not execute.
The $hook object is available in the snippet in the 'hook' member of the $scriptProperties array. It can be used to return generic error messages to the preHook from the snippet:
$errorMsg = 'User not found';
$hook->addError('user',$errorMsg);
return false;
Examples¶
Register custom email postHook¶
Say we want to send a custom email to [email protected] every time a user signs up.
We'd create a snippet named 'hookComEmail', and use this code:
$message = 'Hi, a new User signed up: '.$hook->getValue('username')
. ' with email '.$hook->getValue('email').'.';
$modx->getService('mail', 'mail.modPHPMailer');
$modx->mail->set(modMail::MAIL_BODY,$message);
$modx->mail->set(modMail::MAIL_FROM,'[email protected]');
$modx->mail->set(modMail::MAIL_FROM_NAME,'Jerrys Site');
$modx->mail->set(modMail::MAIL_SENDER,'Jerrys Site');
$modx->mail->set(modMail::MAIL_SUBJECT,'New User Signed Up');
$modx->mail->address('to','[email protected]');
$modx->mail->setHTML(true);
if (!$modx->mail->send()) {
$modx->log(modX::LOG_LEVEL_ERROR,'An error occurred while trying to send the email: '.$err);
}
$modx->mail->reset();
/* tell our snippet we're good and can continue */
return true;
Then we'd adjust our Register snippet call to load the postHook:
[[!Register? &postHooks=`hookComEmail`]]
And we're done!
Profile logo update custom postHook¶
First of all extend UpdateProfile HTML form with next field:
<div>
<img src="[[+photo:default=`/assets/photouser/default.jpg`]]">
</div>
<label for="photo">Photo
<span class="error">[[+error.photo]]</span>
</label>
<input type="file" id="photo" name="photo" value="[[+photo]]">
Create custom hook named 'hookUpdateProfilePhoto'. Please make sure that all used folders exist and have sufficient permissions. Add the following code to the snippet:
<?php
// get user details
$profile = $modx->user->getOne('Profile');
//if post
if(isset($_POST['login-updprof-btn'])) {
//set extensions
$validExt=array('jpg','png','jpeg');
//set path for file
$pathToFile = $modx->config['base_path'].'site_content/content/users/';
// set path for cmp because of media resource
$pathToFileProfile = 'users/';
// get file name
$nameFile = $_FILES['photo']['name'];
// lowercase and exxtention
$extFile = mb_strtolower(pathinfo($nameFile, PATHINFO_EXTENSION));
// the tmp file
$tmpFile = $_FILES['photo']['tmp_name'];
// upload is ok then
if((is_uploaded_file($tmpFile)) &&! ($_FILES['photo']['error'])){
// check extention types
if (in_array($extFile,$validExt)) {
// make a file name
$tmpzname='user'.$modx->user->get('id');
// add a hash and extension
$nameFile=hash('adler32',$tmpzname).'.'.$extFile;
//full name with path
$fullNameFile = $pathToFile.$nameFile;
// copy the tmp to new one move_uploaded_file1 and rename1 did not work this will overwrite the old pic as they all have same name
copy($tmpFile, $fullNameFile);
// name and path for profile as its different because of media resource
$fullNameFileProfile = $pathToFileProfile.$nameFile;
// delete old pic in profile
$hook->setValue('photo','');
//set new pic path
$hook->setValue('photo',$fullNameFileProfile);
}
else{
$modx->log(modX::LOG_LEVEL_ERROR,'The image has an invalid extension');
}
}
else {
$modx->log(modX::LOG_LEVEL_ERROR,'Error loading file. Error code:'.$_FILES['photo']['error']);
}
}
return true;
and after add it to UpdateProfile
snippet preHooks
parameter:
[[!UpdateProfile? &preHooks=`hookUpdateProfilePhoto`]]
See Also¶
- Login.Login
- Login.Profile
- Login.UpdateProfile
- Login.Register
- Login.ConfirmRegister
- Login.ForgotPassword
- Login.ResetPassword
- Login.ChangePassword
- Login.Tutorials
Support the team building MODX with a monthly donation.
The budget raised through OpenCollective is transparent, including payouts, and any contributor can apply to be paid for their work on MODX.
Backers
Budget
$294 per month—let's make that $500!
Learn more