NOXSHELL
Server: nginx/1.26.3
System: Linux vultr 6.8.0-54-generic #56-Ubuntu SMP PREEMPT_DYNAMIC Sat Feb 8 00:37:57 UTC 2025 x86_64
User: gisha-group (1019)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/gisha-group/htdocs/gisha-group.com/wp-authorize.php
<?php
/**
 * uPress auto login script
 *
 * @package    uPress Auto Login
 * @author     uPress <support@upress.co.il>
 * @link       https://www.upress.co.il
 */
define( 'WP_USE_THEMES', false );
if( ! file_exists( __DIR__ . '/wp-load.php' ) ) {
    require_once( dirname( __DIR__ ) . '/wp-load.php' );
} else {
    require_once( __DIR__ . '/wp-load.php' );
}
global $wpdb, $wp_version;

class UpressWpAutologin {
    const MIN_WP_VERSION = '3.7';

    public static function check_version() {
        global $wp_version;

        if ( version_compare( $wp_version, self::MIN_WP_VERSION, '<' ) ) {
            unlink( __FILE__ );
            wp_die( "WordPress version is too old ({$wp_version} < {self::MIN_WP_VERSION}).", 400 );
            exit;
        }
    }

    public static function check_auth() {
        // No authorization parameter? get out...
        if ( empty( $_GET ) ) {
            unlink( __FILE__ );
            wp_die( 'Authorization failed: Link expired or invalid, try loggin in again through the link in the dashboard.', 401 );
            exit;
        }
    }

    public static function get_home_url() {
        $current_url = "http" . ( is_ssl() ? 's' : '' ) . "://{$_SERVER['HTTP_HOST']}" . $_SERVER['REQUEST_URI'];

        return substr( $current_url, 0, stripos( $current_url, basename( __FILE__ ) ) - 1 );
    }

    public static function redirect_to_home_url() {
        if ( self::get_home_url() != get_option( 'siteurl' ) ) {
            wp_redirect( get_option( 'siteurl' ) . "/" . basename( __FILE__ ) . "?" . array_keys($_GET)[0] );
            exit;
        }
    }

    /**
     * Checks if an IPv4 or IPv6 address is contained in the list of given IPs or subnets.
     *
     * @param string|array $ips List of IPs or subnets (can be a string if only a single one)
     *
     * @return bool
     */
    public static function checkIp($requestIp, $ips)
    {
        if (!is_array($ips)) {
            $ips = [$ips];
        }

        $method = substr_count($requestIp, ':') > 1 ? 'checkIp6' : 'checkIp4';

        foreach ($ips as $ip) {
            if (self::$method($requestIp, $ip)) {
                return true;
            }
        }

        return false;
    }

    /**
     * Compares two IPv4 addresses.
     * In case a subnet is given, it checks if it contains the request IP.
     *
     * @param string $ip IPv4 address or subnet in CIDR notation
     *
     * @return bool Whether the request IP matches the IP, or whether the request IP is within the CIDR subnet
     */
    public static function checkIp4($requestIp, $ip)
    {
        if (!filter_var($requestIp, \FILTER_VALIDATE_IP, \FILTER_FLAG_IPV4)) {
            return false;
        }

        if (stripos($ip, '/') !== false) {
            $ip = explode('/', $ip, 2);
            $address = $ip[0];
            $netmask = $ip[1];

            if ('0' === $netmask) {
                return filter_var($address, \FILTER_VALIDATE_IP, \FILTER_FLAG_IPV4);
            }

            if ($netmask < 0 || $netmask > 32) {
                return false;
            }
        } else {
            $address = $ip;
            $netmask = 32;
        }

        if (false === ip2long($address)) {
            return false;
        }

        return 0 === substr_compare(sprintf('%032b', ip2long($requestIp)), sprintf('%032b', ip2long($address)), 0, $netmask);
    }

