Merge branch 'master' into 2.0
commit
e15f7d6bb7
|
@ -336,7 +336,7 @@ EOF;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addClassMapCode($filesystem, $basePath, $vendorPath, $dir, $blacklist = null, $namespaceFilter = null, $autoloadType = null, array $classMap, array &$ambiguousClasses)
|
private function addClassMapCode($filesystem, $basePath, $vendorPath, $dir, $blacklist, $namespaceFilter, $autoloadType, array $classMap, array &$ambiguousClasses)
|
||||||
{
|
{
|
||||||
foreach ($this->generateClassMap($dir, $blacklist, $namespaceFilter, $autoloadType) as $class => $path) {
|
foreach ($this->generateClassMap($dir, $blacklist, $namespaceFilter, $autoloadType) as $class => $path) {
|
||||||
$pathCode = $this->getPathCode($filesystem, $basePath, $vendorPath, $path).",\n";
|
$pathCode = $this->getPathCode($filesystem, $basePath, $vendorPath, $path).",\n";
|
||||||
|
|
|
@ -323,7 +323,7 @@ class Installer
|
||||||
1 === $fundingCount ? '' : 's',
|
1 === $fundingCount ? '' : 's',
|
||||||
1 === $fundingCount ? 'is' : 'are'
|
1 === $fundingCount ? 'is' : 'are'
|
||||||
),
|
),
|
||||||
'<info>Use the composer fund command to find out more!</info>',
|
'<info>Use the `composer fund` command to find out more!</info>',
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -134,6 +134,17 @@ class PathRepository extends ArrayRepository implements ConfigurableRepositoryIn
|
||||||
$urlMatches = $this->getUrlMatches();
|
$urlMatches = $this->getUrlMatches();
|
||||||
|
|
||||||
if (empty($urlMatches)) {
|
if (empty($urlMatches)) {
|
||||||
|
if (preg_match('{[*{}]}', $this->url)) {
|
||||||
|
$url = $this->url;
|
||||||
|
while (preg_match('{[*{}]}', $url)) {
|
||||||
|
$url = dirname($url);
|
||||||
|
}
|
||||||
|
// the parent directory before any wildcard exists, so we assume it is correctly configured but simply empty
|
||||||
|
if (is_dir($url)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
throw new \RuntimeException('The `url` supplied for the path (' . $this->url . ') repository does not exist');
|
throw new \RuntimeException('The `url` supplied for the path (' . $this->url . ') repository does not exist');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -429,6 +429,29 @@ class GitLabDriver extends VcsDriver
|
||||||
if ($fetchingRepoData) {
|
if ($fetchingRepoData) {
|
||||||
$json = $response->decodeJson();
|
$json = $response->decodeJson();
|
||||||
|
|
||||||
|
// Accessing the API with a token with Guest (10) access will return
|
||||||
|
// more data than unauthenticated access but no default_branch data
|
||||||
|
// accessing files via the API will then also fail
|
||||||
|
if (!isset($json['default_branch']) && isset($json['permissions'])) {
|
||||||
|
$this->isPrivate = $json['visibility'] !== 'public';
|
||||||
|
|
||||||
|
$moreThanGuestAccess = false;
|
||||||
|
// Check both access levels (e.g. project, group)
|
||||||
|
// - value will be null if no access is set
|
||||||
|
// - value will be array with key access_level if set
|
||||||
|
foreach ($json['permissions'] as $permission) {
|
||||||
|
if ($permission && $permission['access_level'] > 10) {
|
||||||
|
$moreThanGuestAccess = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$moreThanGuestAccess) {
|
||||||
|
$this->io->writeError('<warning>GitLab token with Guest only access detected</warning>');
|
||||||
|
|
||||||
|
return $this->attemptCloneFallback();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// force auth as the unauthenticated version of the API is broken
|
// force auth as the unauthenticated version of the API is broken
|
||||||
if (!isset($json['default_branch'])) {
|
if (!isset($json['default_branch'])) {
|
||||||
if (!empty($json['id'])) {
|
if (!empty($json['id'])) {
|
||||||
|
|
|
@ -53,7 +53,7 @@ Installing dependencies from lock file (including require-dev)
|
||||||
Package operations: 3 installs, 0 updates, 0 removals
|
Package operations: 3 installs, 0 updates, 0 removals
|
||||||
Generating autoload files
|
Generating autoload files
|
||||||
2 packages you are using are looking for funding.
|
2 packages you are using are looking for funding.
|
||||||
Use the composer fund command to find out more!
|
Use the `composer fund` command to find out more!
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
Installing b/b (1.0.0)
|
Installing b/b (1.0.0)
|
||||||
Installing d/d (1.0.0)
|
Installing d/d (1.0.0)
|
||||||
|
|
Loading…
Reference in New Issue