Upstream composer has replaced the 'hash' with a smarter 'content-hash', but instead of re-implementing (or copy-pasting) all of that in MediaWiki we can just compare the dependencies themselves, since that's all we care about. Bug: T147189 Change-Id: Ic2f22a82699e2b707b6ccb355605999a183a56a0
37 lines
941 B
PHP
37 lines
941 B
PHP
<?php
|
|
|
|
/**
|
|
* Reads a composer.lock file and provides accessors to get
|
|
* its hash and what is installed
|
|
*
|
|
* @since 1.25
|
|
*/
|
|
class ComposerLock {
|
|
|
|
/**
|
|
* @param string $location
|
|
*/
|
|
public function __construct( $location ) {
|
|
$this->contents = json_decode( file_get_contents( $location ), true );
|
|
}
|
|
|
|
/**
|
|
* Dependencies currently installed according to composer.lock
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getInstalledDependencies() {
|
|
$deps = [];
|
|
foreach ( $this->contents['packages'] as $installed ) {
|
|
$deps[$installed['name']] = [
|
|
'version' => ComposerJson::normalizeVersion( $installed['version'] ),
|
|
'type' => $installed['type'],
|
|
'licenses' => isset( $installed['license'] ) ? $installed['license'] : [],
|
|
'authors' => isset( $installed['authors'] ) ? $installed['authors'] : [],
|
|
'description' => isset( $installed['description'] ) ? $installed['description']: '',
|
|
];
|
|
}
|
|
|
|
return $deps;
|
|
}
|
|
}
|