#!/usr/local/cpanel/3rdparty/bin/perl
# cpanel - scripts/unlink_service_account 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::unlink_service_account;
use strict;
use warnings;
use Cpanel::AcctUtils::DomainOwner::Tiny ();
use Cpanel::JSON ();
use Cpanel::SafeRun::Errors ();
use Cpanel::Usage ();
exit( run(@ARGV) ) unless caller();
sub run {
my (@args) = @_;
my ( $user, $service, $dismiss );
my $opts = {
'user' => \$user,
'service' => \$service,
'dismiss' => \$dismiss,
};
Cpanel::Usage::wrap_options( \@args, \&usage, $opts );
usage() unless ( $user && $service );
my ( $local, $domain ) = split( /\@/, $user, 2 );
usage() unless ( $local && $domain );
my $owner = Cpanel::AcctUtils::DomainOwner::Tiny::getdomainowner( $domain, { default => '' } );
if ( !$owner ) {
print "Cannot find the owner of $domain, try rebuilding /etc/userdomains first with /usr/local/cpanel/scripts/updateuserdomains\n";
return 1;
}
# Use bin/uapi instead of Cpanel::API::execute because this script is uncompiled, and some of the
# API code we need is unshipped.
my $json = Cpanel::SafeRun::Errors::saferunallerrors(
'/usr/local/cpanel/bin/uapi',
!$< ? ( '--user', $owner ) : (), # if we're running as root, we need to tell it which user to run the API call for
'--output', 'json',
'UserManager', 'unlink_service_account',
map { join '=', @$_ } ( [ username => $local ], [ domain => $domain ], [ service => $service ], [ dismiss => $dismiss ] )
);
my $response = Cpanel::JSON::Load($json);
if ( !$response->{result}{status} ) {
print "$_\n" foreach ( @{ $response->{result}{errors} } );
return 1;
}
return 0;
}
sub usage {
my $prog = $0;
print <<USAGE;
$0 [options] - Unlink a service account from a sub-account.
This script may be run either as root or by a cPanel user.
OPTIONS
--user USER\@DOMAIN
Full login of the sub-account.
--service SERVICE
Service to unlink from the user (ftp, webdisk, or email)
--dismiss
Also dismiss the merge prompt, so this account will not show up as as merge candidate
Sample usages:
> $0 --user test\@domain1.example --service ftp
> $0 --user test3\@domain1.example --service email
USAGE
exit 0;
}
1;