commit
06fd83a6be
@ -0,0 +1,24 @@
|
||||
This is free and unencumbered software released into the public domain.
|
||||
|
||||
Anyone is free to copy, modify, publish, use, compile, sell, or
|
||||
distribute this software, either in source code form or as a compiled
|
||||
binary, for any purpose, commercial or non-commercial, and by any
|
||||
means.
|
||||
|
||||
In jurisdictions that recognize copyright laws, the author or authors
|
||||
of this software dedicate any and all copyright interest in the
|
||||
software to the public domain. We make this dedication for the benefit
|
||||
of the public at large and to the detriment of our heirs and
|
||||
successors. We intend this dedication to be an overt act of
|
||||
relinquishment in perpetuity of all present and future rights to this
|
||||
software under copyright law.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
For more information, please refer to <https://unlicense.org>
|
@ -0,0 +1,14 @@
|
||||
{
|
||||
"name": "brepo/phpquoteshellarg",
|
||||
"description": "Improved escape shell arguments for support of special charactars",
|
||||
"keywords": ["quoteshellarg", "escapeshellarg"],
|
||||
"homepage": "https://dev.brepo.ru/bayrepo/hestiacp",
|
||||
"type": "library",
|
||||
"license": "Unlicense",
|
||||
"require": {
|
||||
"php": ">=8.0"
|
||||
},
|
||||
"autoload": {
|
||||
"files":["src/Hestiacp/quoteshellarg/quoteshellarg.php"]
|
||||
}
|
||||
}
|
@ -0,0 +1,40 @@
|
||||
<?php
|
||||
declare (strict_types = 1);
|
||||
namespace Hestiacp\quoteshellarg;
|
||||
|
||||
/**
|
||||
* quotes shell arguments
|
||||
* (doing a better job than escapeshellarg)
|
||||
*
|
||||
* @param string|int|float $arg
|
||||
* @throws UnexpectedValueException if $arg contains null bytes
|
||||
* @return string
|
||||
*/
|
||||
|
||||
function quoteshellarg(string | int | float $arg): string
|
||||
{
|
||||
if (\is_float($arg)) {
|
||||
// 17: >The 53-bit significand precision gives from 15 to 17 significant decimal digits precision.
|
||||
return \escapeshellarg(\sprintf('%.17g', $arg));
|
||||
}
|
||||
if (\is_int($arg)) {
|
||||
return \escapeshellarg((string) $arg);
|
||||
}
|
||||
static $isUnix = null;
|
||||
if ($isUnix === null) {
|
||||
$isUnix = \in_array(PHP_OS_FAMILY, array('Linux', 'BSD', 'Darwin', 'Solaris'), true) || PHP_OS === 'CYGWIN';
|
||||
}
|
||||
if ($isUnix) {
|
||||
// PHP's built-in escapeshellarg() for unix is kindof garbage: https://3v4l.org/Hkv7h
|
||||
// corrupting-or-stripping UTF-8 unicode characters like "æøå" and non-printable characters like "\x01",
|
||||
// both of which are fully legal in unix shell arguments.
|
||||
// In single-quoted-unix-shell-arguments there are only 2 bytes that needs special attention: \x00 and \x27
|
||||
if (false !== \strpos($arg, "\x00")) {
|
||||
throw new \UnexpectedValueException('unix shell arguments cannot contain null bytes!');
|
||||
}
|
||||
return "'" . \strtr($arg, array("'" => "'\\''")) . "'";
|
||||
}
|
||||
// todo: quoteshellarg for windows? it's a nightmare though: https://docs.microsoft.com/en-us/archive/blogs/twistylittlepassagesallalike/everyone-quotes-command-line-arguments-the-wrong-way
|
||||
// fallback to php's builtin escapeshellarg
|
||||
return \escapeshellarg($arg);
|
||||
}
|
Loading…
Reference in new issue