Current File : /home/pacjaorg/public_html/kmm/libraries/src/Console/ExtensionDiscoverCommand.php
<?php

/**
 * Joomla! Content Management System
 *
 * @copyright  (C) 2021 Open Source Matters, Inc. <https://www.joomla.org>
 * @license    GNU General Public License version 2 or later; see LICENSE.txt
 */

namespace Joomla\CMS\Console;

use Joomla\Console\Command\AbstractCommand;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\Console\Style\SymfonyStyle;

// phpcs:disable PSR1.Files.SideEffects
\defined('JPATH_PLATFORM') or die;
// phpcs:enable PSR1.Files.SideEffects

/**
 * Console command for discovering extensions
 *
 * @since  4.0.0
 */
class ExtensionDiscoverCommand extends AbstractCommand
{
    /**
     * The default command name
     *
     * @var    string
     *
     * @since  4.0.0
     */
    protected static $defaultName = 'extension:discover';

    /**
     * Stores the Input Object
     *
     * @var    InputInterface
     *
     * @since  4.0.0
     */
    private $cliInput;

    /**
     * SymfonyStyle Object
     *
     * @var    SymfonyStyle
     *
     * @since  4.0.0
     */
    private $ioStyle;

    /**
     * Configures the IO
     *
     * @param   InputInterface   $input   Console Input
     * @param   OutputInterface  $output  Console Output
     *
     * @return  void
     *
     * @since   4.0.0
     *
     */
    private function configureIO(InputInterface $input, OutputInterface $output): void
    {
        $this->cliInput = $input;
        $this->ioStyle  = new SymfonyStyle($input, $output);
    }

    /**
     * Initialise the command.
     *
     * @return  void
     *
     * @since   4.0.0
     */
    protected function configure(): void
    {
        $help = "<info>%command.name%</info> is used to discover extensions
		\nUsage:
		\n  <info>php %command.full_name%</info>";

        $this->setDescription('Discover extensions');
        $this->setHelp($help);
    }

    /**
     * Used for discovering extensions
     *
     * @return  integer  The count of discovered extensions
     *
     * @throws  \Exception
     *
     * @since   4.0.0
     */
    public function processDiscover(): int
    {
        $app = $this->getApplication();

        $mvcFactory = $app->bootComponent('com_installer')->getMVCFactory();

        $model = $mvcFactory->createModel('Discover', 'Administrator');

        return $model->discover();
    }

    /**
     * Used for finding the text for the note
     *
     * @param   int  $count   The count of installed Extensions
     *
     * @return  string  The text for the note
     *
     * @since   4.0.0
     */
    public function getNote(int $count): string
    {
        if ($count < 1) {
            return 'No extensions were discovered.';
        } elseif ($count === 1) {
            return $count . ' extension has been discovered.';
        } else {
            return $count . ' extensions have been discovered.';
        }
    }

    /**
     * Internal function to execute the command.
     *
     * @param   InputInterface   $input   The input to inject into the command.
     * @param   OutputInterface  $output  The output to inject into the command.
     *
     * @return  integer  The command exit code
     *
     * @since   4.0.0
     */
    protected function doExecute(InputInterface $input, OutputInterface $output): int
    {
        $this->configureIO($input, $output);

        $count = $this->processDiscover();
        $this->ioStyle->title('Discover Extensions');
        $this->ioStyle->note($this->getNote($count));

        return Command::SUCCESS;
    }
}
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!