#!/usr/bin/perl
# cpanel - scripts/cpan_config 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
BEGIN { unshift @INC, '/usr/local/cpanel'; }
use strict;
use warnings; # DO NOT REMOVE. NEEDED FOR PATH LOOKUP
use Cpanel::CleanINC ();
use Cpanel::cPCPAN ();
use Cpanel::cPCPAN::Config ();
if ( $> != 0 ) {
die "Unable to set system CPAN::Config. Permission denied.\n";
}
my $cpanbasedir = '/home';
my $cpan = { 'basedir' => $cpanbasedir };
my $cpan_config = Cpanel::cPCPAN::fetch_config($cpan);
my $path = $INC{'warnings.pm'};
$path =~ s/\/warnings\.pm$//;
if ( !-e $path . '/CPAN' ) {
mkdir $path . '/CPAN';
}
my $cpan_config_file = $path . '/CPAN/Config.pm';
my $now = time;
if ( -e $cpan_config_file ) {
rename $cpan_config_file, $cpan_config_file . '.' . $now or die "Unable to archive $cpan_config_file: $!";
print "Existing $cpan_config_file archived as ${cpan_config_file}.${now}\n";
}
if ( open my $conf_fh, '>', $cpan_config_file ) {
my $localtime = localtime($now);
print {$conf_fh} <<"EOM";
# This CPAN::Config was automatically generated using /usr/local/cpanel/scripts/cpan_config
# at $localtime
#
# If this Config.pm replaced an existing version, then it would be located at:
# ${cpan_config_file}.${now}
# This is CPAN.pm's systemwide configuration file. This file provides
# defaults for users, and the values can be changed in a per-user
# configuration file.
EOM
print {$conf_fh} qq{\$CPAN::Config = \{\n};
foreach my $key ( sort keys %{$cpan_config} ) {
print {$conf_fh} " '$key' => ", neatvalue( $cpan_config->{$key} ), ",\n";
}
print {$conf_fh} "};\n1;\n__END__\n";
close $conf_fh;
}
# stolen from MakeMaker; not taking the original because it is buggy;
# bugreport will have to say: keys of hashes remain unquoted and can
# produce syntax errors
sub neatvalue {
my ($value) = @_;
return 'undef' unless defined $value;
my $ref_type = ref $value;
unless ($ref_type) {
$value =~ s/\\/\\\\/g;
return "q[$value]";
}
if ( $ref_type eq 'ARRAY' ) {
my ( @m, @neat );
push @m, '[';
foreach my $elem (@$value) {
push @neat, "q[$elem]";
}
push @m, join ', ', @neat;
push @m, ']';
return join '', @m;
}
return "$value" unless $ref_type eq 'HASH';
my ( @m, $key, $val );
while ( ( $key, $val ) = each %$value ) {
last unless defined $key; # cautious programming in case (undef,undef) is true
push( @m, "q[$key]=>" . neatvalue($val) );
}
return '{ ' . join( ', ', @m ) . ' }';
}