mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Currently has a file handle leak (and will eventually run out of handles) related to the self update process. Either need to fix that or rip out self-update and leave that up to cron or something. DO NOT DELETE THIS TEXT #### Please note > Please read this information carefully. You can run `./scripts/pre-commit.php` to check your code before submitting. - [x] Have you followed our [code guidelines?](http://docs.librenms.org/Developing/Code-Guidelines/) #### Testers If you would like to test this pull request then please run: `./scripts/github-apply <pr_id>`, i.e `./scripts/github-apply 5926`
176 lines
5.1 KiB
PHP
176 lines
5.1 KiB
PHP
<?php
|
|
/**
|
|
* ComposerHelper.php
|
|
*
|
|
* Helper functions for composer
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @package LibreNMS
|
|
* @link http://librenms.org
|
|
* @copyright 2016 Tony Murray
|
|
* @author Tony Murray <murraytony@gmail.com>
|
|
*/
|
|
|
|
namespace LibreNMS;
|
|
|
|
use Composer\Installer\PackageEvent;
|
|
use Composer\Script\Event;
|
|
|
|
class ComposerHelper
|
|
{
|
|
public static function postRootPackageInstall(Event $event)
|
|
{
|
|
if (!file_exists('.env')) {
|
|
self::setPermissions();
|
|
self::populateEnv();
|
|
}
|
|
}
|
|
|
|
public static function postInstall(Event $event)
|
|
{
|
|
if (!file_exists('.env')) {
|
|
self::setPermissions();
|
|
}
|
|
|
|
self::populateEnv();
|
|
}
|
|
|
|
public static function preUpdate(Event $event)
|
|
{
|
|
if (!getenv('FORCE')) {
|
|
echo "Running composer update is not advisable. Please run composer install to update instead.\n";
|
|
echo "If know what you are doing and want to write a new composer.lock file set FORCE=1.\n";
|
|
echo "If you don't know what to do, run: composer install\n";
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
public static function preInstall(Event $event)
|
|
{
|
|
$vendor_dir = $event->getComposer()->getConfig()->get('vendor-dir');
|
|
|
|
if (!is_file("$vendor_dir/autoload.php")) {
|
|
// checkout vendor from 1.36
|
|
$cmds = array(
|
|
"git checkout 609676a9f8d72da081c61f82967e1d16defc0c4e -- $vendor_dir",
|
|
"git reset HEAD $vendor_dir" // don't add vendor directory to the index
|
|
);
|
|
|
|
self::exec($cmds);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Initially populate .env file
|
|
*/
|
|
private static function populateEnv()
|
|
{
|
|
if (!file_exists('.env')) {
|
|
copy('.env.example', '.env');
|
|
self::exec('php artisan key:generate');
|
|
}
|
|
|
|
$config = [
|
|
'db_host' => '',
|
|
'db_port' => '',
|
|
'db_name' => '',
|
|
'db_user' => '',
|
|
'db_pass' => '',
|
|
'db_socket' => '',
|
|
'base_url' => '',
|
|
'user' => '',
|
|
'group' => '',
|
|
];
|
|
|
|
@include 'config.php';
|
|
|
|
self::setEnv([
|
|
'NODE_ID' => uniqid(),
|
|
'DB_HOST' => $config['db_host'],
|
|
'DB_PORT' => $config['db_port'],
|
|
'DB_USERNAME' => $config['db_user'],
|
|
'DB_PASSWORD' => $config['db_pass'],
|
|
'DB_DATABASE' => $config['db_name'],
|
|
'DB_SOCKET' => $config['db_socket'],
|
|
'APP_URL' => $config['base_url'],
|
|
'LIBRENMS_USER' => $config['user'],
|
|
'LIBRENMS_GROUP' => $config['group'],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Set a setting in .env file
|
|
*
|
|
* @param array $settings KEY => value list of settings
|
|
* @param string $file
|
|
*/
|
|
private static function setEnv($settings, $file = '.env')
|
|
{
|
|
$original_content = $content = file_get_contents($file);
|
|
|
|
// ensure trailing line return
|
|
if (substr($content, -1) !== PHP_EOL) {
|
|
$content .= PHP_EOL;
|
|
}
|
|
|
|
foreach ($settings as $key => $value) {
|
|
// only add non-empty settings
|
|
if (empty($value)) {
|
|
continue;
|
|
}
|
|
|
|
// quote strings with spaces
|
|
if (strpos($value, ' ') !== false) {
|
|
$value = "\"$value\"";
|
|
}
|
|
|
|
if (strpos($content, "$key=") !== false) {
|
|
// only replace ones that aren't already set for safety and uncomment
|
|
// escape $ in the replacement
|
|
$content = preg_replace("/#?$key=\n/", addcslashes("$key=$value\n", '$'), $content);
|
|
} else {
|
|
$content .= "$key=$value\n";
|
|
}
|
|
}
|
|
|
|
// only write if the content has changed
|
|
if ($content !== $original_content) {
|
|
file_put_contents($file, $content);
|
|
}
|
|
}
|
|
|
|
private static function setPermissions()
|
|
{
|
|
$permissions_cmds = [
|
|
'setfacl -R -m g::rwx rrd/ logs/ storage/ bootstrap/cache/',
|
|
'setfacl -d -m g::rwx rrd/ logs/ storage/ bootstrap/cache/',
|
|
];
|
|
|
|
self::exec($permissions_cmds);
|
|
}
|
|
|
|
/**
|
|
* Run a command or array of commands and echo the command and output
|
|
*
|
|
* @param string|array $cmds
|
|
*/
|
|
private static function exec($cmds)
|
|
{
|
|
$cmd = "set -v\n" . implode(PHP_EOL, (array)$cmds);
|
|
passthru($cmd);
|
|
}
|
|
}
|