Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php /* * LDAP - Password Modify Extended Operation Driver * * Driver for passwords s..

Decoded Output download

<?php

/*
 * LDAP - Password Modify Extended Operation Driver
 *
 * Driver for passwords stored in SAMBA Active Directory
 * This driver is based on Simple LDAP Password Driver, but uses
 * ldap_modify method (SAMBA Active Directory support)
 * PHP >= 7.2 required
 *
 * @version 1.0
 * @author Jonas Holm Bundgaard <[email protected]>
 * Based on code by Peter Kubica <[email protected]>
 *
 * Copyright (C) The Roundcube Dev Team
 *
 * This program 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 version.
 *
 * This program 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
 * along with this program. If not, see http://www.gnu.org/licenses/.
 */

require_once __DIR__ . '/ldap_simple.php';

class rcube_ldap_samba_ad_password extends rcube_ldap_simple_password
{
    #[Override]
    public function save($curpass, $passwd)
    {
        if (!function_exists('ldap_mod_replace')) {
            rcube::raise_error([
                'code' => 100,
                'type' => 'ldap',
                'message' => 'Password plugin: ldap_mod_replace() not supported',
            ], true);

            return PASSWORD_ERROR;
        }

        // Connect and bind
        $ret = $this->connect($curpass);
        if ($ret !== true) {
            return $ret;
        }

        $hash = password::hash_password($passwd, 'ad');

        $entry = ['unicodePwd' => $hash];

        $this->_debug("C: Replace password for {$this->user}: " . print_r($entry, true));

        if (!ldap_mod_replace($this->conn, $this->user, $entry)) {
            $this->_debug('S: ' . ldap_error($this->conn));

            $errno = ldap_errno($this->conn);

            ldap_unbind($this->conn);

            if ($errno == 0x13) {
                return PASSWORD_CONSTRAINT_VIOLATION;
            }

            return PASSWORD_CONNECT_ERROR;
        }

        $this->_debug('S: OK');

        // All done, no error
        ldap_unbind($this->conn);

        return PASSWORD_SUCCESS;
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

/*
 * LDAP - Password Modify Extended Operation Driver
 *
 * Driver for passwords stored in SAMBA Active Directory
 * This driver is based on Simple LDAP Password Driver, but uses
 * ldap_modify method (SAMBA Active Directory support)
 * PHP >= 7.2 required
 *
 * @version 1.0
 * @author Jonas Holm Bundgaard <[email protected]>
 * Based on code by Peter Kubica <[email protected]>
 *
 * Copyright (C) The Roundcube Dev Team
 *
 * This program 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 version.
 *
 * This program 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
 * along with this program. If not, see http://www.gnu.org/licenses/.
 */

require_once __DIR__ . '/ldap_simple.php';

class rcube_ldap_samba_ad_password extends rcube_ldap_simple_password
{
    #[Override]
    public function save($curpass, $passwd)
    {
        if (!function_exists('ldap_mod_replace')) {
            rcube::raise_error([
                'code' => 100,
                'type' => 'ldap',
                'message' => 'Password plugin: ldap_mod_replace() not supported',
            ], true);

            return PASSWORD_ERROR;
        }

        // Connect and bind
        $ret = $this->connect($curpass);
        if ($ret !== true) {
            return $ret;
        }

        $hash = password::hash_password($passwd, 'ad');

        $entry = ['unicodePwd' => $hash];

        $this->_debug("C: Replace password for {$this->user}: " . print_r($entry, true));

        if (!ldap_mod_replace($this->conn, $this->user, $entry)) {
            $this->_debug('S: ' . ldap_error($this->conn));

            $errno = ldap_errno($this->conn);

            ldap_unbind($this->conn);

            if ($errno == 0x13) {
                return PASSWORD_CONSTRAINT_VIOLATION;
            }

            return PASSWORD_CONNECT_ERROR;
        }

        $this->_debug('S: OK');

        // All done, no error
        ldap_unbind($this->conn);

        return PASSWORD_SUCCESS;
    }
}

Function Calls

None

Variables

None

Stats

MD5 a1cc3cab7dff565cc00da47c4b33dabf
Eval Count 0
Decode Time 85 ms