[HOME]

Path : /scripts/
Upload :
Current File : //scripts/cpservice

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

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

my $init;
if ( exists $ENV{'DEBUG'} ) {

    # In debug mode choice of operating systems are:
    #     centos, redhat, rhel
    $init = Cpanel::Init->new( { 'os' => $ENV{'DEBUG'} } );
}
else {
    $init = Cpanel::Init->new();    # Have the module figure out if the operating system is supported.
}

if ( scalar @ARGV >= 2 && ( $ARGV[1] =~ m/\binstall\b|\buninstall\b|\benable\b|\bdisable\b|\badd\b|\bremove\b/i ) ) {
    my $service   = shift @ARGV;
    my $command   = shift @ARGV;
    my $extra_arg = shift @ARGV;
    my $retval    = $init->run_command_for_one( $command, $service, $extra_arg );

    if ( ref $retval eq 'HASH' ) {
        print $retval->{'message'} . "\n";
        exit( !$retval->{'status'} );
    }
    elsif ($retval) {
        print $command . ' was successful' . "\n";
        exit(0);
    }
    else {
        print $command . ' failed' . "\n";
        exit(1);
    }
}
elsif ( scalar @ARGV == 2 ) {
    my $service = shift @ARGV;
    my $command = shift @ARGV;

    # extend securetmp runtime ( fix several cases related to securetmp #57407, #39252 )
    $init->maximum_time( 60 * 10 ) if $service eq 'securetmp';

    my $retval = $init->run_command( $service, $command );
    print "Command failed: " . $command . "\n" unless $retval->{'status'};
    print $retval->{'message'};

    # need to revert status code to convert into a system code
    #   0 -> error ; 1 -> success
    exit( $retval->{'status'} ? 0 : 1 );
}
else {
    usage();
}

sub usage {
    print 'Usage: ' . $init->prog_name() . ' [ service_name [ start | stop | status | ... ]] | [ service_name [ install | uninstall ]] | [ service_name [ enable [run_levels] | disable [run_levels]]]' . "\n";
}

__END__

=pod

=head1 NAME

cpservice - [Interact with initscripts that are cPanel managed]

=head1 USAGE

    cpservice [ service_name [ start | stop | status | ... ]] | [ service_name [ install | uninstall ]] | [ service_name [ enable|disable ]]

=head1 DESCRIPTION

    This script allows for the control of cPanel managed services. Its interface
    mimics the redhat service command but with more feature specific to cPanel.

=head1 USAGE EXAMPLES

=over 4

=item cpservice install

This command will install initscript in the correct directory
for the running operating system.

=item cpservice checkinstall

This command will configure the system to startup all cpanel managed services at boot up.

=item cpservice service_name command

This command will send the C<command> to the cpanel managed C<service>.

=back

=cut