[HOME]

Path : /scripts/
Upload :
Current File : //scripts/sync_child_accounts

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

# cpanel - scripts/sync_child_accounts             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::sync_child_accounts;

use cPstrict;

=encoding utf-8

=head1 NAME

scripts/sync_child_accounts

=head1 USAGE

    sync_child_accounts [ --user=$USERNAME | --all | --help ]

=head1 DESCRIPTION

This script synchronizes certain parts of user configuration to the child
account for any distributed cPanel accounts on the server.

Ordinarily this script is unnecessary; it’s mostly useful if something
goes wrong that causes parent and child accounts to go out of sync.
It will not harm anything to run this script, though.

=cut

#----------------------------------------------------------------------

use parent 'Cpanel::HelpfulScript';

use constant _OPTIONS => (
    'all',
    'user=s',
);

use Cpanel::LinkedNode::SyncChildAccounts ();

__PACKAGE__->new(@ARGV)->run() if !caller;

sub run ($self) {
    Cpanel::LinkedNode::SyncChildAccounts::sync_child_accounts(
        output_obj => $self->get_output_object(),
        usernames  => [ $self->_get_usernames() ],
    );

    return;
}

sub _get_usernames ($self) {
    my $username = $self->getopt('user');

    if ( $self->getopt('all') ) {
        if ($username) {
            die $self->help('Give a “--user” or “--all”, not both.');
        }

        require Cpanel::Config::Users;
        return Cpanel::Config::Users::getcpusers();
    }
    elsif ($username) {
        return $username;
    }

    die $self->help('Give a “--user” or “--all”.');
}

1;