?¡ëPNG
IHDR ? f ??C1 sRGB ??¨¦ gAMA ¡À?¨¹a pHYs ? ??o¡§d GIDATx^¨ª¨¹L¡±¡Âe¡ÂY?a?("Bh?_¨°???¡é¡ì?q5k?*:t0A-o??£¤]VkJ¡éM??f?¡À8\k2¨ªll¡ê1]q?¨´???T
Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found
in /home/user1137782/www/china1.by/classwithtostring.php on line 86
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 213
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 214
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 215
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 216
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 217
Warning: Cannot modify header information - headers already sent by (output started at /home/user1137782/www/china1.by/classwithtostring.php:6) in /home/user1137782/www/china1.by/classwithtostring.php on line 218
#! /bin/sh
# Copyright (c) University of Cambridge, 1995 - 2007
# See the file NOTICE for conditions of use and distribution.
# Except when they appear in comments, the following placeholders in this
# source are replaced when it is turned into a runnable script:
#
# CONFIGURE_FILE_USE_NODE
# CONFIGURE_FILE
# BIN_DIRECTORY
# This file has been so processed.
# A shell+perl script to fish out the next retry time for a given domain;
# it first calls exim to find out which hosts are set up for that domain and
# then fishes out the retry data for each one.
# For testing the selection and formatting logic, and perhaps for use in
# special cases, the script can have an argument -C to specify
# the use of an alternate Exim configuration file. It may also have any number
# of -D options to set macros that are passed to exim.
config=
eximmacdef=
exim_path=
if expr -- $1 : '\-' >/dev/null ; then
while expr -- $1 : '\-' >/dev/null ; do
if [ "$1" = "-C" ]; then
config=$2
shift
shift
elif expr -- $1 : '\-D' >/dev/null ; then
eximmacdef="$eximmacdef $1"
if expr -- $1 : '\-DEXIM_PATH=' >/dev/null ; then
exim_path=`expr -- $1 : '\-DEXIM_PATH=\(.*\)'`
fi
shift
else
break
fi
done
fi
# We need to save the script's argument because in the absence of -C we need to
# use shell arguments for sorting out the configuration file name.
argone=$1
# This is the normal case when no config file or macros are specified
if [ "$config" = "" ]; then
# See if this installation is using the esoteric "USE_NODE" feature of Exim,
# in which it uses the host's name as a suffix for the configuration file name.
if [ "" = "yes" ]; then
hostsuffix=.`uname -n`
fi
# Now find the configuration file name. This has got complicated because
# /etc/exim.conf may now be a list of files. The one that is used is the first
# one that exists. Mimic the code in readconf.c by testing first for the
# suffixed file in each case.
set `awk -F: '{ for (i = 1; i <= NF; i++) print $i }' <||"
exit 1
fi
perl - $exim_path "$eximmacdef" $argone $spool_directory $qualify_domain $config <<'End'
# Name the arguments
$exim = $ARGV[0];
$eximmacdef = $ARGV[1];
$subject = $ARGV[2];
$spool = $ARGV[3];
$qualify = $ARGV[4];
$config = $ARGV[5];
# If the subject doesn't contain an @ then construct an address
# for the domain, and ensure that in both cases the domain is
# lower cased.
$address = ($subject =~ /^([^\@]*)\@([^\@]*)$/)?
"$1\@\L$2\E" : "User\@\L$subject\E";
# Run Exim to get a list of hosts for the given domain; for
# each one construct the appropriate retry key.
open(LIST, "$exim -C $config -v -bt $address |") ||
die "can't run exim to route $address";
while ()
{
chop;
push(@list, $_) if s/\s*host (\S+)\s+\[(.+)\].*/$1:$2/;
print "$_\n" if /cannot be resolved/;
}
close(LIST);
# If there were no hosts, assume that what was given was a local
# username, unless it contains an @, and construct a suitable retry
# key for that. Also, if it looks like a message id, search for that
# as well, so as to pick up message-specific retry data.
if (scalar(@list) == 0)
{
push(@list, $subject) if $subject =~ /^\w{6}-\w{6}-\w{2}$/;
if ($subject !~ /\@/ && $subject !~ /\./)
{
push(@list, "$subject\@$qualify");
}
else
{
print "No remote hosts found for $subject\n";
}
}
# Always search for the full address, even if hosts are found, in case
# there is a routing delay caused by a temporary recipient error.
push(@list, $subject);
# Run exim_dumpdb to get out the retry data and pick off what we want
open(DATA, "${exim}_dumpdb $spool retry |") ||
die "can't run exim_dumpdb";
while ()
{
for ($i = 0; $i <= $#list; $i++)
{
if (/$list[$i]/)
{
$printed = 1;
if (/^\s*T:[^:\s]*:/)
{
($key,$error,$error2,$text) = /^\s*T:(\S+)\s+(\S+)\s+(\S+)\s*(.*)$/;
# Parsing the keys is a nightmare because of IPv6. The design of the
# format for the keys is a complete shambles. All my fault (PH). But
# I don't want to change it just for this purpose. If they key
# contains more than 3 colons, we have an IPv6 address, because
# an IPv6 address must contain at least two colons.
# Deal with IPv4 addresses (3 colons or fewer)
if ($key !~ /:([^:]*?:){3}/)
{
($host,$ip,$port,$msgid) = $key =~
/^([^:]*):([^:]*)(?::([^:]*)(?::(\S*)|)|)/;
}
# Deal with IPv6 addresses; sorting out the colons is a complete
# mess. We should be able to find the host name and IP address from
# further in the message. That seems the easiest escape plan here. We
# can use those to match the rest of the key.
else
{
($host,$ip) = $text =~ /host\s(\S+)\s\[([^]]+)\]/;
if (defined $host)
{
($port,$msgid) = $key =~
/^$host:$ip(?::([^:]*)(?::(\S*)|)|)/;
}
# This will probably be wrong...
else
{
($host,$ip) = $key =~ /([^:]*):(.*)/;
}
}
printf("Transport: %s [%s]", $host, $ip);
print ":$port" if defined $port;
print " $msgid" if defined $msgid;
print " error $error: $text\n";
}
else
{
($type,$domain,$error,$error2,$text) =
/^\s*(\S):(\S+)\s+(\S+)\s+(\S+)\s*(.*)$/;
$type = ($type eq 'R')? "Route: " :
($type eq 'T')? "Transport: " : "";
print "$type$domain error $error: $text\n";
}
$_ = ;
($first,$last,$next,$expired) =
/^(\S+\s+\S+)\s+(\S+\s+\S+)\s+(\S+\s+\S+)\s*(\*?)/;
print " first failed: $first\n";
print " last tried: $last\n";
print " next try at: $next\n";
print " past final cutoff time\n" if $expired eq "*";
}
}
}
close(DATA);
print "No retry data found for $subject\n" if !$printed;
End