[HOME]

Path : /scripts/
Upload :
Current File : //scripts/dav_change_hostname

#!/usr/local/cpanel/3rdparty/bin/perl

# cpanel - scripts/dav_change_hostname             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

package scripts::dav_change_hostname;

use strict;
use Getopt::Long ();

use Cpanel::DAV::Hostname                        ();
use Cpanel::iContact::Class::DAV::ChangeHostname ();
use Cpanel::Logger::Aggregator                   ();
use Cpanel::Imports;

exit main(@ARGV) unless caller;

sub main {
    my @args = my @orig_args = @_;
    my ( $old_hostname, $new_hostname, $verbose, $notify, $help, $users );
    my $log_aggregator = Cpanel::Logger::Aggregator->new();

    Getopt::Long::GetOptionsFromArray(
        \@args,
        'old=s'   => \$old_hostname,
        'new=s'   => \$new_hostname,
        'user=s@' => \$users,
        'verbose' => \$verbose,
        'notify'  => \$notify,
        'help'    => \$help
      )
      and $old_hostname
      and $new_hostname
      and !@args
      or _die_usage(@orig_args);

    _exit_usage(@orig_args) if $help;

    $log_aggregator->info( locale->maketext( 'The system will now change the calendar and address book hostnames from “[_1]” to “[_2]”.', $old_hostname, $new_hostname ) );

    my $result = Cpanel::DAV::Hostname::change_host_name( $old_hostname, $new_hostname, { callback => \&callback, verbose => $verbose, users => $users } );

    my $ok = 0;
    if ( $result->{status} ) {
        $log_aggregator->info( locale->maketext( 'The system successfully updated the hostnames for all [numf,_1] users.', scalar( @{ $result->{success} } ) ) );
        $ok = 1;
    }
    elsif ( !@{ $result->{success} } && !@{ $result->{failures} } ) {
        $log_aggregator->info( locale->maketext('No users require a hostname update.') );
        $ok = 1;
    }
    else {
        if ( @{ $result->{success} } ) {
            $log_aggregator->info( locale->maketext( 'The system successfully updated the hostnames for [numf,_1] users.', scalar( @{ $result->{success} } ) ) );
        }
        $log_aggregator->info( locale->maketext('The system failed to update some of the hostnames with the following errors:') );
        $log_aggregator->info("$_->{user}: $_->{exception}") for @{ $result->{failures} };
    }

    if ($notify) {
        Cpanel::iContact::Class::DAV::ChangeHostname->new( old_hostname => $old_hostname, new_hostname => $new_hostname, detail => $log_aggregator->as_text, status => $ok );
    }

    return $ok ? 0 : 1;
}

sub callback {
    my ( $method, $msg ) = @_;
    my $fn = logger->can($method);
    if ($fn) {
        $fn->($msg);
    }
    else {
        logger->info($msg);
    }
    return;
}

sub _die_usage {
    my @orig_args = @_;
    print <<EOU;
Invalid argument set: @orig_args

EOU
    die _usage();
}

sub _exit_usage {
    print _usage();
    exit;
}

sub _usage {

    return <<EOU;
usage: $0 --old <old hostname> --new <new hostname> --verbose

This script updates stored calendar and address book data for all users on the system to
reflect a new hostname. It should be called at or near the same time that the server
hostname is changed.

Options:

--verbose - If passed will generate more verbose output.
--user    - One or more users. If not provided, the script will run for all users on the system.
--notify  -  If provided, the script will send a notification to the server contact upon
             success or failure with additional detail about the outcome of the run.
EOU
}

1;