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>