2012-01-16 13:14:15 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Composer.
|
|
|
|
*
|
|
|
|
* (c) Nils Adermann <naderman@naderman.de>
|
|
|
|
* Jordi Boggiano <j.boggiano@seld.be>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Composer\IO;
|
|
|
|
|
2013-08-18 13:32:34 +00:00
|
|
|
use Composer\Config;
|
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
|
|
|
* The Input/Output helper interface.
|
|
|
|
*
|
|
|
|
* @author François Pluchino <francois.pluchino@opendisplay.com>
|
|
|
|
*/
|
2012-01-17 22:13:35 +00:00
|
|
|
interface IOInterface
|
2012-01-17 22:07:33 +00:00
|
|
|
{
|
2016-01-28 13:41:19 +00:00
|
|
|
const QUIET = 1;
|
|
|
|
const NORMAL = 2;
|
|
|
|
const VERBOSE = 4;
|
|
|
|
const VERY_VERBOSE = 8;
|
|
|
|
const DEBUG = 16;
|
|
|
|
|
2012-01-17 22:07:33 +00:00
|
|
|
/**
|
|
|
|
* Is this input means interactive?
|
|
|
|
*
|
2012-06-23 09:58:18 +00:00
|
|
|
* @return bool
|
2012-01-17 22:07:33 +00:00
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function isInteractive();
|
2012-01-17 09:29:54 +00:00
|
|
|
|
2012-04-01 02:32:00 +00:00
|
|
|
/**
|
2013-04-26 21:23:35 +00:00
|
|
|
* Is this output verbose?
|
2012-04-01 02:32:00 +00:00
|
|
|
*
|
2012-06-23 09:58:18 +00:00
|
|
|
* @return bool
|
2012-04-01 02:32:00 +00:00
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function isVerbose();
|
2012-04-01 02:32:00 +00:00
|
|
|
|
2013-04-26 21:23:35 +00:00
|
|
|
/**
|
|
|
|
* Is the output very verbose?
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isVeryVerbose();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Is the output in debug verbosity?
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isDebug();
|
|
|
|
|
2012-04-26 12:54:34 +00:00
|
|
|
/**
|
|
|
|
* Is this output decorated?
|
|
|
|
*
|
2012-06-23 09:58:18 +00:00
|
|
|
* @return bool
|
2012-04-26 12:54:34 +00:00
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function isDecorated();
|
2012-04-26 12:54:34 +00:00
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
2012-01-17 22:07:33 +00:00
|
|
|
* Writes a message to the output.
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
2016-01-28 13:41:19 +00:00
|
|
|
* @param string|array $messages The message as an array of lines or a single string
|
|
|
|
* @param bool $newline Whether to add a newline or not
|
|
|
|
* @param int $verbosity Verbosity level from the VERBOSITY_* constants
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2016-01-28 13:41:19 +00:00
|
|
|
public function write($messages, $newline = true, $verbosity = self::NORMAL);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
2015-02-06 12:52:44 +00:00
|
|
|
/**
|
|
|
|
* Writes a message to the error output.
|
|
|
|
*
|
2016-01-28 13:41:19 +00:00
|
|
|
* @param string|array $messages The message as an array of lines or a single string
|
|
|
|
* @param bool $newline Whether to add a newline or not
|
|
|
|
* @param int $verbosity Verbosity level from the VERBOSITY_* constants
|
2015-02-06 12:52:44 +00:00
|
|
|
*/
|
2016-01-28 13:41:19 +00:00
|
|
|
public function writeError($messages, $newline = true, $verbosity = self::NORMAL);
|
2015-02-06 12:52:44 +00:00
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
2012-01-17 22:07:33 +00:00
|
|
|
* Overwrites a previous message to the output.
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
2016-01-28 13:41:19 +00:00
|
|
|
* @param string|array $messages The message as an array of lines or a single string
|
|
|
|
* @param bool $newline Whether to add a newline or not
|
|
|
|
* @param int $size The size of line
|
|
|
|
* @param int $verbosity Verbosity level from the VERBOSITY_* constants
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2016-01-28 13:41:19 +00:00
|
|
|
public function overwrite($messages, $newline = true, $size = null, $verbosity = self::NORMAL);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
2015-02-18 09:03:45 +00:00
|
|
|
/**
|
|
|
|
* Overwrites a previous message to the error output.
|
|
|
|
*
|
2016-01-28 13:41:19 +00:00
|
|
|
* @param string|array $messages The message as an array of lines or a single string
|
|
|
|
* @param bool $newline Whether to add a newline or not
|
|
|
|
* @param int $size The size of line
|
|
|
|
* @param int $verbosity Verbosity level from the VERBOSITY_* constants
|
2015-02-18 09:03:45 +00:00
|
|
|
*/
|
2016-01-28 13:41:19 +00:00
|
|
|
public function overwriteError($messages, $newline = true, $size = null, $verbosity = self::NORMAL);
|
2015-02-18 09:03:45 +00:00
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
|
|
|
* Asks a question to the user.
|
|
|
|
*
|
2018-04-12 15:36:57 +00:00
|
|
|
* @param string $question The question to ask
|
|
|
|
* @param string $default The default answer if none is given by the user
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
|
|
|
* @throws \RuntimeException If there is no data to read in the input stream
|
2015-09-28 09:51:14 +00:00
|
|
|
* @return string The user answer
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function ask($question, $default = null);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asks a confirmation to the user.
|
|
|
|
*
|
|
|
|
* The question will be asked until the user answers by nothing, yes, or no.
|
|
|
|
*
|
2018-04-12 15:36:57 +00:00
|
|
|
* @param string $question The question to ask
|
|
|
|
* @param bool $default The default answer if the user enters nothing
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
2012-06-23 09:58:18 +00:00
|
|
|
* @return bool true if the user has confirmed, false otherwise
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function askConfirmation($question, $default = true);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asks for a value and validates the response.
|
|
|
|
*
|
|
|
|
* The validator receives the data to validate. It must return the
|
|
|
|
* validated data when the data is valid and throw an exception
|
|
|
|
* otherwise.
|
|
|
|
*
|
2018-04-12 15:36:57 +00:00
|
|
|
* @param string $question The question to ask
|
|
|
|
* @param callable $validator A PHP callback
|
|
|
|
* @param null|int $attempts Max number of times to ask before giving up (default of null means infinite)
|
|
|
|
* @param mixed $default The default answer if none is given by the user
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
|
|
|
* @throws \Exception When any of the validators return an error
|
2015-09-28 09:51:14 +00:00
|
|
|
* @return mixed
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2015-04-30 10:09:15 +00:00
|
|
|
public function askAndValidate($question, $validator, $attempts = null, $default = null);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asks a question to the user and hide the answer.
|
|
|
|
*
|
|
|
|
* @param string $question The question to ask
|
|
|
|
*
|
|
|
|
* @return string The answer
|
|
|
|
*/
|
2012-05-22 15:13:15 +00:00
|
|
|
public function askAndHideAnswer($question);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
2014-08-12 09:12:07 +00:00
|
|
|
/**
|
|
|
|
* Asks the user to select a value.
|
|
|
|
*
|
2018-04-12 15:36:57 +00:00
|
|
|
* @param string $question The question to ask
|
|
|
|
* @param array $choices List of choices to pick from
|
|
|
|
* @param bool|string $default The default answer if the user enters nothing
|
|
|
|
* @param bool|int $attempts Max number of times to ask before giving up (false by default, which means infinite)
|
|
|
|
* @param string $errorMessage Message which will be shown if invalid value from choice list would be picked
|
|
|
|
* @param bool $multiselect Select more than one value separated by comma
|
2014-08-12 09:12:07 +00:00
|
|
|
*
|
|
|
|
* @throws \InvalidArgumentException
|
2016-02-29 17:32:32 +00:00
|
|
|
* @return int|string|array The selected value or values (the key of the choices array)
|
2014-08-12 09:12:07 +00:00
|
|
|
*/
|
2016-02-29 15:32:49 +00:00
|
|
|
public function select($question, $choices, $default, $attempts = false, $errorMessage = 'Value "%s" is invalid', $multiselect = false);
|
2014-08-12 09:12:07 +00:00
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
2012-11-07 12:33:50 +00:00
|
|
|
* Get all authentication information entered.
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
2012-11-07 12:33:50 +00:00
|
|
|
* @return array The map of authentication data
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2012-11-07 12:33:50 +00:00
|
|
|
public function getAuthentications();
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
2012-11-07 12:33:50 +00:00
|
|
|
* Verify if the repository has a authentication information.
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
|
|
|
* @param string $repositoryName The unique name of repository
|
|
|
|
*
|
2015-09-28 09:51:14 +00:00
|
|
|
* @return bool
|
2012-01-16 13:14:15 +00:00
|
|
|
*/
|
2012-11-07 12:33:50 +00:00
|
|
|
public function hasAuthentication($repositoryName);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the username and password of repository.
|
|
|
|
*
|
|
|
|
* @param string $repositoryName The unique name of repository
|
|
|
|
*
|
|
|
|
* @return array The 'username' and 'password'
|
|
|
|
*/
|
2012-11-07 12:33:50 +00:00
|
|
|
public function getAuthentication($repositoryName);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
2012-11-07 12:33:50 +00:00
|
|
|
* Set the authentication information for the repository.
|
2012-01-16 13:14:15 +00:00
|
|
|
*
|
|
|
|
* @param string $repositoryName The unique name of repository
|
|
|
|
* @param string $username The username
|
|
|
|
* @param string $password The password
|
|
|
|
*/
|
2012-11-07 12:33:50 +00:00
|
|
|
public function setAuthentication($repositoryName, $username, $password = null);
|
2013-08-18 13:32:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads authentications from a config instance
|
|
|
|
*
|
|
|
|
* @param Config $config
|
|
|
|
*/
|
|
|
|
public function loadConfiguration(Config $config);
|
2012-01-16 13:14:15 +00:00
|
|
|
}
|