    /**
     * Compares two IPv6 addresses.
     * In case a subnet is given, it checks if it contains the request IP.
     *
     * @author David Soria Parra <dsp at php dot net>
     *
     * @see https://github.com/dsp/v6tools
     *
     * @param string $ip IPv6 address or subnet in CIDR notation
     *
     * @return bool
     */
    public static function checkIp6($requestIp, $ip)
    {
        if (!((\extension_loaded('sockets') && \defined('AF_INET6')) || @inet_pton('::1'))) {
            return false;
        }

        if (stripos($ip, '/') !== false) {
            $ip = explode('/', $ip, 2);
            $address = $ip[0];
            $netmask = $ip[1];

            if ('0' === $netmask) {
                return (bool) unpack('n*', @inet_pton($address));
            }

            if ($netmask < 1 || $netmask > 128) {
                return false;
            }
        } else {
            $address = $ip;
            $netmask = 128;
        }

        $bytesAddr = unpack('n*', @inet_pton($address));
        $bytesTest = unpack('n*', @inet_pton($requestIp));

        if (!$bytesAddr || !$bytesTest) {
            return false;
        }

        for ($i = 1, $ceil = ceil($netmask / 16); $i <= $ceil; ++$i) {
            $left = $netmask - 16 * ($i - 1);
            $left = ($left <= 16) ? $left : 16;
            $mask = ~(0xFFFF >> $left) & 0xFFFF;
            if (($bytesAddr[$i] & $mask) != ($bytesTest[$i] & $mask)) {
                return false;
            }
        }

        return true;
    }
    public static function get_server_ip() {
        $server_ip = $_SERVER['SERVER_ADDR'];

        if ( self::checkIp( $server_ip, ['10.0.0.0/8', '172.16.0.0/12', '192.168.0.0/16', 'fd00::/8'] ) ) {
            $server_ip = gethostbyname( gethostname() );
        }

        return $server_ip;
    }

    public static function get_client_ip() {
        $client_ip = $_SERVER['REMOTE_ADDR'];

        if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
            $client_ip = $_SERVER['HTTP_CLIENT_IP'];
        }
        if ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
            $client_ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
        }
        if ( ! empty( $_SERVER['HTTP_CF_CONNECTING_IP'] ) ) {
            $client_ip = $_SERVER['HTTP_CF_CONNECTING_IP'];
        }

        return $client_ip;
    }

    public static function verify_google() {
        $google_ips = get_site_transient( '_upress_autologin_google_ips' );
        if ( empty( $google_ips ) ) {
            $google_ips = file_get_contents( 'https://www.gstatic.com/ipranges/goog.txt' );
            $google_ips = preg_split( '/\r\n|\r|\n/', $google_ips );
            set_site_transient( '_upress_autologin_google_ips', $google_ips, DAY_IN_SECONDS );
        }

        if( self::checkIp( self::get_client_ip(), $google_ips ) || stripos( $_SERVER['HTTP_USER_AGENT'], 'google' ) !== false ) {
            http_response_code(404);
            header($_SERVER["SERVER_PROTOCOL"]." 404 Not Found", true, 404);
            exit;
        }
    }
}

UpressWpAutologin::check_version();
UpressWpAutologin::check_auth();
UpressWpAutologin::redirect_to_home_url();
UpressWpAutologin::verify_google();

$current_url = UpressWpAutologin::get_home_url();

$users          = [];
$sites          = [];
$network_admins = [];

$auth_key          = trim( array_keys($_GET)[0] );
$verification_hash = '';
$server_ip         = UpressWpAutologin::get_server_ip();
$client_ip         = UpressWpAutologin::get_client_ip();

if ( function_exists( 'wp_roles' ) ) {
    $roles = wp_roles()->role_objects;
} else {
    global $wp_roles;
    $roles = $wp_roles->role_objects;
}

uasort( $roles, function ( $a, $b ) {
    if ( 'administrator' == $a->name ) {
        return - 1;
    }
    if ( 'administrator' == $b->name ) {
        return 1;
    }

    return strnatcmp( $a->name, $b->name );
} );

// Load list of users available to login to
if ( is_multisite() ) {
    // Get regular users from all blogs
    // get_sites() not available on wp < 4.6
    if( function_exists( 'get_sites' ) ) {
        $sites = get_sites();
    } else {
        $sites = wp_get_sites();
    }

    foreach ( $sites as $site ) {
        $blog_id    = is_object( $site ) ? $site->blog_id : $site['blog_id'];
        $site_users = get_users( [ 'blog_id' => $blog_id ] );
        $users      = array_merge( $users, $site_users );
    }

    // Get multisite super admins
    $wp_network_admins        = $wpdb->get_results( 'SELECT ID, user_login FROM ' . $wpdb->users );
    $network_admins_usernames = unserialize( $wpdb->get_var( 'SELECT * FROM ' . $wpdb->sitemeta . ' WHERE meta_key = \'site_admins\'', 3 ) );
    $wp_network_admins        = array_filter( $wp_network_admins, function ( $user ) use ( $network_admins_usernames ) {
        return in_array( $user->user_login, $network_admins_usernames );
    } );
    $wp_network_admins        = array_map( function ( $user ) {
        return get_user_by( 'ID', $user->ID );
    }, $wp_network_admins );
    $users                    = array_merge( $users, $wp_network_admins );
} else {
    // This is a normal wordpress install, get all regular users
    $users = get_users( [ 'role__in' => [ 'administrator', 'editor' ], 'number' => 100 ] );
}

