晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/thread-self/root/scripts/ |
Upload File : |
#!/usr/local/cpanel/3rdparty/bin/perl
# cpanel - scripts/ensure_conf_dir_crt_key Copyright 2022 cPanel, L.L.C.
# All rights reserved.
# copyright@cpanel.net http://cpanel.net
# This code is subject to the cPanel license. Unauthorized copying is prohibited
use strict;
use warnings;
use Cpanel::ConfigFiles::Apache ();
use Cpanel::Hostname ();
use Cpanel::SSLPath ();
use Cpanel::Logger ();
use Cpanel::FileUtils::Copy ();
use Cpanel::FileUtils::Chown ();
my $apacheconf = Cpanel::ConfigFiles::Apache->new();
if ( !-e '/var/cpanel/ssl' ) {
mkdir '/var/cpanel/ssl', 0755;
}
if ( !-e '/var/cpanel/ssl/cpanel' ) {
mkdir '/var/cpanel/ssl/cpanel', 0755;
}
if ( !-e '/var/cpanel/ssl/cpanel/cpanel.pem' && !-e '/var/cpanel/ssl/cpanel/mycpanel.pem' ) {
# When we added the free hostname certificate, checkallsslcerts does quite
# a bit more than the original design which is not what we want here.
require Cpanel::SSLCerts;
Cpanel::SSLCerts::createDefaultSSLFiles( 'service' => 'cpanel' );
}
my $hostname = Cpanel::Hostname::gethostname();
my $ssl_root = Cpanel::SSLPath::getsslroot();
my %certificates = (
'crt' => {
'dir' => $apacheconf->dir_conf() . '/ssl.crt',
'file' => 'server.crt',
},
'key' => {
'dir' => $apacheconf->dir_conf() . '/ssl.key',
'file' => 'server.key',
},
);
foreach my $type ( keys %certificates ) {
my $dir = $certificates{$type}{'dir'};
my $file = $certificates{$type}{'file'};
mkdir $dir if !-d $dir;
my $path = $dir . '/' . $file;
my $initialized = 0;
if ( !-e $path || -z _ ) {
Cpanel::FileUtils::Copy::safecopy( '/var/cpanel/ssl/cpanel/cpanel.pem', $path );
$initialized = 1;
}
else {
if ( open my $look_fh, '<', $path ) {
my $cont = do { local $/; <$look_fh> };
close $look_fh;
if ( $cont =~ m/SKIPME/m ) {
Cpanel::FileUtils::Copy::safecopy( '/var/cpanel/ssl/cpanel/cpanel.pem', $path );
$initialized = 1;
}
}
else {
Cpanel::Logger::logger(
{
'message' => "Unable to read $path: $!",
'level' => 'warn',
'service' => 'ensure_conf_dir_crt_key',
'output' => 1,
'backtrace' => 0,
}
);
}
}
if ( $initialized && $type ne 'key' ) {
# remove key from this .pem
if ( open my $crt_fh, '<', $path ) {
my $cont = do { local $/; <$crt_fh> };
close $crt_fh;
if ( open my $new_fh, '>', $path ) {
$cont =~ s{
-----BEGIN(\s+\w+)*\s+PRIVATE\s+KEY-----
.*
-----END(\s+\w+)*\s+PRIVATE\s+KEY-----
}{}xms;
print {$new_fh} $cont;
close $new_fh;
}
}
}
if ( $type eq 'key' ) {
if ( !-e $ssl_root . '/private/' . $hostname . '.key' || -z _ ) {
Cpanel::FileUtils::Copy::safecopy( $path, $ssl_root . '/private/' . $hostname . '.key' );
}
#fix any possible perm/ownership problems.
for my $p ( $path, $ssl_root . '/private/' . $hostname . '.key' ) {
Cpanel::FileUtils::Chown::check_and_fix_owner_and_permissions_for(
'uid' => 0,
'gid' => 0,
'octal_perms' => 0600,
'path' => $p
);
}
}
else {
if ( !-e $ssl_root . '/certs/' . $hostname . '.crt' || -z _ ) {
Cpanel::FileUtils::Copy::safecopy( $path, $ssl_root . '/certs/' . $hostname . '.crt' );
}
#fix any possible perm/ownership problems.
for my $p ( $path, $ssl_root . '/certs/' . $hostname . '.crt' ) {
Cpanel::FileUtils::Chown::check_and_fix_owner_and_permissions_for(
'uid' => 0,
'gid' => 0,
'octal_perms' => 0644,
'path' => $p
);
}
}
}
# Check for any keys left by the transition between EA3 and EA4 and fix their perms.
if ( -f '/etc/cpanel/ea4/is_ea4' ) {
Cpanel::FileUtils::Chown::check_and_fix_owner_and_permissions_for(
'uid' => 0,
'gid' => 0,
'octal_perms' => 0600,
'path' => '/usr/local/apache/conf/ssl.key/server.key'
);
}
else {
Cpanel::FileUtils::Chown::check_and_fix_owner_and_permissions_for(
'uid' => 0,
'gid' => 0,
'octal_perms' => 0600,
'path' => '/etc/apache2/conf.d/ssl.key/server.key'
);
}