Release of v5.1.1-alpha1
Move all banners to GitHub. Adds library phpspreadsheet to JCB. Adds import item example to demo component. Updates the Superpower class with the GetRemote class in the plugin. Ensures the super power autoloader triggers the correct repositories.
This commit is contained in:
130
libraries/phpspreadsheet/vendor/ezyang/htmlpurifier/library/HTMLPurifier/VarParser/Flexible.php
vendored
Normal file
130
libraries/phpspreadsheet/vendor/ezyang/htmlpurifier/library/HTMLPurifier/VarParser/Flexible.php
vendored
Normal file
@ -0,0 +1,130 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Performs safe variable parsing based on types which can be used by
|
||||
* users. This may not be able to represent all possible data inputs,
|
||||
* however.
|
||||
*/
|
||||
class HTMLPurifier_VarParser_Flexible extends HTMLPurifier_VarParser
|
||||
{
|
||||
/**
|
||||
* @param mixed $var
|
||||
* @param int $type
|
||||
* @param bool $allow_null
|
||||
* @return array|bool|float|int|mixed|null|string
|
||||
* @throws HTMLPurifier_VarParserException
|
||||
*/
|
||||
protected function parseImplementation($var, $type, $allow_null)
|
||||
{
|
||||
if ($allow_null && $var === null) {
|
||||
return null;
|
||||
}
|
||||
switch ($type) {
|
||||
// Note: if code "breaks" from the switch, it triggers a generic
|
||||
// exception to be thrown. Specific errors can be specifically
|
||||
// done here.
|
||||
case self::C_MIXED:
|
||||
case self::ISTRING:
|
||||
case self::C_STRING:
|
||||
case self::TEXT:
|
||||
case self::ITEXT:
|
||||
return $var;
|
||||
case self::C_INT:
|
||||
if (is_string($var) && ctype_digit($var)) {
|
||||
$var = (int)$var;
|
||||
}
|
||||
return $var;
|
||||
case self::C_FLOAT:
|
||||
if ((is_string($var) && is_numeric($var)) || is_int($var)) {
|
||||
$var = (float)$var;
|
||||
}
|
||||
return $var;
|
||||
case self::C_BOOL:
|
||||
if (is_int($var) && ($var === 0 || $var === 1)) {
|
||||
$var = (bool)$var;
|
||||
} elseif (is_string($var)) {
|
||||
if ($var == 'on' || $var == 'true' || $var == '1') {
|
||||
$var = true;
|
||||
} elseif ($var == 'off' || $var == 'false' || $var == '0') {
|
||||
$var = false;
|
||||
} else {
|
||||
throw new HTMLPurifier_VarParserException("Unrecognized value '$var' for $type");
|
||||
}
|
||||
}
|
||||
return $var;
|
||||
case self::ALIST:
|
||||
case self::HASH:
|
||||
case self::LOOKUP:
|
||||
if (is_string($var)) {
|
||||
// special case: technically, this is an array with
|
||||
// a single empty string item, but having an empty
|
||||
// array is more intuitive
|
||||
if ($var == '') {
|
||||
return array();
|
||||
}
|
||||
if (strpos($var, "\n") === false && strpos($var, "\r") === false) {
|
||||
// simplistic string to array method that only works
|
||||
// for simple lists of tag names or alphanumeric characters
|
||||
$var = explode(',', $var);
|
||||
} else {
|
||||
$var = preg_split('/(,|[\n\r]+)/', $var);
|
||||
}
|
||||
// remove spaces
|
||||
foreach ($var as $i => $j) {
|
||||
$var[$i] = trim($j);
|
||||
}
|
||||
if ($type === self::HASH) {
|
||||
// key:value,key2:value2
|
||||
$nvar = array();
|
||||
foreach ($var as $keypair) {
|
||||
$c = explode(':', $keypair, 2);
|
||||
if (!isset($c[1])) {
|
||||
continue;
|
||||
}
|
||||
$nvar[trim($c[0])] = trim($c[1]);
|
||||
}
|
||||
$var = $nvar;
|
||||
}
|
||||
}
|
||||
if (!is_array($var)) {
|
||||
break;
|
||||
}
|
||||
$keys = array_keys($var);
|
||||
if ($keys === array_keys($keys)) {
|
||||
if ($type == self::ALIST) {
|
||||
return $var;
|
||||
} elseif ($type == self::LOOKUP) {
|
||||
$new = array();
|
||||
foreach ($var as $key) {
|
||||
$new[$key] = true;
|
||||
}
|
||||
return $new;
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if ($type === self::ALIST) {
|
||||
trigger_error("Array list did not have consecutive integer indexes", E_USER_WARNING);
|
||||
return array_values($var);
|
||||
}
|
||||
if ($type === self::LOOKUP) {
|
||||
foreach ($var as $key => $value) {
|
||||
if ($value !== true) {
|
||||
trigger_error(
|
||||
"Lookup array has non-true value at key '$key'; " .
|
||||
"maybe your input array was not indexed numerically",
|
||||
E_USER_WARNING
|
||||
);
|
||||
}
|
||||
$var[$key] = true;
|
||||
}
|
||||
}
|
||||
return $var;
|
||||
default:
|
||||
$this->errorInconsistent(__CLASS__, $type);
|
||||
}
|
||||
$this->errorGeneric($var, $type);
|
||||
}
|
||||
}
|
||||
|
||||
// vim: et sw=4 sts=4
|
38
libraries/phpspreadsheet/vendor/ezyang/htmlpurifier/library/HTMLPurifier/VarParser/Native.php
vendored
Normal file
38
libraries/phpspreadsheet/vendor/ezyang/htmlpurifier/library/HTMLPurifier/VarParser/Native.php
vendored
Normal file
@ -0,0 +1,38 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* This variable parser uses PHP's internal code engine. Because it does
|
||||
* this, it can represent all inputs; however, it is dangerous and cannot
|
||||
* be used by users.
|
||||
*/
|
||||
class HTMLPurifier_VarParser_Native extends HTMLPurifier_VarParser
|
||||
{
|
||||
|
||||
/**
|
||||
* @param mixed $var
|
||||
* @param int $type
|
||||
* @param bool $allow_null
|
||||
* @return null|string
|
||||
*/
|
||||
protected function parseImplementation($var, $type, $allow_null)
|
||||
{
|
||||
return $this->evalExpression($var);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $expr
|
||||
* @return mixed
|
||||
* @throws HTMLPurifier_VarParserException
|
||||
*/
|
||||
protected function evalExpression($expr)
|
||||
{
|
||||
$var = null;
|
||||
$result = eval("\$var = $expr;");
|
||||
if ($result === false) {
|
||||
throw new HTMLPurifier_VarParserException("Fatal error in evaluated code");
|
||||
}
|
||||
return $var;
|
||||
}
|
||||
}
|
||||
|
||||
// vim: et sw=4 sts=4
|
Reference in New Issue
Block a user