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;
|
|
|
|
|
2012-01-17 09:29:54 +00:00
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
2012-01-16 13:14:15 +00:00
|
|
|
use Symfony\Component\Console\Helper\HelperSet;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Input/Output helper interface.
|
|
|
|
*
|
|
|
|
* @author François Pluchino <francois.pluchino@opendisplay.com>
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
interface IOInterface extends OutputInterface
|
2012-01-16 13:14:15 +00:00
|
|
|
{
|
2012-01-17 09:29:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Is this input means interactive?
|
|
|
|
*
|
|
|
|
* @return Boolean
|
|
|
|
*/
|
|
|
|
function isInteractive();
|
|
|
|
|
2012-01-16 13:14:15 +00:00
|
|
|
/**
|
|
|
|
* Overwrites a previous message to the output.
|
|
|
|
*
|
|
|
|
* @param string|array $messages The message as an array of lines of a single string
|
|
|
|
* @param integer $size The size of line
|
|
|
|
* @param Boolean $newline Whether to add a newline or not
|
|
|
|
* @param integer $type The type of output
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function overwrite($messages, $size = 80, $newline = false, $type = 0);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Overwrites a previous message to the output and adds a newline at the end.
|
|
|
|
*
|
|
|
|
* @param string|array $messages The message as an array of lines of a single string
|
|
|
|
* @param integer $size The size of line
|
|
|
|
* @param integer $type The type of output
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function overwriteln($messages, $size = 80, $type = 0);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asks a question to the user.
|
|
|
|
*
|
|
|
|
* @param string|array $question The question to ask
|
|
|
|
* @param string $default The default answer if none is given by the user
|
|
|
|
*
|
|
|
|
* @return string The user answer
|
|
|
|
*
|
|
|
|
* @throws \RuntimeException If there is no data to read in the input stream
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
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.
|
|
|
|
*
|
|
|
|
* @param string|array $question The question to ask
|
|
|
|
* @param Boolean $default The default answer if the user enters nothing
|
|
|
|
*
|
|
|
|
* @return Boolean true if the user has confirmed, false otherwise
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
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.
|
|
|
|
*
|
|
|
|
* @param string|array $question The question to ask
|
|
|
|
* @param callback $validator A PHP callback
|
|
|
|
* @param integer $attempts Max number of times to ask before giving up (false by default, which means infinite)
|
|
|
|
* @param string $default The default answer if none is given by the user
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*
|
|
|
|
* @throws \Exception When any of the validators return an error
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function askAndValidate($question, $validator, $attempts = false, $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-01-17 09:29:54 +00:00
|
|
|
function askAndHideAnswer($question);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the last username entered.
|
|
|
|
*
|
|
|
|
* @return string The username
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function getLastUsername();
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the last password entered.
|
|
|
|
*
|
|
|
|
* @return string The password
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function getLastPassword();
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all authentification informations entered.
|
|
|
|
*
|
|
|
|
* @return array The map of authentification
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function getAuthentifications();
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Verify if the repository has a authentification informations.
|
|
|
|
*
|
|
|
|
* @param string $repositoryName The unique name of repository
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function hasAuthentification($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-01-17 09:29:54 +00:00
|
|
|
function getAuthentification($repositoryName);
|
2012-01-16 13:14:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the authentification informations for the repository.
|
|
|
|
*
|
|
|
|
* @param string $repositoryName The unique name of repository
|
|
|
|
* @param string $username The username
|
|
|
|
* @param string $password The password
|
|
|
|
*/
|
2012-01-17 09:29:54 +00:00
|
|
|
function setAuthentification($repositoryName, $username, $password = null);
|
2012-01-16 13:14:15 +00:00
|
|
|
}
|