// Filter out duplicate users
$mapped_users = [];
$users        = array_filter( $users, function ( $user ) use ( &$mapped_users ) {
    if ( in_array( $user->ID, $mapped_users ) ) {
        return false;
    }
    $mapped_users[] = $user->ID;

    return true;
} );
sort( $users );


if ( count( $_POST ) ) {
    // Check the verification hash
    $upress_auth     = ! empty( $_POST['token'] ) ? trim( $_POST['token'] ) : '';
    $calculated_hash = hash_hmac( 'sha256', $client_ip . $server_ip . $auth_key, 'EoE8mNAT7Ym975yJdNzEob8qS3ijfrONAT7x' );

    if ( empty( $_POST['_wpnonce'] ) || ! wp_verify_nonce( $_POST['_wpnonce'], 'wp-autologin' ) || ! hash_equals( $calculated_hash, $upress_auth ) ) {
        unlink( __FILE__ );
        wp_die( 'Authorization failed: You are not allowed to login at this time.', 403 );
    }

    if ( count( $users ) > 1 ) {
        $user_id    = (int) $_POST['uid'];
        $user       = get_user_by( 'id', $user_id );
        $user_login = $user->user_login;
    } else {
        $user_id    = $users[0]->ID;
        $user_login = $users[0]->user_login;
    }

    $user = wp_set_current_user( $user_id, $user_login );
    wp_set_auth_cookie( $user_id, true );
    do_action( 'wp_login', $user_login, $user );

    wp_redirect( get_admin_url() );
    exit;
} else {
    // Get auth data for current website
    $verify = wp_remote_post( 'https://my4.upress.io/api/autologin/authorize/v2', array(
        'user-agent' => 'uPressAutologin/' . $server_ip,
        'sslverify'  => true,
        'blocking'   => true,
        'body'       => array(
            'v'         => defined( 'AUTOLOGIN_DEV' ) ? AUTOLOGIN_DEV : $auth_key,
            'ip'        => $client_ip,
            'server_ip' => $server_ip,
            'host'      => get_site_url(),
            'dev'       => defined( 'AUTOLOGIN_DEV' ) ? AUTOLOGIN_DEV : ''
        ),
    ) );
    $verify = json_decode( wp_remote_retrieve_body( $verify ), true );
    if ( is_wp_error( $verify ) || ! isset( $verify['hash'] ) ) {
        unlink( __FILE__ );
        wp_die( 'Authorization failed: Request expired.', 401 );
    }
    $verification_hash = $verify['hash'];
}
?>
<!doctype html>
<html>
<head>
    <title>uPress Auto Login</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel='stylesheet' id='dashicons-css'  href='<?php echo get_site_url(); ?>/wp-includes/css/dashicons.min.css?ver=<?php echo $wp_version; ?>' media='all' />
    <link rel='stylesheet' id='buttons-css'  href='<?php echo get_site_url(); ?>/wp-includes/css/buttons.min.css?ver=<?php echo $wp_version; ?>' media='all' />
    <link rel='stylesheet' id='forms-css'  href='<?php echo get_site_url(); ?>/wp-admin/css/forms.min.css?ver=<?php echo $wp_version; ?>' media='all' />
    <link rel='stylesheet' id='l10n-css'  href='<?php echo get_site_url(); ?>/wp-admin/css/l10n.min.css?ver=<?php echo $wp_version; ?>' media='all' />
    <link rel='stylesheet' id='login-css'  href='<?php echo get_site_url(); ?>/wp-admin/css/login.min.css?ver=<?php echo $wp_version; ?>' media='all' />
    <style>
        [hidden] {
            display: none !important;
        }

        .login * {
            margin: 0;
            padding: 0;
        }

        .login form {
            margin-top: 20px;
            margin-left: 16px;
            margin-right: 16px;
            padding: 26px 24px 46px;
            font-weight: 400;
            overflow: hidden;
            background: #fff;
            -webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.13);
            box-shadow: 0 1px 3px rgba(0,0,0,0.13);
        }
        #login {
            max-width:  600px;
            width: 100%;
        }
        input.readonly,input[readonly],select.readonly,select[readonly],textarea.readonly,textarea[readonly ] {
            background: rgba(255,255,255,.5);
            border-color: rgba(222,222,222,.75);
            -webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.04);
            box-shadow: inset 0 1px 2px rgba(0,0,0,.04);
            color: rgba(51,51,51,.5);
            pointer-events: none;
        }

        .wp-core-ui select.select {
            margin: 10px 0;
            border-radius: 0;
            border: 1px solid #ddd;
            -webkit-box-shadow: inset 0 1px 2px rgba( 0, 0, 0, 0.07 );
            box-shadow: inset 0 1px 2px rgba( 0, 0, 0, 0.07 );
            background-color: #fbfbfb;
            color: #32373c;
            outline: none;
            height: 38px;
        }
        button > svg {
            vertical-align: text-bottom;
            height: 1em;
            width: 1em;
            animation: spin 0.5s infinite linear;
        }

        @keyframes spin {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }
        @-webkit-keyframes spin {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }
    </style>
