Jump to content
AndZyk

Clear password before encryption

Recommended Posts

Hello,

can somebody tell me, if it is possible to get the clear password of an InputfieldPassword inside a module, before it is encrypted?

I have made a custom module which sets the password of an Auth0User after the hook publishReady with a random generated password. When I try to get a clear password from a InputfieldPassword in this hook, it is of course already encrypted (which is of course good). But is there a hook before the encryption, so I could get it one time to send it to Auth0?

If there is not such thing, could be another possibility to add a jQuery script to get the value directly from the DOM and save it somewhere temporarily?

I know this might be an unusual question, but I would appreciate any feedback. :)

Regards, Andreas

Share this post


Link to post
Share on other sites

Hook before/after Password::setPass() method instead? Keep in mind that this hook is called before page publish (while setting value for a password field)

/**
 * Set the 'pass' to the given value
 * 
 * @param string $value
 * @throws WireException if given invalid $value
 *
 */
protected function ___setPass($value) {

    // if nothing supplied, then don't continue
    if(!strlen($value)) return;
    if(!is_string($value)) throw new WireException("Password must be a string"); 

    // first check to see if it actually changed
    if($this->data['salt'] && $this->data['hash']) {
        $hash = $this->hash($value);
        if($this->isBlowfish($hash)) $hash = substr($hash, 29);
        // if no change then return now
        if($hash === $this->data['hash']) return; 
    }

    // password has changed
    $this->trackChange('pass');

    // force reset by clearing out the salt, hash() will gen a new salt
    $this->data['salt'] = ''; 

    // generate the new hash
    $hash = $this->hash($value);

    // if it's a blowfish hash, separate the salt from the hash
    if($this->isBlowfish($hash)) {
        $this->data['salt'] = substr($hash, 0, 29); // previously 28
        $this->data['hash'] = substr($hash, 29);
    } else {
        $this->data['hash'] = $hash;
    }
}

 

  • Like 2
  • Thanks 1

Share this post


Link to post
Share on other sites

Thanks @abdus and @adrian,

I was able to grab the clear password with the Password:setPass hook and saved it into a session variable to pass it between my module functions. Of course I clear the session variable afterwards. ;)

Share this post


Link to post
Share on other sites
1 minute ago, AndZyk said:

and saved it into a session variable to pass it between my module functions

Why not use a variable defined in the module class, eg:

protected $clearPassword

and populated via:

$this->clearPassword

in the hook's function. This will be available throughout the module's functions.

This is what I did in my EmailNewUser that I linked to above.

  • Like 2

Share this post


Link to post
Share on other sites

Of course you are right. I should have looked closer at your code. ;)

  • Like 1

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • By Lewis Newson
      Hi All,
      Im working on streamlining my email sending setup for SMTP. I have a page where the user of the website can input the SMTP host, port, connection type email and password etc but the password field has an additional box underneath it for 'Confirming' it as if it were a new password. The placeholder text also says 'New Password' but I want to be able to change that. I just need an input field where they can enter their SMTP password without it being plain text.
      Thanks for your help!
    • By Tyssen
      I have a client who is reporting that in the last couple of days they can no longer login to their site with their normal browser (Chrome). Using another browser or an incognito window works.
      I've tried logging into the site using the same login details in my usual browser (Firefox) and have had no problems.
      The site is a membership site and today other members are reporting the same problem.
      The site is running 3.0.148 and has the session handler DB and login throttle modules installed. It was recently upgraded to 3.x from 2.x. But no changes have been made to the site between the time when they were able to login OK and when the problem started happening.
    • By anttila
      We are developing an App that sends data over the Internet to ProcessWire (POST/JSON). We want password to be protected somehow when sending it, but I should be able to compare it to PW's passwords. We were thinking of using md5 encryption, but PW uses different encryption.
      How can I be sure that user has active account when they use the App?
    • By Robin S
      Password Generator
      Adds a password generator to InputfieldPassword.

       
      Usage
      Install the Password Generator module.
      Now any InputfieldPassword has a password generation feature. The settings for the generator are taken automatically from the settings* of the password field.
      *Settings not supported by the generator:
      Complexify: but generated passwords should still satisfy complexify settings in the recommended range. Banned words: but the generated passwords are random strings so actual words are unlikely to occur.  
      https://modules.processwire.com/modules/password-generator/
      https://github.com/Toutouwai/PasswordGenerator
×
×
  • Create New...