mindscreen / yarnlock
A package for parsing and interpreting yarn.lock files
Installs: 160 577
Dependents: 4
Suggesters: 0
Security: 0
Stars: 4
Watchers: 5
Forks: 5
Open Issues: 3
Requires
- php: >=7.2
- ext-ctype: *
Requires (Dev)
- phpunit/phpunit: ^8.5
- squizlabs/php_codesniffer: ^3.9
README
A php-package for parsing and evaluating the yarn.lock format.
Basic Usage
<?php use Mindscreen\YarnLock; $yarnLock = YarnLock::fromString(file_get_contents('yarn.lock')); $allPackages = $yarnLock->getPackages(); $hasBabelCore = $yarnLock->hasPackage('babel-core', '^6.0.0'); $babelCorePackages = $yarnLock->getPackagesByName('babel-core'); $babelCoreDependencies = $babelCorePackages[0]->getDependencies();
Package Depth
If you maybe don't just want all packages but only the direct dependencies plus one level of indirection, you have to go a little extra mile:
<?php use Mindscreen\YarnLock; // read the dependencies from the package.json file $packageDependencies = (json_decode(file_get_contents('package.json')))->dependencies; // get these packages from the yarn lock-file $rootDependencies = array_map(function($packageName, $packageVersion) use ($yarnLock) { return $yarnLock->getPackage($packageName, $packageVersion); }, array_keys($packageDependencies), array_values($packageDependencies)); // some of our dependencies might be used by other dependencies deeper down the tree so // they wouldn't appear in the top levels, if we wouldn't explicitly set them there. $yarnLock->calculateDepth($rootDependencies); // get the first two levels; the second argument is the exclusive upper limit $yarnLock->getPackagesByDepth(0, 2);