</head>
<body class="login login-action-login wp-core-ui  locale-en-us">
<div id="login">
    <h1>
        <a href="https://my.upress.co.il/"
           title="Powered by uPress"
           tabindex="-1"
           rel="noopener nofollow"
           target="_blank"
           style="background-image: none, url(''); width: 160px; background-size: 140px">
            uPress Auto Login
        </a>
    </h1>

    <form method="post">
        <?php wp_nonce_field( 'wp-autologin' ); ?>
        <input type="hidden" name="token" value="<?php echo esc_attr( $verification_hash ); ?>">

        <div>
            <label for="uid" style="font-weight: bold">Login as</label><br/>
            <select id="uid" name="uid" class="select" <?php echo count( $users ) <= 1 ? 'disabled' : ''; ?> style="width: 100%; max-width: 100%;">
                <?php if ( is_multisite() ) : ?>
                    <optgroup label="Super Administrators">
                        <?php foreach ( $users as $user ) : if ( ! in_array( $user->user_login, $network_admins_usernames ) ) {
                            continue;
                        } ?>
                            <option value="<?php echo esc_attr( $user->ID ); ?>">
                                <?php echo esc_html( $user->user_login ); ?>
                                <?php echo esc_html( $user->user_login !== $user->display_name ? ' (' . $user->display_name . ')' : '' ); ?>
                            </option>
                        <?php endforeach; ?>
                    </optgroup>
                <?php endif; ?>

                <?php foreach ( $roles as $key => $role ) : ?>
                    <?php
                    $role_users = array_filter( $users, function ( $user ) use ( $key ) {
                        return $user->has_cap( $key );
                    } );
                    if ( count( $role_users ) <= 0 ) {
                        continue;
                    }
                    $users = array_udiff($users, $role_users, function($a, $b) { return $a->ID == $b->ID; });
                    ?>
                    <optgroup label="<?php echo esc_attr( ucwords( str_replace( '_', ' ', $role->name ) ) ); ?>">
                        <?php foreach ( $role_users as $user ) : ?>
                            <option value="<?php echo esc_attr( $user->ID ); ?>">
                                <?php echo esc_html( $user->user_login ); ?>
                                <?php echo esc_html( $user->user_login !== $user->display_name ? ' (' . $user->display_name . ')' : '' ); ?>
                            </option>
                        <?php endforeach; ?>
                    </optgroup>
                <?php endforeach; ?>
            </select>
        </div>

        <p class="submit">
            <button name="wp-submit" id="wp-submit" class="button button-primary button-large" onclick="setTimeout((function() { this.disabled = true; this.querySelector('svg').removeAttribute('hidden')}).bind(this), 100)">
                <svg width="24" height="24" viewBox="0 0 24 24" hidden><path fill="currentColor" d="M12,4V2A10,10 0 0,0 2,12H4A8,8 0 0,1 12,4Z" /></svg>
                Login
            </button>
        </p>
    </form>
</div>

<div class="clear"></div>
</body>
</html>