Installation and verification of phar distributed PHP applications has never been this easy!
Adding all the required tools like PHPUnit, PHPMD and phpDox in their matching versions to a project used to be a lot of repetitive work: Started by finding the download URL, figuring out what the actually correct and matching version is followed by verifying the sha1 and gpg signatures and making the archive executable. And of course you'd have to repeat this very thing for every tool needed.
Alternatively, you could have used composer. And cluttered your project's dependencies with the ones of your tools. And fight their potential dependency conflicts.
No more! Now can rely on PHIVE to install and manage your projects tooling needs without all the hassle and without cluttered dependencies!
Installation of PHIVE is easy and about the last time you have to do anything phar related manually. Grab your copy of PHIVE from the releases section at our github page or follow these 5 simple steps:
wget -o https://github.com/theseer/PHIVE/releases/latest/PHIVE.phar
gpg --keyserver some.where --import 0x1234567890
gpg --verify https://github.com/theseer/PHIVE/releases/latest/PHIVE.phar.asc PHIVE.phar
chmod +x PHIVE.phar
sudo mv PHIVE.phar /usr/bin/PHIVE
Once installed, PHIVE is ready for action. Some example invocations are shown below:
PHIVE install
PHIVE install phpunit
PHIVE install phpunit@4.6.1
PHIVE install --copy phpdox
PHIVE install phpdox bin/phpdox
PHIVE install composer
PHIVE install --signature https://proprietary.org/sig.asc https://proprietary.org/some.phar
To leverage the power of PHIVE, you don't need to do anything but install the tools you need using the PHIVE executable. PHIVE will automatically record your changes in an xml configuration file so you can replay the process as needed.
To support for more advanced uses and to be able to replay an installation, a PHIVE configuration file can of course
also be added to your project manually. Running PHIVE skel
will get you an annotated example configuration file to
get you started.
You can browse and query the phar.io project database to find out which tools are already known by PHIVE here:
[-------------------------------] [search]
If your application is missing and you want to have it added, please open a ticket and/or supply a pull request.
- Composer
- PHPUnit
- phpDox
- PHP MessDetector
- PHP CodeSniffer
PHIVE makes installation easy by providing a means to resolve the given alias to an actual download location, including the verification of the certificate supplied by the server. Once downloaded, the archive's SHA1/SHA256/SHA512 hash is verified and so its OpenPGP/GnuPG or OpenSSL signature.
Instead of redownloading the same phar multiple times, the archive is kept at a shared location (by default in ~/.PHIVE) and only a symbolic link is created for the project. You can of course also explicitly request a copy of the phar to be made in favor of symbolic links (use --copy).
Phar.io only serves as a central database to resolve alias names but does not provide the actual phar files. If you want to be independent of phar.io, simply use the fully qualified url to any PHIVE compatbile repository server.
To make your phar based project available to PHIVE users, you need to provide a download location either by following some simple conventions or by generating a metadata file. The later can be automated using [toolx].
If no metadata file can be found, PHIVE will assume that auto indexing for the repository base url is enabled and the resulting HTML document contains links to all downloadable phars. Each phar's filename has to follow this pattern:
projectname-<semantic version>
projectname-nightly
For each phar an accompanying .asc file has to be provided, containing the OpenPGP/GnuPG or OpenSSL signature.
PHIVE and phar.io are open source projects released under the BSD license. You are welcome to join the development team! Please refer to the contributing document for more details.