bogdanbeniaminb / simpledep
Simple Dependency Solver for PHP
Installs: 50
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/bogdanbeniaminb/simpledep
Requires
- php: >=7.4
- z4kn4fein/php-semver: ^2.0
README
This is a simple solver for install/uninstall requests and their dependencies.
Purpose
The purpose of this project is to provide a simple dependency tree solver for package management tools like internal marketplaces. It is not intended to be a full-featured package manager like Composer or NPM.
How to run
The main class is the Solver class. Its constructor method takes a Pool of packages, a RequestsCollection of requests and an array of installed packages. The solve method returns an array of Operation objects. Each Operation object has a type property that can be install or uninstall, a name property with the package name and a version property with the package version.
<?php $foo1 = (new Package('foo', '1.0.0'))->addLink('require', 'bar', '>=1.0.0'); $foo2 = (new Package('foo', '1.0.1'))->addLink('require', 'bar', '>=1.0.1'); $bar1 = (new Package('bar', '1.0.0'))->addLink('require', 'baz', '>=1.0.0'); $bar2 = (new Package('bar', '1.0.1'))->addLink('require', 'baz', '>=1.0.5'); $boo1 = (new Package('boo', '1.0.5')) ->addLink('conflict', 'bee', '>=1.0.0') ->addLink('replace', 'wow', '>=1.0.0'); $boo2 = (new Package('boo', '1.0.7')) ->addLink('conflict', 'bee', '>=1.0.0') ->addLink('replace', 'wow', '>=1.0.0'); $baz1 = new Package('baz', '1.0.0'); $baz2 = new Package('baz', '1.0.1'); $pool = (new Pool()) ->addPackage($foo1) ->addPackage($bar1) ->addPackage($boo1) ->addPackage($boo2) ->addPackage($baz1) ->addPackage($foo2) ->addPackage($bar2) ->addPackage($baz2); $requests = (new RequestsCollection()) ->install('foo', '>=1.0.0') ->update('boo') ->uninstall('bee'); $installed = [ 'boo' => [ 'version' => '1.0.0', ], 'bee' => [ 'version' => '1.0.0', ], ]; $solver = new Solver($pool, $requests, $installed); $solution = $solver->solve(); // print_r($solution); // Convert the solution to an array of arrays. $solutionArray = array_map( fn(Operation $operation) => $operation->toArray(), $solution ); echo (json_encode($solutionArray, JSON_PRETTY_PRINT));
The code above will output the following:
{
  "baz": {
    "type": "install",
    "name": "baz",
    "version": "1.0.1",
    "requiredBy": [{
        "type": "install",
        "name": "bar",
        "version": "1.0.0"
      },
      {
        "type": "install",
        "name": "foo",
        "version": "1.0.0"
      }
    ]
  },
  "bar": {
    "type": "install",
    "name": "bar",
    "version": "1.0.0",
    "requiredBy": [{
      "type": "install",
      "name": "foo",
      "version": "1.0.0"
    }]
  },
  "foo": {
    "type": "install",
    "name": "foo",
    "version": "1.0.0",
    "requiredBy": []
  },
  "boo": {
    "type": "install",
    "name": "boo",
    "version": "1.0.7",
    "requiredBy": []
  },
  "bee": {
    "type": "uninstall",
    "name": "bee",
    "version": null,
    "requiredBy": [{
      "type": "install",
      "name": "boo",
      "version": "1.0.7"
    }]
  }
}