KUJUNTI.ID MINISH3LL
Path : /scripts/
(S)h3ll Cr3at0r :
F!le Upl0ad :

B-Con CMD Config cPanel C-Rdp D-Log Info Jump Mass Ransom Symlink vHost Zone-H

Current File : //scripts/installsqlite3


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

# cpanel - scripts/installsqlite3                  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::Logger  ();
use Cpanel::SysPkgs ();
use Cpanel::Usage   ();
use Cpanel::Rlimit  ();

run(@ARGV) unless caller();

sub run {

    my $force;
    Cpanel::Usage::wrap_options( \@ARGV, \&usage, { 'force' => \$force } );

    my $logger = Cpanel::Logger->new();

    if ( has_sqlite3() && !$force ) {
        $logger->info("Sqlite3 is already installed.");
        return;
    }

    # Case 64238: yum can consume a lot of memory on 64-bit systems, and the global maxmem setting gets in the way
    Cpanel::Rlimit::set_rlimit_to_infinity();

    my $syspkgs = Cpanel::SysPkgs->new();
    if ( !$syspkgs ) { $logger->die("Could not create SysPkgs object"); }

    $syspkgs->install(
        'pkglist' => [
            'sqlite',        'sqlite-devel', 'sqlite-dev', 'sqlite3',
            'sqlite3-devel', 'sqlite3-dev'
        ]
    );

    if ( has_sqlite3() ) {
        $logger->info("Sqlite3 was installed successfully using the OS package manager");
        return;
    }

    $logger->info("Failed to install sqlite3 using operating system package manager.");
    exit(1);
}

sub has_sqlite3 {
    foreach my $path ( '/usr/', '/usr/local/' ) {
        return 1 if ( -x "${path}bin/sqlite3" && -e "${path}include/sqlite3.h" );
    }
    return 0;
}

sub usage {
    print <<EO_USAGE;
installsqlite3 [options]

    Options:
      --help       Brief help message
      --force      Force installation even if sqlite3 already appears installed

EO_USAGE
    exit 0;
}

© KUJUNTI.ID