From 9e34188682cd3c51a110ecf383359dc19a96be5b Mon Sep 17 00:00:00 2001 From: "Romain B." <8530352+Rom1-B@users.noreply.github.com> Date: Fri, 8 Nov 2024 11:23:32 +0100 Subject: [PATCH] Add php-cs-fixer (#109) --- .php-cs-fixer.php | 20 + composer.json | 1 + composer.lock | 2226 +++++++++++++++++++++++++++++++----- front/config.php | 8 +- front/configfield.form.php | 2 +- hook.php | 11 +- inc/config.class.php | 147 +-- inc/configfield.class.php | 127 +- inc/generation.class.php | 120 +- inc/profile.class.php | 46 +- setup.php | 16 +- 11 files changed, 2223 insertions(+), 501 deletions(-) create mode 100644 .php-cs-fixer.php diff --git a/.php-cs-fixer.php b/.php-cs-fixer.php new file mode 100644 index 0000000..5fd203d --- /dev/null +++ b/.php-cs-fixer.php @@ -0,0 +1,20 @@ +in(__DIR__) + ->name('*.php'); + +$config = new Config(); + +$rules = [ + '@PER-CS2.0' => true, + 'trailing_comma_in_multiline' => ['elements' => ['arguments', 'array_destructuring', 'arrays']], // For PHP 7.4 compatibility +]; + +return $config + ->setRules($rules) + ->setFinder($finder) + ->setUsingCache(false); diff --git a/composer.json b/composer.json index 95761e4..41de459 100644 --- a/composer.json +++ b/composer.json @@ -3,6 +3,7 @@ "php": ">=7.4" }, "require-dev": { + "friendsofphp/php-cs-fixer": "^3.64", "glpi-project/tools": "^0.7.4", "php-parallel-lint/php-parallel-lint": "^1.4", "phpstan/extension-installer": "^1.4", diff --git a/composer.lock b/composer.lock index 6b64485..f12d992 100644 --- a/composer.lock +++ b/composer.lock @@ -4,300 +4,378 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "8e92cf7293e50a7861728b81fbd4831f", + "content-hash": "85d59b5395247975721ed61cd0c9de2e", "packages": [], "packages-dev": [ { - "name": "glpi-project/tools", - "version": "0.7.4", + "name": "clue/ndjson-react", + "version": "v1.3.0", "source": { "type": "git", - "url": "https://github.com/glpi-project/tools.git", - "reference": "65a09a93350da6fa67d423dd94e4cb4023a17e20" + "url": "https://github.com/clue/reactphp-ndjson.git", + "reference": "392dc165fce93b5bb5c637b67e59619223c931b0" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/glpi-project/tools/zipball/65a09a93350da6fa67d423dd94e4cb4023a17e20", - "reference": "65a09a93350da6fa67d423dd94e4cb4023a17e20", + "url": "https://api.github.com/repos/clue/reactphp-ndjson/zipball/392dc165fce93b5bb5c637b67e59619223c931b0", + "reference": "392dc165fce93b5bb5c637b67e59619223c931b0", "shasum": "" }, "require": { - "symfony/console": "^5.4 || ^6.0", - "twig/twig": "^3.3" + "php": ">=5.3", + "react/stream": "^1.2" }, "require-dev": { - "nikic/php-parser": "^4.13", - "phpstan/phpstan-src": "^1.10" + "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35", + "react/event-loop": "^1.2" }, - "bin": [ - "bin/extract-locales", - "bin/licence-headers-check", - "tools/plugin-release" - ], "type": "library", "autoload": { "psr-4": { - "GlpiProject\\Tools\\": "src/" + "Clue\\React\\NDJson\\": "src/" } }, "notification-url": "https://packagist.org/downloads/", "license": [ - "GPL-3.0-or-later" + "MIT" ], "authors": [ { - "name": "Teclib'", - "email": "glpi@teclib.com", - "homepage": "http://teclib-group.com" + "name": "Christian Lück", + "email": "christian@clue.engineering" } ], - "description": "Various tools for GLPI and its plugins", + "description": "Streaming newline-delimited JSON (NDJSON) parser and encoder for ReactPHP.", + "homepage": "https://github.com/clue/reactphp-ndjson", "keywords": [ - "glpi", - "plugins", - "tools" + "NDJSON", + "json", + "jsonlines", + "newline", + "reactphp", + "streaming" ], "support": { - "issues": "https://github.com/glpi-project/tools/issues", - "source": "https://github.com/glpi-project/tools" + "issues": "https://github.com/clue/reactphp-ndjson/issues", + "source": "https://github.com/clue/reactphp-ndjson/tree/v1.3.0" }, - "time": "2024-09-18T06:58:02+00:00" + "funding": [ + { + "url": "https://clue.engineering/support", + "type": "custom" + }, + { + "url": "https://github.com/clue", + "type": "github" + } + ], + "time": "2022-12-23T10:58:28+00:00" }, { - "name": "php-parallel-lint/php-parallel-lint", - "version": "v1.4.0", + "name": "composer/pcre", + "version": "3.3.1", "source": { "type": "git", - "url": "https://github.com/php-parallel-lint/PHP-Parallel-Lint.git", - "reference": "6db563514f27e19595a19f45a4bf757b6401194e" + "url": "https://github.com/composer/pcre.git", + "reference": "63aaeac21d7e775ff9bc9d45021e1745c97521c4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-parallel-lint/PHP-Parallel-Lint/zipball/6db563514f27e19595a19f45a4bf757b6401194e", - "reference": "6db563514f27e19595a19f45a4bf757b6401194e", + "url": "https://api.github.com/repos/composer/pcre/zipball/63aaeac21d7e775ff9bc9d45021e1745c97521c4", + "reference": "63aaeac21d7e775ff9bc9d45021e1745c97521c4", "shasum": "" }, "require": { - "ext-json": "*", - "php": ">=5.3.0" + "php": "^7.4 || ^8.0" }, - "replace": { - "grogy/php-parallel-lint": "*", - "jakub-onderka/php-parallel-lint": "*" + "conflict": { + "phpstan/phpstan": "<1.11.10" }, "require-dev": { - "nette/tester": "^1.3 || ^2.0", - "php-parallel-lint/php-console-highlighter": "0.* || ^1.0", - "squizlabs/php_codesniffer": "^3.6" - }, - "suggest": { - "php-parallel-lint/php-console-highlighter": "Highlight syntax in code snippet" + "phpstan/phpstan": "^1.11.10", + "phpstan/phpstan-strict-rules": "^1.1", + "phpunit/phpunit": "^8 || ^9" }, - "bin": [ - "parallel-lint" - ], "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + }, + "phpstan": { + "includes": [ + "extension.neon" + ] + } + }, "autoload": { - "classmap": [ - "./src/" - ] + "psr-4": { + "Composer\\Pcre\\": "src" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ - "BSD-2-Clause" + "MIT" ], "authors": [ { - "name": "Jakub Onderka", - "email": "ahoj@jakubonderka.cz" + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "http://seld.be" } ], - "description": "This tool checks the syntax of PHP files about 20x faster than serial check.", - "homepage": "https://github.com/php-parallel-lint/PHP-Parallel-Lint", + "description": "PCRE wrapping library that offers type-safe preg_* replacements.", "keywords": [ - "lint", - "static analysis" + "PCRE", + "preg", + "regex", + "regular expression" ], "support": { - "issues": "https://github.com/php-parallel-lint/PHP-Parallel-Lint/issues", - "source": "https://github.com/php-parallel-lint/PHP-Parallel-Lint/tree/v1.4.0" + "issues": "https://github.com/composer/pcre/issues", + "source": "https://github.com/composer/pcre/tree/3.3.1" }, - "time": "2024-03-27T12:14:49+00:00" + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-08-27T18:44:43+00:00" }, { - "name": "phpstan/extension-installer", - "version": "1.4.3", + "name": "composer/semver", + "version": "3.4.3", "source": { "type": "git", - "url": "https://github.com/phpstan/extension-installer.git", - "reference": "85e90b3942d06b2326fba0403ec24fe912372936" + "url": "https://github.com/composer/semver.git", + "reference": "4313d26ada5e0c4edfbd1dc481a92ff7bff91f12" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/extension-installer/zipball/85e90b3942d06b2326fba0403ec24fe912372936", - "reference": "85e90b3942d06b2326fba0403ec24fe912372936", + "url": "https://api.github.com/repos/composer/semver/zipball/4313d26ada5e0c4edfbd1dc481a92ff7bff91f12", + "reference": "4313d26ada5e0c4edfbd1dc481a92ff7bff91f12", "shasum": "" }, "require": { - "composer-plugin-api": "^2.0", - "php": "^7.2 || ^8.0", - "phpstan/phpstan": "^1.9.0 || ^2.0" + "php": "^5.3.2 || ^7.0 || ^8.0" }, "require-dev": { - "composer/composer": "^2.0", - "php-parallel-lint/php-parallel-lint": "^1.2.0", - "phpstan/phpstan-strict-rules": "^0.11 || ^0.12 || ^1.0" + "phpstan/phpstan": "^1.11", + "symfony/phpunit-bridge": "^3 || ^7" }, - "type": "composer-plugin", + "type": "library", "extra": { - "class": "PHPStan\\ExtensionInstaller\\Plugin" + "branch-alias": { + "dev-main": "3.x-dev" + } }, "autoload": { "psr-4": { - "PHPStan\\ExtensionInstaller\\": "src/" + "Composer\\Semver\\": "src" } }, "notification-url": "https://packagist.org/downloads/", "license": [ "MIT" ], - "description": "Composer plugin for automatic installation of PHPStan extensions", + "authors": [ + { + "name": "Nils Adermann", + "email": "naderman@naderman.de", + "homepage": "http://www.naderman.de" + }, + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "http://seld.be" + }, + { + "name": "Rob Bast", + "email": "rob.bast@gmail.com", + "homepage": "http://robbast.nl" + } + ], + "description": "Semver library that offers utilities, version constraint parsing and validation.", "keywords": [ - "dev", - "static analysis" + "semantic", + "semver", + "validation", + "versioning" ], "support": { - "issues": "https://github.com/phpstan/extension-installer/issues", - "source": "https://github.com/phpstan/extension-installer/tree/1.4.3" + "irc": "ircs://irc.libera.chat:6697/composer", + "issues": "https://github.com/composer/semver/issues", + "source": "https://github.com/composer/semver/tree/3.4.3" }, - "time": "2024-09-04T20:21:43+00:00" + "funding": [ + { + "url": "https://packagist.com", + "type": "custom" + }, + { + "url": "https://github.com/composer", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" + } + ], + "time": "2024-09-19T14:15:21+00:00" }, { - "name": "phpstan/phpstan", - "version": "1.12.7", + "name": "composer/xdebug-handler", + "version": "3.0.5", "source": { "type": "git", - "url": "https://github.com/phpstan/phpstan.git", - "reference": "dc2b9976bd8b0f84ec9b0e50cc35378551de7af0" + "url": "https://github.com/composer/xdebug-handler.git", + "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpstan/zipball/dc2b9976bd8b0f84ec9b0e50cc35378551de7af0", - "reference": "dc2b9976bd8b0f84ec9b0e50cc35378551de7af0", + "url": "https://api.github.com/repos/composer/xdebug-handler/zipball/6c1925561632e83d60a44492e0b344cf48ab85ef", + "reference": "6c1925561632e83d60a44492e0b344cf48ab85ef", "shasum": "" }, "require": { - "php": "^7.2|^8.0" + "composer/pcre": "^1 || ^2 || ^3", + "php": "^7.2.5 || ^8.0", + "psr/log": "^1 || ^2 || ^3" }, - "conflict": { - "phpstan/phpstan-shim": "*" + "require-dev": { + "phpstan/phpstan": "^1.0", + "phpstan/phpstan-strict-rules": "^1.1", + "phpunit/phpunit": "^8.5 || ^9.6 || ^10.5" }, - "bin": [ - "phpstan", - "phpstan.phar" - ], "type": "library", "autoload": { - "files": [ - "bootstrap.php" - ] + "psr-4": { + "Composer\\XdebugHandler\\": "src" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ "MIT" ], - "description": "PHPStan - PHP Static Analysis Tool", + "authors": [ + { + "name": "John Stevenson", + "email": "john-stevenson@blueyonder.co.uk" + } + ], + "description": "Restarts a process without Xdebug.", "keywords": [ - "dev", - "static analysis" + "Xdebug", + "performance" ], "support": { - "docs": "https://phpstan.org/user-guide/getting-started", - "forum": "https://github.com/phpstan/phpstan/discussions", - "issues": "https://github.com/phpstan/phpstan/issues", - "security": "https://github.com/phpstan/phpstan/security/policy", - "source": "https://github.com/phpstan/phpstan-src" + "irc": "ircs://irc.libera.chat:6697/composer", + "issues": "https://github.com/composer/xdebug-handler/issues", + "source": "https://github.com/composer/xdebug-handler/tree/3.0.5" }, "funding": [ { - "url": "https://github.com/ondrejmirtes", - "type": "github" + "url": "https://packagist.com", + "type": "custom" }, { - "url": "https://github.com/phpstan", + "url": "https://github.com/composer", "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/composer/composer", + "type": "tidelift" } ], - "time": "2024-10-18T11:12:07+00:00" + "time": "2024-05-06T16:37:16+00:00" }, { - "name": "phpstan/phpstan-deprecation-rules", - "version": "1.2.1", + "name": "evenement/evenement", + "version": "v3.0.2", "source": { "type": "git", - "url": "https://github.com/phpstan/phpstan-deprecation-rules.git", - "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82" + "url": "https://github.com/igorw/evenement.git", + "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpstan-deprecation-rules/zipball/f94d246cc143ec5a23da868f8f7e1393b50eaa82", - "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82", + "url": "https://api.github.com/repos/igorw/evenement/zipball/0a16b0d71ab13284339abb99d9d2bd813640efbc", + "reference": "0a16b0d71ab13284339abb99d9d2bd813640efbc", "shasum": "" }, "require": { - "php": "^7.2 || ^8.0", - "phpstan/phpstan": "^1.12" + "php": ">=7.0" }, "require-dev": { - "php-parallel-lint/php-parallel-lint": "^1.2", - "phpstan/phpstan-phpunit": "^1.0", - "phpunit/phpunit": "^9.5" - }, - "type": "phpstan-extension", - "extra": { - "phpstan": { - "includes": [ - "rules.neon" - ] - } + "phpunit/phpunit": "^9 || ^6" }, + "type": "library", "autoload": { "psr-4": { - "PHPStan\\": "src/" + "Evenement\\": "src/" } }, "notification-url": "https://packagist.org/downloads/", "license": [ "MIT" ], - "description": "PHPStan rules for detecting usage of deprecated classes, methods, properties, constants and traits.", + "authors": [ + { + "name": "Igor Wiedler", + "email": "igor@wiedler.ch" + } + ], + "description": "Événement is a very simple event dispatching library for PHP", + "keywords": [ + "event-dispatcher", + "event-emitter" + ], "support": { - "issues": "https://github.com/phpstan/phpstan-deprecation-rules/issues", - "source": "https://github.com/phpstan/phpstan-deprecation-rules/tree/1.2.1" + "issues": "https://github.com/igorw/evenement/issues", + "source": "https://github.com/igorw/evenement/tree/v3.0.2" }, - "time": "2024-09-11T15:52:35+00:00" + "time": "2023-08-08T05:53:35+00:00" }, { - "name": "psr/container", - "version": "1.1.2", + "name": "fidry/cpu-core-counter", + "version": "1.2.0", "source": { "type": "git", - "url": "https://github.com/php-fig/container.git", - "reference": "513e0666f7216c7459170d56df27dfcefe1689ea" + "url": "https://github.com/theofidry/cpu-core-counter.git", + "reference": "8520451a140d3f46ac33042715115e290cf5785f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/php-fig/container/zipball/513e0666f7216c7459170d56df27dfcefe1689ea", - "reference": "513e0666f7216c7459170d56df27dfcefe1689ea", + "url": "https://api.github.com/repos/theofidry/cpu-core-counter/zipball/8520451a140d3f46ac33042715115e290cf5785f", + "reference": "8520451a140d3f46ac33042715115e290cf5785f", "shasum": "" }, "require": { - "php": ">=7.4.0" + "php": "^7.2 || ^8.0" + }, + "require-dev": { + "fidry/makefile": "^0.2.0", + "fidry/php-cs-fixer-config": "^1.1.2", + "phpstan/extension-installer": "^1.2.0", + "phpstan/phpstan": "^1.9.2", + "phpstan/phpstan-deprecation-rules": "^1.0.0", + "phpstan/phpstan-phpunit": "^1.2.2", + "phpstan/phpstan-strict-rules": "^1.4.4", + "phpunit/phpunit": "^8.5.31 || ^9.5.26", + "webmozarts/strict-phpunit": "^7.5" }, "type": "library", "autoload": { "psr-4": { - "Psr\\Container\\": "src/" + "Fidry\\CpuCoreCounter\\": "src/" } }, "notification-url": "https://packagist.org/downloads/", @@ -306,158 +384,1644 @@ ], "authors": [ { - "name": "PHP-FIG", - "homepage": "https://www.php-fig.org/" + "name": "Théo FIDRY", + "email": "theo.fidry@gmail.com" } ], - "description": "Common Container Interface (PHP FIG PSR-11)", - "homepage": "https://github.com/php-fig/container", + "description": "Tiny utility to get the number of CPU cores.", "keywords": [ - "PSR-11", - "container", - "container-interface", - "container-interop", - "psr" + "CPU", + "core" + ], + "support": { + "issues": "https://github.com/theofidry/cpu-core-counter/issues", + "source": "https://github.com/theofidry/cpu-core-counter/tree/1.2.0" + }, + "funding": [ + { + "url": "https://github.com/theofidry", + "type": "github" + } + ], + "time": "2024-08-06T10:04:20+00:00" + }, + { + "name": "friendsofphp/php-cs-fixer", + "version": "v3.64.0", + "source": { + "type": "git", + "url": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer.git", + "reference": "58dd9c931c785a79739310aef5178928305ffa67" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHP-CS-Fixer/PHP-CS-Fixer/zipball/58dd9c931c785a79739310aef5178928305ffa67", + "reference": "58dd9c931c785a79739310aef5178928305ffa67", + "shasum": "" + }, + "require": { + "clue/ndjson-react": "^1.0", + "composer/semver": "^3.4", + "composer/xdebug-handler": "^3.0.3", + "ext-filter": "*", + "ext-json": "*", + "ext-tokenizer": "*", + "fidry/cpu-core-counter": "^1.0", + "php": "^7.4 || ^8.0", + "react/child-process": "^0.6.5", + "react/event-loop": "^1.0", + "react/promise": "^2.0 || ^3.0", + "react/socket": "^1.0", + "react/stream": "^1.0", + "sebastian/diff": "^4.0 || ^5.0 || ^6.0", + "symfony/console": "^5.4 || ^6.0 || ^7.0", + "symfony/event-dispatcher": "^5.4 || ^6.0 || ^7.0", + "symfony/filesystem": "^5.4 || ^6.0 || ^7.0", + "symfony/finder": "^5.4 || ^6.0 || ^7.0", + "symfony/options-resolver": "^5.4 || ^6.0 || ^7.0", + "symfony/polyfill-mbstring": "^1.28", + "symfony/polyfill-php80": "^1.28", + "symfony/polyfill-php81": "^1.28", + "symfony/process": "^5.4 || ^6.0 || ^7.0", + "symfony/stopwatch": "^5.4 || ^6.0 || ^7.0" + }, + "require-dev": { + "facile-it/paraunit": "^1.3 || ^2.3", + "infection/infection": "^0.29.5", + "justinrainbow/json-schema": "^5.2", + "keradus/cli-executor": "^2.1", + "mikey179/vfsstream": "^1.6.11", + "php-coveralls/php-coveralls": "^2.7", + "php-cs-fixer/accessible-object": "^1.1", + "php-cs-fixer/phpunit-constraint-isidenticalstring": "^1.5", + "php-cs-fixer/phpunit-constraint-xmlmatchesxsd": "^1.5", + "phpunit/phpunit": "^9.6.19 || ^10.5.21 || ^11.2", + "symfony/var-dumper": "^5.4 || ^6.0 || ^7.0", + "symfony/yaml": "^5.4 || ^6.0 || ^7.0" + }, + "suggest": { + "ext-dom": "For handling output formats in XML", + "ext-mbstring": "For handling non-UTF8 characters." + }, + "bin": [ + "php-cs-fixer" + ], + "type": "application", + "autoload": { + "psr-4": { + "PhpCsFixer\\": "src/" + }, + "exclude-from-classmap": [ + "src/Fixer/Internal/*" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Dariusz Rumiński", + "email": "dariusz.ruminski@gmail.com" + } + ], + "description": "A tool to automatically fix PHP code style", + "keywords": [ + "Static code analysis", + "fixer", + "standards", + "static analysis" + ], + "support": { + "issues": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/issues", + "source": "https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/tree/v3.64.0" + }, + "funding": [ + { + "url": "https://github.com/keradus", + "type": "github" + } + ], + "time": "2024-08-30T23:09:38+00:00" + }, + { + "name": "glpi-project/tools", + "version": "0.7.4", + "source": { + "type": "git", + "url": "https://github.com/glpi-project/tools.git", + "reference": "65a09a93350da6fa67d423dd94e4cb4023a17e20" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/glpi-project/tools/zipball/65a09a93350da6fa67d423dd94e4cb4023a17e20", + "reference": "65a09a93350da6fa67d423dd94e4cb4023a17e20", + "shasum": "" + }, + "require": { + "symfony/console": "^5.4 || ^6.0", + "twig/twig": "^3.3" + }, + "require-dev": { + "nikic/php-parser": "^4.13", + "phpstan/phpstan-src": "^1.10" + }, + "bin": [ + "bin/extract-locales", + "bin/licence-headers-check", + "tools/plugin-release" + ], + "type": "library", + "autoload": { + "psr-4": { + "GlpiProject\\Tools\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "GPL-3.0-or-later" + ], + "authors": [ + { + "name": "Teclib'", + "email": "glpi@teclib.com", + "homepage": "http://teclib-group.com" + } + ], + "description": "Various tools for GLPI and its plugins", + "keywords": [ + "glpi", + "plugins", + "tools" + ], + "support": { + "issues": "https://github.com/glpi-project/tools/issues", + "source": "https://github.com/glpi-project/tools" + }, + "time": "2024-09-18T06:58:02+00:00" + }, + { + "name": "php-parallel-lint/php-parallel-lint", + "version": "v1.4.0", + "source": { + "type": "git", + "url": "https://github.com/php-parallel-lint/PHP-Parallel-Lint.git", + "reference": "6db563514f27e19595a19f45a4bf757b6401194e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-parallel-lint/PHP-Parallel-Lint/zipball/6db563514f27e19595a19f45a4bf757b6401194e", + "reference": "6db563514f27e19595a19f45a4bf757b6401194e", + "shasum": "" + }, + "require": { + "ext-json": "*", + "php": ">=5.3.0" + }, + "replace": { + "grogy/php-parallel-lint": "*", + "jakub-onderka/php-parallel-lint": "*" + }, + "require-dev": { + "nette/tester": "^1.3 || ^2.0", + "php-parallel-lint/php-console-highlighter": "0.* || ^1.0", + "squizlabs/php_codesniffer": "^3.6" + }, + "suggest": { + "php-parallel-lint/php-console-highlighter": "Highlight syntax in code snippet" + }, + "bin": [ + "parallel-lint" + ], + "type": "library", + "autoload": { + "classmap": [ + "./src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-2-Clause" + ], + "authors": [ + { + "name": "Jakub Onderka", + "email": "ahoj@jakubonderka.cz" + } + ], + "description": "This tool checks the syntax of PHP files about 20x faster than serial check.", + "homepage": "https://github.com/php-parallel-lint/PHP-Parallel-Lint", + "keywords": [ + "lint", + "static analysis" + ], + "support": { + "issues": "https://github.com/php-parallel-lint/PHP-Parallel-Lint/issues", + "source": "https://github.com/php-parallel-lint/PHP-Parallel-Lint/tree/v1.4.0" + }, + "time": "2024-03-27T12:14:49+00:00" + }, + { + "name": "phpstan/extension-installer", + "version": "1.4.3", + "source": { + "type": "git", + "url": "https://github.com/phpstan/extension-installer.git", + "reference": "85e90b3942d06b2326fba0403ec24fe912372936" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpstan/extension-installer/zipball/85e90b3942d06b2326fba0403ec24fe912372936", + "reference": "85e90b3942d06b2326fba0403ec24fe912372936", + "shasum": "" + }, + "require": { + "composer-plugin-api": "^2.0", + "php": "^7.2 || ^8.0", + "phpstan/phpstan": "^1.9.0 || ^2.0" + }, + "require-dev": { + "composer/composer": "^2.0", + "php-parallel-lint/php-parallel-lint": "^1.2.0", + "phpstan/phpstan-strict-rules": "^0.11 || ^0.12 || ^1.0" + }, + "type": "composer-plugin", + "extra": { + "class": "PHPStan\\ExtensionInstaller\\Plugin" + }, + "autoload": { + "psr-4": { + "PHPStan\\ExtensionInstaller\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "Composer plugin for automatic installation of PHPStan extensions", + "keywords": [ + "dev", + "static analysis" + ], + "support": { + "issues": "https://github.com/phpstan/extension-installer/issues", + "source": "https://github.com/phpstan/extension-installer/tree/1.4.3" + }, + "time": "2024-09-04T20:21:43+00:00" + }, + { + "name": "phpstan/phpstan", + "version": "1.12.7", + "source": { + "type": "git", + "url": "https://github.com/phpstan/phpstan.git", + "reference": "dc2b9976bd8b0f84ec9b0e50cc35378551de7af0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpstan/phpstan/zipball/dc2b9976bd8b0f84ec9b0e50cc35378551de7af0", + "reference": "dc2b9976bd8b0f84ec9b0e50cc35378551de7af0", + "shasum": "" + }, + "require": { + "php": "^7.2|^8.0" + }, + "conflict": { + "phpstan/phpstan-shim": "*" + }, + "bin": [ + "phpstan", + "phpstan.phar" + ], + "type": "library", + "autoload": { + "files": [ + "bootstrap.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "PHPStan - PHP Static Analysis Tool", + "keywords": [ + "dev", + "static analysis" + ], + "support": { + "docs": "https://phpstan.org/user-guide/getting-started", + "forum": "https://github.com/phpstan/phpstan/discussions", + "issues": "https://github.com/phpstan/phpstan/issues", + "security": "https://github.com/phpstan/phpstan/security/policy", + "source": "https://github.com/phpstan/phpstan-src" + }, + "funding": [ + { + "url": "https://github.com/ondrejmirtes", + "type": "github" + }, + { + "url": "https://github.com/phpstan", + "type": "github" + } + ], + "time": "2024-10-18T11:12:07+00:00" + }, + { + "name": "phpstan/phpstan-deprecation-rules", + "version": "1.2.1", + "source": { + "type": "git", + "url": "https://github.com/phpstan/phpstan-deprecation-rules.git", + "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/phpstan/phpstan-deprecation-rules/zipball/f94d246cc143ec5a23da868f8f7e1393b50eaa82", + "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82", + "shasum": "" + }, + "require": { + "php": "^7.2 || ^8.0", + "phpstan/phpstan": "^1.12" + }, + "require-dev": { + "php-parallel-lint/php-parallel-lint": "^1.2", + "phpstan/phpstan-phpunit": "^1.0", + "phpunit/phpunit": "^9.5" + }, + "type": "phpstan-extension", + "extra": { + "phpstan": { + "includes": [ + "rules.neon" + ] + } + }, + "autoload": { + "psr-4": { + "PHPStan\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "PHPStan rules for detecting usage of deprecated classes, methods, properties, constants and traits.", + "support": { + "issues": "https://github.com/phpstan/phpstan-deprecation-rules/issues", + "source": "https://github.com/phpstan/phpstan-deprecation-rules/tree/1.2.1" + }, + "time": "2024-09-11T15:52:35+00:00" + }, + { + "name": "psr/container", + "version": "1.1.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/container.git", + "reference": "513e0666f7216c7459170d56df27dfcefe1689ea" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/container/zipball/513e0666f7216c7459170d56df27dfcefe1689ea", + "reference": "513e0666f7216c7459170d56df27dfcefe1689ea", + "shasum": "" + }, + "require": { + "php": ">=7.4.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Psr\\Container\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common Container Interface (PHP FIG PSR-11)", + "homepage": "https://github.com/php-fig/container", + "keywords": [ + "PSR-11", + "container", + "container-interface", + "container-interop", + "psr" + ], + "support": { + "issues": "https://github.com/php-fig/container/issues", + "source": "https://github.com/php-fig/container/tree/1.1.2" + }, + "time": "2021-11-05T16:50:12+00:00" + }, + { + "name": "psr/event-dispatcher", + "version": "1.0.0", + "source": { + "type": "git", + "url": "https://github.com/php-fig/event-dispatcher.git", + "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/event-dispatcher/zipball/dbefd12671e8a14ec7f180cab83036ed26714bb0", + "reference": "dbefd12671e8a14ec7f180cab83036ed26714bb0", + "shasum": "" + }, + "require": { + "php": ">=7.2.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.0.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\EventDispatcher\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "http://www.php-fig.org/" + } + ], + "description": "Standard interfaces for event handling.", + "keywords": [ + "events", + "psr", + "psr-14" + ], + "support": { + "issues": "https://github.com/php-fig/event-dispatcher/issues", + "source": "https://github.com/php-fig/event-dispatcher/tree/1.0.0" + }, + "time": "2019-01-08T18:20:26+00:00" + }, + { + "name": "psr/log", + "version": "1.1.4", + "source": { + "type": "git", + "url": "https://github.com/php-fig/log.git", + "reference": "d49695b909c3b7628b6289db5479a1c204601f11" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/log/zipball/d49695b909c3b7628b6289db5479a1c204601f11", + "reference": "d49695b909c3b7628b6289db5479a1c204601f11", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.1.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Log\\": "Psr/Log/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for logging libraries", + "homepage": "https://github.com/php-fig/log", + "keywords": [ + "log", + "psr", + "psr-3" + ], + "support": { + "source": "https://github.com/php-fig/log/tree/1.1.4" + }, + "time": "2021-05-03T11:20:27+00:00" + }, + { + "name": "react/cache", + "version": "v1.2.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/cache.git", + "reference": "d47c472b64aa5608225f47965a484b75c7817d5b" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/cache/zipball/d47c472b64aa5608225f47965a484b75c7817d5b", + "reference": "d47c472b64aa5608225f47965a484b75c7817d5b", + "shasum": "" + }, + "require": { + "php": ">=5.3.0", + "react/promise": "^3.0 || ^2.0 || ^1.1" + }, + "require-dev": { + "phpunit/phpunit": "^9.5 || ^5.7 || ^4.8.35" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Cache\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async, Promise-based cache interface for ReactPHP", + "keywords": [ + "cache", + "caching", + "promise", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/cache/issues", + "source": "https://github.com/reactphp/cache/tree/v1.2.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2022-11-30T15:59:55+00:00" + }, + { + "name": "react/child-process", + "version": "v0.6.5", + "source": { + "type": "git", + "url": "https://github.com/reactphp/child-process.git", + "reference": "e71eb1aa55f057c7a4a0d08d06b0b0a484bead43" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/child-process/zipball/e71eb1aa55f057c7a4a0d08d06b0b0a484bead43", + "reference": "e71eb1aa55f057c7a4a0d08d06b0b0a484bead43", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.0", + "react/event-loop": "^1.2", + "react/stream": "^1.2" + }, + "require-dev": { + "phpunit/phpunit": "^9.3 || ^5.7 || ^4.8.35", + "react/socket": "^1.8", + "sebastian/environment": "^5.0 || ^3.0 || ^2.0 || ^1.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\ChildProcess\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Event-driven library for executing child processes with ReactPHP.", + "keywords": [ + "event-driven", + "process", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/child-process/issues", + "source": "https://github.com/reactphp/child-process/tree/v0.6.5" + }, + "funding": [ + { + "url": "https://github.com/WyriHaximus", + "type": "github" + }, + { + "url": "https://github.com/clue", + "type": "github" + } + ], + "time": "2022-09-16T13:41:56+00:00" + }, + { + "name": "react/dns", + "version": "v1.13.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/dns.git", + "reference": "eb8ae001b5a455665c89c1df97f6fb682f8fb0f5" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/dns/zipball/eb8ae001b5a455665c89c1df97f6fb682f8fb0f5", + "reference": "eb8ae001b5a455665c89c1df97f6fb682f8fb0f5", + "shasum": "" + }, + "require": { + "php": ">=5.3.0", + "react/cache": "^1.0 || ^0.6 || ^0.5", + "react/event-loop": "^1.2", + "react/promise": "^3.2 || ^2.7 || ^1.2.1" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36", + "react/async": "^4.3 || ^3 || ^2", + "react/promise-timer": "^1.11" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Dns\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async DNS resolver for ReactPHP", + "keywords": [ + "async", + "dns", + "dns-resolver", + "reactphp" + ], + "support": { + "issues": "https://github.com/reactphp/dns/issues", + "source": "https://github.com/reactphp/dns/tree/v1.13.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-06-13T14:18:03+00:00" + }, + { + "name": "react/event-loop", + "version": "v1.5.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/event-loop.git", + "reference": "bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/event-loop/zipball/bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354", + "reference": "bbe0bd8c51ffc05ee43f1729087ed3bdf7d53354", + "shasum": "" + }, + "require": { + "php": ">=5.3.0" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" + }, + "suggest": { + "ext-pcntl": "For signal handling support when using the StreamSelectLoop" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\EventLoop\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "ReactPHP's core reactor event loop that libraries can use for evented I/O.", + "keywords": [ + "asynchronous", + "event-loop" + ], + "support": { + "issues": "https://github.com/reactphp/event-loop/issues", + "source": "https://github.com/reactphp/event-loop/tree/v1.5.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2023-11-13T13:48:05+00:00" + }, + { + "name": "react/promise", + "version": "v3.2.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/promise.git", + "reference": "8a164643313c71354582dc850b42b33fa12a4b63" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/promise/zipball/8a164643313c71354582dc850b42b33fa12a4b63", + "reference": "8a164643313c71354582dc850b42b33fa12a4b63", + "shasum": "" + }, + "require": { + "php": ">=7.1.0" + }, + "require-dev": { + "phpstan/phpstan": "1.10.39 || 1.4.10", + "phpunit/phpunit": "^9.6 || ^7.5" + }, + "type": "library", + "autoload": { + "files": [ + "src/functions_include.php" + ], + "psr-4": { + "React\\Promise\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "A lightweight implementation of CommonJS Promises/A for PHP", + "keywords": [ + "promise", + "promises" + ], + "support": { + "issues": "https://github.com/reactphp/promise/issues", + "source": "https://github.com/reactphp/promise/tree/v3.2.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-05-24T10:39:05+00:00" + }, + { + "name": "react/socket", + "version": "v1.16.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/socket.git", + "reference": "23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/socket/zipball/23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1", + "reference": "23e4ff33ea3e160d2d1f59a0e6050e4b0fb0eac1", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.0", + "react/dns": "^1.13", + "react/event-loop": "^1.2", + "react/promise": "^3.2 || ^2.6 || ^1.2.1", + "react/stream": "^1.4" + }, + "require-dev": { + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36", + "react/async": "^4.3 || ^3.3 || ^2", + "react/promise-stream": "^1.4", + "react/promise-timer": "^1.11" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Socket\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Async, streaming plaintext TCP/IP and secure TLS socket server and client connections for ReactPHP", + "keywords": [ + "Connection", + "Socket", + "async", + "reactphp", + "stream" + ], + "support": { + "issues": "https://github.com/reactphp/socket/issues", + "source": "https://github.com/reactphp/socket/tree/v1.16.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-07-26T10:38:09+00:00" + }, + { + "name": "react/stream", + "version": "v1.4.0", + "source": { + "type": "git", + "url": "https://github.com/reactphp/stream.git", + "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/reactphp/stream/zipball/1e5b0acb8fe55143b5b426817155190eb6f5b18d", + "reference": "1e5b0acb8fe55143b5b426817155190eb6f5b18d", + "shasum": "" + }, + "require": { + "evenement/evenement": "^3.0 || ^2.0 || ^1.0", + "php": ">=5.3.8", + "react/event-loop": "^1.2" + }, + "require-dev": { + "clue/stream-filter": "~1.2", + "phpunit/phpunit": "^9.6 || ^5.7 || ^4.8.36" + }, + "type": "library", + "autoload": { + "psr-4": { + "React\\Stream\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Christian Lück", + "email": "christian@clue.engineering", + "homepage": "https://clue.engineering/" + }, + { + "name": "Cees-Jan Kiewiet", + "email": "reactphp@ceesjankiewiet.nl", + "homepage": "https://wyrihaximus.net/" + }, + { + "name": "Jan Sorgalla", + "email": "jsorgalla@gmail.com", + "homepage": "https://sorgalla.com/" + }, + { + "name": "Chris Boden", + "email": "cboden@gmail.com", + "homepage": "https://cboden.dev/" + } + ], + "description": "Event-driven readable and writable streams for non-blocking I/O in ReactPHP", + "keywords": [ + "event-driven", + "io", + "non-blocking", + "pipe", + "reactphp", + "readable", + "stream", + "writable" + ], + "support": { + "issues": "https://github.com/reactphp/stream/issues", + "source": "https://github.com/reactphp/stream/tree/v1.4.0" + }, + "funding": [ + { + "url": "https://opencollective.com/reactphp", + "type": "open_collective" + } + ], + "time": "2024-06-11T12:45:25+00:00" + }, + { + "name": "sebastian/diff", + "version": "4.0.6", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/ba01945089c3a293b01ba9badc29ad55b106b0bc", + "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc", + "shasum": "" + }, + "require": { + "php": ">=7.3" + }, + "require-dev": { + "phpunit/phpunit": "^9.3", + "symfony/process": "^4.2 || ^5" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "4.0-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + }, + { + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" + } + ], + "description": "Diff implementation", + "homepage": "https://github.com/sebastianbergmann/diff", + "keywords": [ + "diff", + "udiff", + "unidiff", + "unified diff" + ], + "support": { + "issues": "https://github.com/sebastianbergmann/diff/issues", + "source": "https://github.com/sebastianbergmann/diff/tree/4.0.6" + }, + "funding": [ + { + "url": "https://github.com/sebastianbergmann", + "type": "github" + } + ], + "time": "2024-03-02T06:30:58+00:00" + }, + { + "name": "squizlabs/php_codesniffer", + "version": "3.10.3", + "source": { + "type": "git", + "url": "https://github.com/PHPCSStandards/PHP_CodeSniffer.git", + "reference": "62d32998e820bddc40f99f8251958aed187a5c9c" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/62d32998e820bddc40f99f8251958aed187a5c9c", + "reference": "62d32998e820bddc40f99f8251958aed187a5c9c", + "shasum": "" + }, + "require": { + "ext-simplexml": "*", + "ext-tokenizer": "*", + "ext-xmlwriter": "*", + "php": ">=5.4.0" + }, + "require-dev": { + "phpunit/phpunit": "^4.0 || ^5.0 || ^6.0 || ^7.0 || ^8.0 || ^9.3.4" + }, + "bin": [ + "bin/phpcbf", + "bin/phpcs" + ], + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.x-dev" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Greg Sherwood", + "role": "Former lead" + }, + { + "name": "Juliette Reinders Folmer", + "role": "Current lead" + }, + { + "name": "Contributors", + "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer/graphs/contributors" + } + ], + "description": "PHP_CodeSniffer tokenizes PHP, JavaScript and CSS files and detects violations of a defined set of coding standards.", + "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer", + "keywords": [ + "phpcs", + "standards", + "static analysis" + ], + "support": { + "issues": "https://github.com/PHPCSStandards/PHP_CodeSniffer/issues", + "security": "https://github.com/PHPCSStandards/PHP_CodeSniffer/security/policy", + "source": "https://github.com/PHPCSStandards/PHP_CodeSniffer", + "wiki": "https://github.com/PHPCSStandards/PHP_CodeSniffer/wiki" + }, + "funding": [ + { + "url": "https://github.com/PHPCSStandards", + "type": "github" + }, + { + "url": "https://github.com/jrfnl", + "type": "github" + }, + { + "url": "https://opencollective.com/php_codesniffer", + "type": "open_collective" + } + ], + "time": "2024-09-18T10:38:58+00:00" + }, + { + "name": "symfony/console", + "version": "v5.4.44", + "source": { + "type": "git", + "url": "https://github.com/symfony/console.git", + "reference": "5b5a0aa66e3296e303e22490f90f521551835a83" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/console/zipball/5b5a0aa66e3296e303e22490f90f521551835a83", + "reference": "5b5a0aa66e3296e303e22490f90f521551835a83", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "symfony/deprecation-contracts": "^2.1|^3", + "symfony/polyfill-mbstring": "~1.0", + "symfony/polyfill-php73": "^1.9", + "symfony/polyfill-php80": "^1.16", + "symfony/service-contracts": "^1.1|^2|^3", + "symfony/string": "^5.1|^6.0" + }, + "conflict": { + "psr/log": ">=3", + "symfony/dependency-injection": "<4.4", + "symfony/dotenv": "<5.1", + "symfony/event-dispatcher": "<4.4", + "symfony/lock": "<4.4", + "symfony/process": "<4.4" + }, + "provide": { + "psr/log-implementation": "1.0|2.0" + }, + "require-dev": { + "psr/log": "^1|^2", + "symfony/config": "^4.4|^5.0|^6.0", + "symfony/dependency-injection": "^4.4|^5.0|^6.0", + "symfony/event-dispatcher": "^4.4|^5.0|^6.0", + "symfony/lock": "^4.4|^5.0|^6.0", + "symfony/process": "^4.4|^5.0|^6.0", + "symfony/var-dumper": "^4.4|^5.0|^6.0" + }, + "suggest": { + "psr/log": "For using the console logger", + "symfony/event-dispatcher": "", + "symfony/lock": "", + "symfony/process": "" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Console\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Eases the creation of beautiful and testable command line interfaces", + "homepage": "https://symfony.com", + "keywords": [ + "cli", + "command-line", + "console", + "terminal" + ], + "support": { + "source": "https://github.com/symfony/console/tree/v5.4.44" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-20T07:56:40+00:00" + }, + { + "name": "symfony/deprecation-contracts", + "version": "v2.5.3", + "source": { + "type": "git", + "url": "https://github.com/symfony/deprecation-contracts.git", + "reference": "80d075412b557d41002320b96a096ca65aa2c98d" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/80d075412b557d41002320b96a096ca65aa2c98d", + "reference": "80d075412b557d41002320b96a096ca65aa2c98d", + "shasum": "" + }, + "require": { + "php": ">=7.1" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "files": [ + "function.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "A generic function and convention to trigger deprecation notices", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.3" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2023-01-24T14:02:46+00:00" + }, + { + "name": "symfony/event-dispatcher", + "version": "v5.4.45", + "source": { + "type": "git", + "url": "https://github.com/symfony/event-dispatcher.git", + "reference": "72982eb416f61003e9bb6e91f8b3213600dcf9e9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/72982eb416f61003e9bb6e91f8b3213600dcf9e9", + "reference": "72982eb416f61003e9bb6e91f8b3213600dcf9e9", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "symfony/deprecation-contracts": "^2.1|^3", + "symfony/event-dispatcher-contracts": "^2|^3", + "symfony/polyfill-php80": "^1.16" + }, + "conflict": { + "symfony/dependency-injection": "<4.4" + }, + "provide": { + "psr/event-dispatcher-implementation": "1.0", + "symfony/event-dispatcher-implementation": "2.0" + }, + "require-dev": { + "psr/log": "^1|^2|^3", + "symfony/config": "^4.4|^5.0|^6.0", + "symfony/dependency-injection": "^4.4|^5.0|^6.0", + "symfony/error-handler": "^4.4|^5.0|^6.0", + "symfony/expression-language": "^4.4|^5.0|^6.0", + "symfony/http-foundation": "^4.4|^5.0|^6.0", + "symfony/service-contracts": "^1.1|^2|^3", + "symfony/stopwatch": "^4.4|^5.0|^6.0" + }, + "suggest": { + "symfony/dependency-injection": "", + "symfony/http-kernel": "" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\EventDispatcher\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/event-dispatcher/tree/v5.4.45" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:11:13+00:00" + }, + { + "name": "symfony/event-dispatcher-contracts", + "version": "v2.5.3", + "source": { + "type": "git", + "url": "https://github.com/symfony/event-dispatcher-contracts.git", + "reference": "540f4c73e87fd0c71ca44a6aa305d024ac68cb73" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/540f4c73e87fd0c71ca44a6aa305d024ac68cb73", + "reference": "540f4c73e87fd0c71ca44a6aa305d024ac68cb73", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "psr/event-dispatcher": "^1" + }, + "suggest": { + "symfony/event-dispatcher-implementation": "" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "2.5-dev" + }, + "thanks": { + "name": "symfony/contracts", + "url": "https://github.com/symfony/contracts" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Contracts\\EventDispatcher\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Generic abstractions related to dispatching event", + "homepage": "https://symfony.com", + "keywords": [ + "abstractions", + "contracts", + "decoupling", + "interfaces", + "interoperability", + "standards" + ], + "support": { + "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v2.5.3" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } ], - "support": { - "issues": "https://github.com/php-fig/container/issues", - "source": "https://github.com/php-fig/container/tree/1.1.2" - }, - "time": "2021-11-05T16:50:12+00:00" + "time": "2024-01-23T13:51:25+00:00" }, { - "name": "squizlabs/php_codesniffer", - "version": "3.10.3", + "name": "symfony/filesystem", + "version": "v5.4.45", "source": { "type": "git", - "url": "https://github.com/PHPCSStandards/PHP_CodeSniffer.git", - "reference": "62d32998e820bddc40f99f8251958aed187a5c9c" + "url": "https://github.com/symfony/filesystem.git", + "reference": "57c8294ed37d4a055b77057827c67f9558c95c54" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/PHPCSStandards/PHP_CodeSniffer/zipball/62d32998e820bddc40f99f8251958aed187a5c9c", - "reference": "62d32998e820bddc40f99f8251958aed187a5c9c", + "url": "https://api.github.com/repos/symfony/filesystem/zipball/57c8294ed37d4a055b77057827c67f9558c95c54", + "reference": "57c8294ed37d4a055b77057827c67f9558c95c54", "shasum": "" }, "require": { - "ext-simplexml": "*", - "ext-tokenizer": "*", - "ext-xmlwriter": "*", - "php": ">=5.4.0" + "php": ">=7.2.5", + "symfony/polyfill-ctype": "~1.8", + "symfony/polyfill-mbstring": "~1.8", + "symfony/polyfill-php80": "^1.16" }, "require-dev": { - "phpunit/phpunit": "^4.0 || ^5.0 || ^6.0 || ^7.0 || ^8.0 || ^9.3.4" + "symfony/process": "^5.4|^6.4" }, - "bin": [ - "bin/phpcbf", - "bin/phpcs" - ], "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.x-dev" - } + "autoload": { + "psr-4": { + "Symfony\\Component\\Filesystem\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] }, "notification-url": "https://packagist.org/downloads/", "license": [ - "BSD-3-Clause" + "MIT" ], "authors": [ { - "name": "Greg Sherwood", - "role": "Former lead" - }, - { - "name": "Juliette Reinders Folmer", - "role": "Current lead" + "name": "Fabien Potencier", + "email": "fabien@symfony.com" }, { - "name": "Contributors", - "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer/graphs/contributors" + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" } ], - "description": "PHP_CodeSniffer tokenizes PHP, JavaScript and CSS files and detects violations of a defined set of coding standards.", - "homepage": "https://github.com/PHPCSStandards/PHP_CodeSniffer", - "keywords": [ - "phpcs", - "standards", - "static analysis" - ], + "description": "Provides basic utilities for the filesystem", + "homepage": "https://symfony.com", "support": { - "issues": "https://github.com/PHPCSStandards/PHP_CodeSniffer/issues", - "security": "https://github.com/PHPCSStandards/PHP_CodeSniffer/security/policy", - "source": "https://github.com/PHPCSStandards/PHP_CodeSniffer", - "wiki": "https://github.com/PHPCSStandards/PHP_CodeSniffer/wiki" + "source": "https://github.com/symfony/filesystem/tree/v5.4.45" }, "funding": [ { - "url": "https://github.com/PHPCSStandards", - "type": "github" + "url": "https://symfony.com/sponsor", + "type": "custom" }, { - "url": "https://github.com/jrfnl", + "url": "https://github.com/fabpot", "type": "github" }, { - "url": "https://opencollective.com/php_codesniffer", - "type": "open_collective" + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" } ], - "time": "2024-09-18T10:38:58+00:00" + "time": "2024-10-22T13:05:35+00:00" }, { - "name": "symfony/console", - "version": "v5.4.44", + "name": "symfony/finder", + "version": "v5.4.45", "source": { "type": "git", - "url": "https://github.com/symfony/console.git", - "reference": "5b5a0aa66e3296e303e22490f90f521551835a83" + "url": "https://github.com/symfony/finder.git", + "reference": "63741784cd7b9967975eec610b256eed3ede022b" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/console/zipball/5b5a0aa66e3296e303e22490f90f521551835a83", - "reference": "5b5a0aa66e3296e303e22490f90f521551835a83", + "url": "https://api.github.com/repos/symfony/finder/zipball/63741784cd7b9967975eec610b256eed3ede022b", + "reference": "63741784cd7b9967975eec610b256eed3ede022b", "shasum": "" }, "require": { "php": ">=7.2.5", "symfony/deprecation-contracts": "^2.1|^3", - "symfony/polyfill-mbstring": "~1.0", - "symfony/polyfill-php73": "^1.9", - "symfony/polyfill-php80": "^1.16", - "symfony/service-contracts": "^1.1|^2|^3", - "symfony/string": "^5.1|^6.0" - }, - "conflict": { - "psr/log": ">=3", - "symfony/dependency-injection": "<4.4", - "symfony/dotenv": "<5.1", - "symfony/event-dispatcher": "<4.4", - "symfony/lock": "<4.4", - "symfony/process": "<4.4" - }, - "provide": { - "psr/log-implementation": "1.0|2.0" - }, - "require-dev": { - "psr/log": "^1|^2", - "symfony/config": "^4.4|^5.0|^6.0", - "symfony/dependency-injection": "^4.4|^5.0|^6.0", - "symfony/event-dispatcher": "^4.4|^5.0|^6.0", - "symfony/lock": "^4.4|^5.0|^6.0", - "symfony/process": "^4.4|^5.0|^6.0", - "symfony/var-dumper": "^4.4|^5.0|^6.0" - }, - "suggest": { - "psr/log": "For using the console logger", - "symfony/event-dispatcher": "", - "symfony/lock": "", - "symfony/process": "" + "symfony/polyfill-php80": "^1.16" }, "type": "library", "autoload": { "psr-4": { - "Symfony\\Component\\Console\\": "" + "Symfony\\Component\\Finder\\": "" }, "exclude-from-classmap": [ "/Tests/" @@ -477,16 +2041,10 @@ "homepage": "https://symfony.com/contributors" } ], - "description": "Eases the creation of beautiful and testable command line interfaces", + "description": "Finds files and directories via an intuitive fluent interface", "homepage": "https://symfony.com", - "keywords": [ - "cli", - "command-line", - "console", - "terminal" - ], "support": { - "source": "https://github.com/symfony/console/tree/v5.4.44" + "source": "https://github.com/symfony/finder/tree/v5.4.45" }, "funding": [ { @@ -502,38 +2060,35 @@ "type": "tidelift" } ], - "time": "2024-09-20T07:56:40+00:00" + "time": "2024-09-28T13:32:08+00:00" }, { - "name": "symfony/deprecation-contracts", - "version": "v2.5.3", + "name": "symfony/options-resolver", + "version": "v5.4.45", "source": { "type": "git", - "url": "https://github.com/symfony/deprecation-contracts.git", - "reference": "80d075412b557d41002320b96a096ca65aa2c98d" + "url": "https://github.com/symfony/options-resolver.git", + "reference": "74e5b6f0db3e8589e6cfd5efb317a1fc2bb52fb6" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/80d075412b557d41002320b96a096ca65aa2c98d", - "reference": "80d075412b557d41002320b96a096ca65aa2c98d", + "url": "https://api.github.com/repos/symfony/options-resolver/zipball/74e5b6f0db3e8589e6cfd5efb317a1fc2bb52fb6", + "reference": "74e5b6f0db3e8589e6cfd5efb317a1fc2bb52fb6", "shasum": "" }, "require": { - "php": ">=7.1" + "php": ">=7.2.5", + "symfony/deprecation-contracts": "^2.1|^3", + "symfony/polyfill-php73": "~1.0", + "symfony/polyfill-php80": "^1.16" }, "type": "library", - "extra": { - "branch-alias": { - "dev-main": "2.5-dev" - }, - "thanks": { - "name": "symfony/contracts", - "url": "https://github.com/symfony/contracts" - } - }, "autoload": { - "files": [ - "function.php" + "psr-4": { + "Symfony\\Component\\OptionsResolver\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" ] }, "notification-url": "https://packagist.org/downloads/", @@ -542,18 +2097,23 @@ ], "authors": [ { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" + "name": "Fabien Potencier", + "email": "fabien@symfony.com" }, { "name": "Symfony Community", "homepage": "https://symfony.com/contributors" } ], - "description": "A generic function and convention to trigger deprecation notices", + "description": "Provides an improved replacement for the array_replace PHP function", "homepage": "https://symfony.com", + "keywords": [ + "config", + "configuration", + "options" + ], "support": { - "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.3" + "source": "https://github.com/symfony/options-resolver/tree/v5.4.45" }, "funding": [ { @@ -569,7 +2129,7 @@ "type": "tidelift" } ], - "time": "2023-01-24T14:02:46+00:00" + "time": "2024-09-25T14:11:13+00:00" }, { "name": "symfony/polyfill-ctype", @@ -1121,6 +2681,68 @@ ], "time": "2024-09-09T11:45:10+00:00" }, + { + "name": "symfony/process", + "version": "v5.4.46", + "source": { + "type": "git", + "url": "https://github.com/symfony/process.git", + "reference": "01906871cb9b5e3cf872863b91aba4ec9767daf4" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/process/zipball/01906871cb9b5e3cf872863b91aba4ec9767daf4", + "reference": "01906871cb9b5e3cf872863b91aba4ec9767daf4", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "symfony/polyfill-php80": "^1.16" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Process\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Executes commands in sub-processes", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/process/tree/v5.4.46" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-06T09:18:28+00:00" + }, { "name": "symfony/service-contracts", "version": "v2.5.3", @@ -1204,6 +2826,68 @@ ], "time": "2023-04-21T15:04:16+00:00" }, + { + "name": "symfony/stopwatch", + "version": "v5.4.45", + "source": { + "type": "git", + "url": "https://github.com/symfony/stopwatch.git", + "reference": "fb2c199cf302eb207f8c23e7ee174c1c31a5c004" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/stopwatch/zipball/fb2c199cf302eb207f8c23e7ee174c1c31a5c004", + "reference": "fb2c199cf302eb207f8c23e7ee174c1c31a5c004", + "shasum": "" + }, + "require": { + "php": ">=7.2.5", + "symfony/service-contracts": "^1|^2|^3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\Stopwatch\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Provides a way to profile code", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/stopwatch/tree/v5.4.45" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-25T14:11:13+00:00" + }, { "name": "symfony/string", "version": "v5.4.44", diff --git a/front/config.php b/front/config.php index 2399f35..ffc7269 100644 --- a/front/config.php +++ b/front/config.php @@ -32,13 +32,13 @@ $config = new PluginGeninventorynumberConfig(); $config->getFromDB(1); -if (Plugin::isPluginActive("geninventorynumber")) { +if (Plugin::isPluginActive('geninventorynumber')) { Html::header( __('Inventory number generation', 'geninventorynumber'), $_SERVER['PHP_SELF'], - "tools", - "plugins", - "geninventorynumber" + 'tools', + 'plugins', + 'geninventorynumber', ); if (isset($_GET['glpi_tab'])) { $_SESSION['glpi_tabs']['plugingeninventorynumberconfig'] = $_GET['glpi_tab']; diff --git a/front/configfield.form.php b/front/configfield.form.php index 6fc86f3..1f1350c 100644 --- a/front/configfield.form.php +++ b/front/configfield.form.php @@ -31,7 +31,7 @@ include('../../../inc/includes.php'); $configfield = new PluginGeninventorynumberConfigField(); -if (isset($_POST["update_fields"]) && isset($_POST["ids"])) { +if (isset($_POST['update_fields']) && isset($_POST['ids'])) { foreach ($_POST['ids'] as $itemtype => $data) { $configfield->update($data); } diff --git a/hook.php b/hook.php index 852a2a5..1a538bd 100644 --- a/hook.php +++ b/hook.php @@ -52,18 +52,19 @@ function plugin_geninventorynumber_MassiveActions($type) $fields = PluginGeninventorynumberConfigField::getConfigFieldByItemType($type); if (PluginGeninventorynumberConfigField::isActiveForItemType($type)) { - if (Session::haveRight("plugin_geninventorynumber", CREATE)) { + if (Session::haveRight('plugin_geninventorynumber', CREATE)) { $actions['PluginGeninventorynumberGeneration' . MassiveAction::CLASS_ACTION_SEPARATOR . 'plugin_geninventorynumber_generate'] = __('Generate inventory number', 'geninventorynumber'); } - if (Session::haveRight("plugin_geninventorynumber", UPDATE)) { + if (Session::haveRight('plugin_geninventorynumber', UPDATE)) { $actions['PluginGeninventorynumberGeneration' . MassiveAction::CLASS_ACTION_SEPARATOR . 'plugin_geninventorynumber_overwrite'] = __('Regenerate inventory number (overwrite)', 'geninventorynumber'); } } } + return $actions; } @@ -71,13 +72,14 @@ function plugin_geninventorynumber_install() { $php_dir = Plugin::getPhpDir('geninventorynumber'); - $migration = new Migration("0.85+1.0"); + $migration = new Migration('0.85+1.0'); include_once($php_dir . '/inc/config.class.php'); include_once($php_dir . '/inc/profile.class.php'); include_once($php_dir . '/inc/configfield.class.php'); PluginGeninventorynumberConfig::install($migration); PluginGeninventorynumberProfile::install($migration); PluginGeninventorynumberConfigField::install($migration); + return true; } @@ -85,7 +87,7 @@ function plugin_geninventorynumber_uninstall() { $php_dir = Plugin::getPhpDir('geninventorynumber'); - $migration = new Migration("0.85+1.0"); + $migration = new Migration('0.85+1.0'); include_once($php_dir . '/inc/config.class.php'); include_once($php_dir . '/inc/profile.class.php'); include_once($php_dir . '/inc/configfield.class.php'); @@ -93,5 +95,6 @@ function plugin_geninventorynumber_uninstall() PluginGeninventorynumberProfile::removeRightsFromSession(); PluginGeninventorynumberProfile::uninstallProfile(); PluginGeninventorynumberConfigField::uninstall($migration); + return true; } diff --git a/inc/config.class.php b/inc/config.class.php index fdf52e1..e8291bb 100644 --- a/inc/config.class.php +++ b/inc/config.class.php @@ -37,27 +37,27 @@ class PluginGeninventorynumberConfig extends CommonDBTM { public static $rightname = 'config'; - public $dohistory = true; + public $dohistory = true; - /** - * Never reset the index - * @var int - */ + /** + * Never reset the index + * @var int + */ public const AUTO_RESET_NONE = 0; - /** - * Reset the index if the last number was generated on a different day - * @var int - */ + /** + * Reset the index if the last number was generated on a different day + * @var int + */ public const AUTO_RESET_DAILY = 1; - /** - * Reset the index if the last number was generated on a different month - * @var int - */ + /** + * Reset the index if the last number was generated on a different month + * @var int + */ public const AUTO_RESET_MONTHLY = 2; - /** - * Reset the index if the last number was generated on a different year - * @var int - */ + /** + * Reset the index if the last number was generated on a different year + * @var int + */ public const AUTO_RESET_YEARLY = 3; public static function getTypeName($nb = 0) @@ -69,19 +69,22 @@ public function defineTabs($options = []) { $ong = []; $this->addStandardTab(__CLASS__, $ong, $options); - $this->addStandardTab("PluginGeninventorynumberConfigField", $ong, $options); - $this->addStandardTab("Log", $ong, $options); + $this->addStandardTab('PluginGeninventorynumberConfigField', $ong, $options); + $this->addStandardTab('Log', $ong, $options); + return $ong; } public function getTabNameForItem(CommonGLPI $item, $withtemplate = 0) { if (get_class($item) == __CLASS__) { - $array_ret = []; + $array_ret = []; $array_ret[0] = __('General setup'); $array_ret[1] = __('GLPI\'s inventory items configuration', 'geninventorynumber'); + return $array_ret; } + return ''; } @@ -95,6 +98,7 @@ public static function displayTabContentForItem(CommonGLPI $item, $tabnum = 1, $ PluginGeninventorynumberConfigField::showForConfig($item->getID()); break; } + return true; } @@ -103,31 +107,31 @@ public function rawSearchOptions() $sopt = []; $sopt[] = [ - 'id' => 'common', - 'name' => __('Inventory number generation', 'geninventorynumber'), + 'id' => 'common', + 'name' => __('Inventory number generation', 'geninventorynumber'), ]; $sopt[] = [ - 'id' => '1', - 'table' => $this->getTable(), - 'field' => 'name', - 'name' => __('Field'), - 'datatype' => 'itemlink', + 'id' => '1', + 'table' => $this->getTable(), + 'field' => 'name', + 'name' => __('Field'), + 'datatype' => 'itemlink', ]; $sopt[] = [ - 'id' => '2', - 'table' => $this->getTable(), - 'field' => 'is_active', - 'name' => __('Active', 'geninventorynumber'), - 'datatype' => 'bool', + 'id' => '2', + 'table' => $this->getTable(), + 'field' => 'is_active', + 'name' => __('Active', 'geninventorynumber'), + 'datatype' => 'bool', ]; $sopt[] = [ - 'id' => '3', - 'table' => $this->getTable(), - 'field' => 'index', - 'name' => __('Global index position', 'geninventorynumber'), + 'id' => '3', + 'table' => $this->getTable(), + 'field' => 'index', + 'name' => __('Global index position', 'geninventorynumber'), ]; return $sopt; @@ -140,10 +144,10 @@ public function rawSearchOptions() public static function getAutoResetOptions(): array { return [ - self::AUTO_RESET_NONE => __('Never', 'geninventorynumber'), - self::AUTO_RESET_DAILY => __('Daily', 'geninventorynumber'), + self::AUTO_RESET_NONE => __('Never', 'geninventorynumber'), + self::AUTO_RESET_DAILY => __('Daily', 'geninventorynumber'), self::AUTO_RESET_MONTHLY => __('Monthly', 'geninventorynumber'), - self::AUTO_RESET_YEARLY => __('Yearly', 'geninventorynumber'), + self::AUTO_RESET_YEARLY => __('Yearly', 'geninventorynumber'), ]; } @@ -163,26 +167,27 @@ public function showForm($id, $options = []) 'params' => $options, 'auto_reset_methods' => self::getAutoResetOptions(), ]); + return true; } - /** - * Check if the index needs to be reset based on the configured auto-reset method - * @return bool - */ + /** + * Check if the index needs to be reset based on the configured auto-reset method + * @return bool + */ public static function needIndexReset(): bool { $config = new self(); $config->getFromDB(1); if ( - $config->fields['auto_reset_method'] === self::AUTO_RESET_NONE + $config->fields['auto_reset_method'] === self::AUTO_RESET_NONE || $config->fields['date_last_generated'] === null ) { return false; } - $current_date = strtotime($_SESSION['glpi_currenttime']); + $current_date = strtotime($_SESSION['glpi_currenttime']); $last_gen_date = strtotime($config->fields['date_last_generated']); switch ($config->fields['auto_reset_method']) { @@ -193,22 +198,23 @@ public static function needIndexReset(): bool case self::AUTO_RESET_YEARLY: return date('Y', $last_gen_date) !== date('Y', $current_date); } + return false; } - /** - * Reset the index to 0 and reset the last generated date - */ + /** + * Reset the index to 0 and reset the last generated date + */ public static function resetIndex(): void { /** @var DBmysql $DB */ global $DB; $DB->update(self::getTable(), [ - 'index' => 0, - 'date_last_generated' => $_SESSION['glpi_currenttime'] + 'index' => 0, + 'date_last_generated' => $_SESSION['glpi_currenttime'], ], [ - 'id' => 1 + 'id' => 1, ]); } @@ -223,7 +229,7 @@ public static function getNextIndex() $it = $DB->request([ 'SELECT' => ['index'], - 'FROM' => getTableForItemType(__CLASS__), + 'FROM' => getTableForItemType(__CLASS__), ]); if (count($it)) { return $it->current()['index'] + 1; @@ -237,12 +243,12 @@ public static function install(Migration $migration) /** @var DBmysql $DB */ global $DB; - $default_charset = DBConnection::getDefaultCharset(); + $default_charset = DBConnection::getDefaultCharset(); $default_collation = DBConnection::getDefaultCollation(); - $default_key_sign = DBConnection::getDefaultPrimaryKeySignOption(); + $default_key_sign = DBConnection::getDefaultPrimaryKeySignOption(); $table = getTableForItemType(__CLASS__); - if ($DB->tableExists("glpi_plugin_generateinventorynumber_config")) { + if ($DB->tableExists('glpi_plugin_generateinventorynumber_config')) { $fields = ['template_computer', 'template_monitor', 'template_printer', 'template_peripheral', 'template_phone' , 'template_networking', 'generate_ocs', 'generate_data_injection', 'generate_internal', @@ -250,16 +256,16 @@ public static function install(Migration $migration) 'peripheral_gen_enabled', 'phone_gen_enabled', 'networking_gen_enabled', 'computer_global_index', 'monitor_global_index', 'printer_global_index', 'peripheral_global_index', 'phone_global_index', - 'networking_global_index' + 'networking_global_index', ]; foreach ($fields as $field) { - $migration->dropField("glpi_plugin_generateinventorynumber_config", $field); + $migration->dropField('glpi_plugin_generateinventorynumber_config', $field); } - $migration->renameTable("glpi_plugin_generateinventorynumber_config", $table); + $migration->renameTable('glpi_plugin_generateinventorynumber_config', $table); } - if ($DB->tableExists("glpi_plugin_geninventorynumber_config")) { - $migration->renameTable("glpi_plugin_geninventorynumber_config", $table); + if ($DB->tableExists('glpi_plugin_geninventorynumber_config')) { + $migration->renameTable('glpi_plugin_geninventorynumber_config', $table); } if (!$DB->tableExists($table)) { @@ -275,11 +281,11 @@ public static function install(Migration $migration) ) ENGINE=InnoDB DEFAULT CHARSET={$default_charset} COLLATE={$default_collation} ROW_FORMAT=DYNAMIC;"; $DB->doQueryOrDie($sql, $DB->error()); - $tmp['id'] = 1; - $tmp['name'] = 'otherserial'; - $tmp['is_active'] = 1; - $tmp['index'] = 0; - $config = new self(); + $tmp['id'] = 1; + $tmp['name'] = 'otherserial'; + $tmp['is_active'] = 1; + $tmp['index'] = 0; + $config = new self(); $config->add($tmp); } else { $migration->addField($table, 'name', 'string', ['value' => 'otherserial']); @@ -299,7 +305,7 @@ public static function install(Migration $migration) $migration->addField($table, 'auto_reset_method', "int unsigned NOT NULL default '0'"); } - //Remove unused table + //Remove unused table if ($DB->tableExists('glpi_plugin_geninventorynumber_indexes')) { $migration->dropTable('glpi_plugin_geninventorynumber_indexes'); } @@ -317,10 +323,10 @@ public static function updateIndex() global $DB; $DB->update(getTableForItemType(__CLASS__), [ - 'index' => new QueryExpression($DB::quoteName('index') . ' + 1'), - 'date_last_generated' => $_SESSION['glpi_currenttime'] + 'index' => new QueryExpression($DB::quoteName('index') . ' + 1'), + 'date_last_generated' => $_SESSION['glpi_currenttime'], ], [ - 'is_active' => 1 + 'is_active' => 1, ]); } @@ -328,11 +334,12 @@ public static function isGenerationActive() { $config = new self(); $config->getFromDB(1); + return $config->fields['is_active']; } public static function getIcon() { - return "fas fa-random"; + return 'fas fa-random'; } } diff --git a/inc/configfield.class.php b/inc/configfield.class.php index 1382843..b5f5725 100644 --- a/inc/configfield.class.php +++ b/inc/configfield.class.php @@ -59,15 +59,15 @@ public static function install(Migration $migration) /** @var array $GENINVENTORYNUMBER_TYPES */ global $DB, $GENINVENTORYNUMBER_TYPES; - $default_charset = DBConnection::getDefaultCharset(); + $default_charset = DBConnection::getDefaultCharset(); $default_collation = DBConnection::getDefaultCollation(); - $default_key_sign = DBConnection::getDefaultPrimaryKeySignOption(); + $default_key_sign = DBConnection::getDefaultPrimaryKeySignOption(); $table = getTableForItemType(__CLASS__); - if ($DB->tableExists("glpi_plugin_geninventorynumber_fields")) { + if ($DB->tableExists('glpi_plugin_geninventorynumber_fields')) { //Only migrate itemtypes when it's only necessary, otherwise it breaks upgrade procedure ! - $migration->renameTable("glpi_plugin_geninventorynumber_fields", $table); + $migration->renameTable('glpi_plugin_geninventorynumber_fields', $table); } if (!$DB->tableExists($table)) { @@ -89,7 +89,7 @@ public static function install(Migration $migration) $migration->changeField($table, 'config_id', 'plugin_geninventorynumber_configs_id', "int {$default_key_sign} NOT NULL default '0'"); if ($migration->changeField($table, 'device_type', 'itemtype', 'string')) { $migration->migrationOneTable($table); - Plugin::migrateItemType([], ["glpi_displaypreferences"], [$table]); + Plugin::migrateItemType([], ['glpi_displaypreferences'], [$table]); } $migration->changeField($table, 'enabled', 'is_active', 'boolean'); $migration->changeField($table, 'use_index', 'use_index', 'boolean'); @@ -101,11 +101,11 @@ public static function install(Migration $migration) $field = new self(); foreach ($GENINVENTORYNUMBER_TYPES as $type) { if (class_exists($type) && !countElementsInTable($table, ['itemtype' => $type])) { - $input["plugin_geninventorynumber_configs_id"] = 1; - $input["itemtype"] = $type; - $input["template"] = "<#######>"; - $input["is_active"] = 0; - $input["index"] = 0; + $input['plugin_geninventorynumber_configs_id'] = 1; + $input['itemtype'] = $type; + $input['template'] = '<#######>'; + $input['is_active'] = 0; + $input['index'] = 0; $field->add($input); } @@ -118,13 +118,13 @@ public static function install(Migration $migration) ) { $max = $DB->request([ 'SELECT' => ['MAX' => 'date_creation as date'], - 'FROM' => $type::getTable() + 'FROM' => $type::getTable(), ])->current()['date']; $DB->update( $cfield::getTable(), ['date_last_generated' => $max], - ['id' => $cfield->getID()] + ['id' => $cfield->getID()], ); } } @@ -148,74 +148,76 @@ public static function showForConfig($id) echo "
"; echo "
"; echo ""; - echo ""; + echo "'; echo ""; echo ""; - echo ""; - echo ""; - echo ""; + echo ''; + echo ''; + echo ''; + echo ''; - echo ""; + echo ''; $rows = getAllDataFromTable(getTableForItemType(__CLASS__)); foreach ($rows as $data) { $itemtype = $data['itemtype']; $typename = is_a($itemtype, CommonDBTM::class, true) ? $itemtype::getTypeName() : $itemtype; - echo ""; + echo "'; echo ""; + echo "'; + echo ''; echo ""; + Dropdown::showYesNo("ids[$itemtype][is_active]", $data['is_active']); + echo ''; echo ""; + Dropdown::showYesNo("ids[$itemtype][use_index]", $data['use_index']); + echo ''; echo ""; + echo ''; echo ""; - echo ""; + echo ''; + echo ''; } echo ""; + echo ''; - echo "
" . __('GLPI\'s inventory items configuration', 'geninventorynumber') . "
" . __('GLPI\'s inventory items configuration', 'geninventorynumber') . '
" . __('Generation templates', 'geninventorynumber'); - echo "" . __('Active') . "" . __('Use global index', 'geninventorynumber') . "" . __('Index position', 'geninventorynumber') . "" . __('Index auto-reset method', 'geninventorynumber') . "
' . __('Active') . '' . __('Use global index', 'geninventorynumber') . '' . __('Index position', 'geninventorynumber') . '' . __('Index auto-reset method', 'geninventorynumber') . '
" . $typename . "" . $typename . '"; - echo ""; + echo ""; echo ""; - echo ""; - echo ""; - Dropdown::showYesNo("ids[$itemtype][is_active]", $data["is_active"]); - echo ""; - Dropdown::showYesNo("ids[$itemtype][use_index]", $data["use_index"]); - echo ""; - if ($data["is_active"] && !$data["use_index"]) { + if ($data['is_active'] && !$data['use_index']) { echo ""; } - echo ""; - if ($data["is_active"] && !$data["use_index"]) { + if ($data['is_active'] && !$data['use_index']) { Dropdown::showFromArray("ids[$itemtype][auto_reset_method]", PluginGeninventorynumberConfig::getAutoResetOptions(), [ - 'value' => $data['auto_reset_method'] ?? 0 + 'value' => $data['auto_reset_method'] ?? 0, ]); } - echo "
"; echo ""; - echo "
"; + echo ''; Html::closeForm(); } public function prepareInputForAdd($input) { - $input = parent::prepareInputForAdd($input); + $input = parent::prepareInputForAdd($input); $check_auto_reset = isset($input['is_active']) && isset($input['use_index']); - if ($check_auto_reset && (!$input["is_active"] || $input["use_index"])) { + if ($check_auto_reset && (!$input['is_active'] || $input['use_index'])) { $input['auto_reset_method'] = 0; } + return $input; } public function prepareInputForUpdate($input) { - $input = parent::prepareInputForUpdate($input); + $input = parent::prepareInputForUpdate($input); $check_auto_reset = isset($input['is_active']) && isset($input['use_index']); - if ($check_auto_reset && (!$input["is_active"] || $input["use_index"])) { + if ($check_auto_reset && (!$input['is_active'] || $input['use_index'])) { $input['auto_reset_method'] = 0; } + return $input; } @@ -225,15 +227,16 @@ public static function getEnabledItemTypes() global $DB; $it = $DB->request([ - 'SELECT' => ['itemtype'], + 'SELECT' => ['itemtype'], 'DISTINCT' => true, - 'FROM' => getTableForItemType(__CLASS__), - 'ORDER' => ['itemtype'] + 'FROM' => getTableForItemType(__CLASS__), + 'ORDER' => ['itemtype'], ]); $types = []; foreach ($it as $data) { $types[] = $data['itemtype']; } + return $types; } @@ -244,8 +247,8 @@ public static function isActiveForItemType($itemtype) $it = $DB->request([ 'SELECT' => ['is_active'], - 'FROM' => getTableForItemType(__CLASS__), - 'WHERE' => ['itemtype' => $itemtype] + 'FROM' => getTableForItemType(__CLASS__), + 'WHERE' => ['itemtype' => $itemtype], ]); if (count($it)) { return $it->current()['is_active']; @@ -268,19 +271,19 @@ public static function needIndexReset($itemtype): bool 'SELECT' => ['date_last_generated', 'auto_reset_method'], 'FROM' => self::getTable(), 'WHERE' => [ - 'itemtype' => $itemtype - ] + 'itemtype' => $itemtype, + ], ]); if ($iterator->count() > 0) { $data = $iterator->current(); if ( - $data['auto_reset_method'] === PluginGeninventorynumberConfig::AUTO_RESET_NONE + $data['auto_reset_method'] === PluginGeninventorynumberConfig::AUTO_RESET_NONE || $data['date_last_generated'] === null ) { return false; } - $current_date = strtotime($_SESSION['glpi_currenttime']); + $current_date = strtotime($_SESSION['glpi_currenttime']); $last_gen_date = strtotime($data['date_last_generated']); switch ($data['auto_reset_method']) { @@ -292,6 +295,7 @@ public static function needIndexReset($itemtype): bool return date('Y', $last_gen_date) !== date('Y', $current_date); } } + return false; } @@ -304,10 +308,10 @@ public static function resetIndex(string $itemtype): void global $DB; $DB->update(self::getTable(), [ - 'index' => 0, - 'date_last_generated' => $_SESSION['glpi_currenttime'] + 'index' => 0, + 'date_last_generated' => $_SESSION['glpi_currenttime'], ], [ - 'itemtype' => $itemtype + 'itemtype' => $itemtype, ]); } @@ -322,12 +326,13 @@ public static function getNextIndex($itemtype) $it = $DB->request([ 'SELECT' => ['index'], - 'FROM' => getTableForItemType(__CLASS__), - 'WHERE' => ['itemtype' => $itemtype] + 'FROM' => getTableForItemType(__CLASS__), + 'WHERE' => ['itemtype' => $itemtype], ]); if (count($it)) { return $it->current()['index'] + 1; } + return 0; } @@ -337,10 +342,10 @@ public static function updateIndex($itemtype) global $DB; $DB->update(getTableForItemType(__CLASS__), [ - 'index' => new QueryExpression($DB::quoteName('index') . ' + 1'), - 'date_last_generated' => $_SESSION['glpi_currenttime'] + 'index' => new QueryExpression($DB::quoteName('index') . ' + 1'), + 'date_last_generated' => $_SESSION['glpi_currenttime'], ], [ - 'itemtype' => $itemtype + 'itemtype' => $itemtype, ]); } @@ -351,12 +356,12 @@ public static function registerNewItemType($itemtype) } if (!countElementsInTable(getTableForItemType(__CLASS__), ['itemtype' => $itemtype])) { - $config = new self(); - $input["plugin_geninventorynumber_configs_id"] = 1; - $input["itemtype"] = $itemtype; - $input["template"] = "<#######>"; - $input["is_active"] = 0; - $input["index"] = 0; + $config = new self(); + $input['plugin_geninventorynumber_configs_id'] = 1; + $input['itemtype'] = $itemtype; + $input['template'] = '<#######>'; + $input['is_active'] = 0; + $input['index'] = 0; $config->add($input); } } diff --git a/inc/generation.class.php b/inc/generation.class.php index 1688c7b..01e7682 100644 --- a/inc/generation.class.php +++ b/inc/generation.class.php @@ -32,17 +32,16 @@ class PluginGeninventorynumberGeneration { - /** - * Flag that indicates whether serial update is allowed. - * Flag is set to true during massive plugin_geninventorynumber_generate/plugin_geninventorynumber_overwrite - * massive actions process, as this is the only place that should be used to update serial numbers when plugin is active. - * @var boolean - */ + /** + * Flag that indicates whether serial update is allowed. + * Flag is set to true during massive plugin_geninventorynumber_generate/plugin_geninventorynumber_overwrite + * massive actions process, as this is the only place that should be used to update serial numbers when plugin is active. + * @var boolean + */ private static $serial_update_allowed = false; public static function autoName($config, CommonDBTM $item) { - $template = Sanitizer::unsanitize($config['template']); $pattern = '/' @@ -65,9 +64,9 @@ public static function autoName($config, CommonDBTM $item) $autonum = $matches['autonum']; $suffix = $matches['suffix']; - // Find # mask length. - // autonum par may contains # at multiple places, for instance <#\Y-\m-\d_######>, so we try to find - // the longer "#" suite. + // Find # mask length. + // autonum par may contains # at multiple places, for instance <#\Y-\m-\d_######>, so we try to find + // the longer "#" suite. $mask = null; for ($i = 10; $i > 0; $i--) { $mask = str_repeat('#', $i); @@ -98,10 +97,10 @@ public static function autoName($config, CommonDBTM $item) date('m'), date('d'), $item->input['serial'] ?? $item->fields['serial'] ?? '', - $item->input['name'] ?? $item->fields['name'] ?? '', + $item->input['name'] ?? $item->fields['name'] ?? '', '', ], - $autonum + $autonum, ); $result = $prefix . $autonum . $suffix; @@ -109,21 +108,22 @@ public static function autoName($config, CommonDBTM $item) return Sanitizer::sanitize($result); } - /** - * @override CommonDBTM::preItemAdd - */ + /** + * @override CommonDBTM::preItemAdd + */ public static function preItemAdd(CommonDBTM $item) { $config = PluginGeninventorynumberConfigField::getConfigFieldByItemType(get_class($item)); if (in_array(get_class($item), PluginGeninventorynumberConfigField::getEnabledItemTypes())) { - if ((!Session::haveRight("plugin_geninventorynumber", CREATE))) { + if ((!Session::haveRight('plugin_geninventorynumber', CREATE))) { if (!isCommandLine()) { Session::addMessageAfterRedirect(__( 'You can\'t modify inventory number', - 'geninventorynumber' + 'geninventorynumber', ), true, ERROR); } + return; } @@ -145,17 +145,15 @@ public static function preItemAdd(CommonDBTM $item) } } - /** - * @override CommonDBTM::preItemUpdate - */ + /** + * @override CommonDBTM::preItemUpdate + */ public static function preItemUpdate(CommonDBTM $item) { - $active = PluginGeninventorynumberConfig::isGenerationActive() && - PluginGeninventorynumberConfigField::isActiveForItemType(get_class($item)); + $active = PluginGeninventorynumberConfig::isGenerationActive() && PluginGeninventorynumberConfigField::isActiveForItemType(get_class($item)); if ($active && !self::$serial_update_allowed) { if ( - isset($item->fields['otherserial'], $item->input['otherserial']) && - $item->fields['otherserial'] != $item->input['otherserial'] + isset($item->fields['otherserial'], $item->input['otherserial']) && $item->fields['otherserial'] != $item->input['otherserial'] ) { // Revert otherserial to previous value $item->input['otherserial'] = $item->fields['otherserial']; @@ -163,44 +161,45 @@ public static function preItemUpdate(CommonDBTM $item) Session::addMessageAfterRedirect( __('You can\'t modify inventory number', 'geninventorynumber'), true, - ERROR + ERROR, ); } } } } - /** - * @since version 0.85 - * - * @see CommonDBTM::showMassiveActionsSubForm() - **/ + /** + * @since version 0.85 + * + * @see CommonDBTM::showMassiveActionsSubForm() + **/ public static function showMassiveActionsSubForm(MassiveAction $ma) { /** @var array $GENINVENTORYNUMBER_TYPES */ global $GENINVENTORYNUMBER_TYPES; - // KK TODO: check if MassiveAction itemtypes are concerned - //if (in_array ($options['itemtype'], $GENINVENTORYNUMBER_TYPES)) { + // KK TODO: check if MassiveAction itemtypes are concerned + //if (in_array ($options['itemtype'], $GENINVENTORYNUMBER_TYPES)) { switch ($ma->getAction()) { - case "plugin_geninventorynumber_generate": - case "plugin_geninventorynumber_overwrite": - echo " "; + case 'plugin_geninventorynumber_generate': + case 'plugin_geninventorynumber_overwrite': + echo ' '; break; default: break; } + return true; } - /** - * Generate numbers from a massive update - * - * @since 9.1+1.0 - * - * @param CommonDBTM $item Existing item to update - */ + /** + * Generate numbers from a massive update + * + * @since 9.1+1.0 + * + * @param CommonDBTM $item Existing item to update + */ public static function doMassiveUpdate(CommonDBTM $item) { if (!in_array(get_class($item), PluginGeninventorynumberConfigField::getEnabledItemTypes())) { @@ -220,7 +219,7 @@ public static function doMassiveUpdate(CommonDBTM $item) $values['massiveaction'] = true; self::$serial_update_allowed = true; - $success = $tmp->update($values); + $success = $tmp->update($values); self::$serial_update_allowed = false; if (!$success) { @@ -231,27 +230,28 @@ public static function doMassiveUpdate(CommonDBTM $item) } else { PluginGeninventorynumberConfigField::updateIndex(get_class($item)); } + return true; } else { $values['otherserial'] = ''; + return $tmp->update($values); } } - /** - * @since version 0.85 - * - * @see CommonDBTM::processMassiveActionsForOneItemtype() - **/ + /** + * @since version 0.85 + * + * @see CommonDBTM::processMassiveActionsForOneItemtype() + **/ public static function processMassiveActionsForOneItemtype( MassiveAction $ma, CommonDBTM $item, array $ids ) { - switch ($ma->getAction()) { - case "plugin_geninventorynumber_generate": - case "plugin_geninventorynumber_overwrite": + case 'plugin_geninventorynumber_generate': + case 'plugin_geninventorynumber_overwrite': //KK Not sure we could have multiple itemtimes foreach ($ma->getItems() as $itemtype => $ids) { foreach ($ids as $id) { @@ -262,11 +262,11 @@ public static function processMassiveActionsForOneItemtype( continue; } - if ($ma->getAction() == "plugin_geninventorynumber_generate") { - //Only generates inventory number for object without it ! - if (isset($item->fields["otherserial"]) && ($item->fields["otherserial"] == "")) { - if (!Session::haveRight("plugin_geninventorynumber", CREATE)) { - $ma->itemDone($itemtype, $id, MassiveAction::ACTION_NORIGHT); + if ($ma->getAction() == 'plugin_geninventorynumber_generate') { + //Only generates inventory number for object without it ! + if (isset($item->fields['otherserial']) && ($item->fields['otherserial'] == '')) { + if (!Session::haveRight('plugin_geninventorynumber', CREATE)) { + $ma->itemDone($itemtype, $id, MassiveAction::ACTION_NORIGHT); } elseif (self::doMassiveUpdate($item)) { $ma->itemDone($itemtype, $id, MassiveAction::ACTION_OK); } else { @@ -277,9 +277,9 @@ public static function processMassiveActionsForOneItemtype( } } - //Or is overwrite action is selected - if (($ma->getAction() == "plugin_geninventorynumber_overwrite")) { - if (!Session::haveRight("plugin_geninventorynumber", UPDATE)) { + //Or is overwrite action is selected + if (($ma->getAction() == 'plugin_geninventorynumber_overwrite')) { + if (!Session::haveRight('plugin_geninventorynumber', UPDATE)) { $ma->itemDone($itemtype, $id, MassiveAction::ACTION_NORIGHT); } elseif (self::doMassiveUpdate($item)) { $ma->itemDone($itemtype, $id, MassiveAction::ACTION_OK); diff --git a/inc/profile.class.php b/inc/profile.class.php index de43728..3ebab94 100644 --- a/inc/profile.class.php +++ b/inc/profile.class.php @@ -34,19 +34,19 @@ class PluginGeninventorynumberProfile extends CommonDBTM { - public static $rightname = "config"; + public static $rightname = 'config'; - /** - * @param $ID integer - */ + /** + * @param $ID integer + */ public static function createFirstAccess($profiles_id) { - include_once(Plugin::getPhpDir('geninventorynumber') . "/inc/profile.class.php"); + include_once(Plugin::getPhpDir('geninventorynumber') . '/inc/profile.class.php'); $profile = new self(); foreach ($profile->getAllRights() as $right) { self::addDefaultProfileInfos( $profiles_id, - [$right['field'] => ALLSTANDARDRIGHT] + [$right['field'] => ALLSTANDARDRIGHT], ); } } @@ -58,7 +58,7 @@ public static function addDefaultProfileInfos($profiles_id, $rights) if ( !countElementsInTable( 'glpi_profilerights', - ['profiles_id' => $profiles_id, 'name' => $right] + ['profiles_id' => $profiles_id, 'name' => $right], ) ) { $myright['profiles_id'] = $profiles_id; @@ -95,9 +95,9 @@ public function showForm($ID, array $options = []) $profile->getFromDB($ID); $rights = $this->getAllRights(); - $profile->displayRightsChoiceMatrix($rights, ['canedit' => $canedit, - 'default_class' => 'tab_bg_2', - 'title' => __('General') + $profile->displayRightsChoiceMatrix($rights, ['canedit' => $canedit, + 'default_class' => 'tab_bg_2', + 'title' => __('General'), ]); if ($canedit) { @@ -107,7 +107,8 @@ public function showForm($ID, array $options = []) echo "
\n"; Html::closeForm(); } - echo ""; + echo ''; + return true; } @@ -115,12 +116,12 @@ public static function getAllRights() { return [ ['itemtype' => 'PluginGeninventorynumber', - 'label' => __('Generate inventory number', 'geninventorynumber'), - 'field' => 'plugin_geninventorynumber', - 'rights' => [CREATE => __('Create'), - UPDATE => __('Update') - ] - ] + 'label' => __('Generate inventory number', 'geninventorynumber'), + 'field' => 'plugin_geninventorynumber', + 'rights' => [CREATE => __('Create'), + UPDATE => __('Update'), + ], + ], ]; } @@ -134,7 +135,7 @@ public static function install(Migration $migration) PluginGeninventorynumberProfile::createFirstAccess($_SESSION['glpiactiveprofile']['id']); } - if ($DB->tableExists("glpi_plugin_geninventorynumber_profiles")) { + if ($DB->tableExists('glpi_plugin_geninventorynumber_profiles')) { foreach (getAllDataFromTable($table) as $data) { $profile = new self(); foreach ($profile->getAllRights() as $right => $rights) { @@ -142,12 +143,12 @@ public static function install(Migration $migration) !countElementsInTable( 'glpi_profilerights', ['profiles_id' => $data['profiles_id'], - 'name' => $rights['field'] - ] + 'name' => $rights['field'], + ], ) ) { - $profileRight = new ProfileRight(); - $myright = []; + $profileRight = new ProfileRight(); + $myright = []; $myright['name'] = $rights['field']; $myright['profiles_id'] = $data['profiles_id']; @@ -188,6 +189,7 @@ public static function displayTabContentForItem(CommonGLPI $item, $tabnum = 1, $ { $profile = new self(); $profile->showForm($item->getID()); + return true; } } diff --git a/setup.php b/setup.php index 5c0d1c1..d9a1f5f 100644 --- a/setup.php +++ b/setup.php @@ -31,9 +31,9 @@ define('PLUGIN_GENINVENTORYNUMBER_VERSION', '2.8.5'); // Minimal GLPI version, inclusive -define("PLUGIN_GENINVENTORYNUMBER_MIN_GLPI", "10.0.11"); +define('PLUGIN_GENINVENTORYNUMBER_MIN_GLPI', '10.0.11'); // Maximum GLPI version, exclusive -define("PLUGIN_GENINVENTORYNUMBER_MAX_GLPI", "10.0.99"); +define('PLUGIN_GENINVENTORYNUMBER_MAX_GLPI', '10.0.99'); function plugin_init_geninventorynumber() { @@ -43,12 +43,12 @@ function plugin_init_geninventorynumber() global $PLUGIN_HOOKS, $CFG_GLPI, $GENINVENTORYNUMBER_TYPES; $PLUGIN_HOOKS['csrf_compliant']['geninventorynumber'] = true; - $PLUGIN_HOOKS['post_init']['geninventorynumber'] = 'plugin_geninventorynumber_postinit'; + $PLUGIN_HOOKS['post_init']['geninventorynumber'] = 'plugin_geninventorynumber_postinit'; $GENINVENTORYNUMBER_TYPES = ['Computer', 'Monitor', 'Printer', 'NetworkEquipment', 'Peripheral', 'Phone', 'SoftwareLicense', 'Cable', 'Appliance', 'Certificate', 'ConsumableItem', 'Enclosure', - 'PassiveDCEquipment', 'PDU', 'Rack' + 'PassiveDCEquipment', 'PDU', 'Rack', ]; $plugin = new Plugin(); @@ -57,13 +57,13 @@ function plugin_init_geninventorynumber() Plugin::registerClass( 'PluginGeninventorynumberProfile', - ['addtabon' => ['Profile']] + ['addtabon' => ['Profile']], ); Plugin::registerClass('PluginGeninventorynumberConfig'); Plugin::registerClass('PluginGeninventorynumberConfigField'); if (Session::haveRight('config', UPDATE)) { - $PLUGIN_HOOKS["menu_toadd"]['geninventorynumber'] + $PLUGIN_HOOKS['menu_toadd']['geninventorynumber'] = ['tools' => 'PluginGeninventorynumberConfig']; } } @@ -81,7 +81,7 @@ function plugin_version_geninventorynumber() 'glpi' => [ 'min' => PLUGIN_GENINVENTORYNUMBER_MIN_GLPI, 'max' => PLUGIN_GENINVENTORYNUMBER_MAX_GLPI, - ] - ] + ], + ], ]; }