1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-22 23:02:42 +01:00

Fix PHP 8.1 "strlen(null)" exceptions which block rendering the Dashboard page

Summary:
`strlen()` was used in Phabricator to check if a generic value is a non-empty string.
This behavior is deprecated since PHP 8.1. Phorge adopts `phutil_nonempty_string()` as a replacement.

Note: this may highlight other absurd input values that might be worth correcting
instead of just ignoring. If phutil_nonempty_string() throws an exception in your
instance, report it to Phorge to evaluate and fix that specific corner case.

Closes T15295

Test Plan: Applied these four changes (on top of D25144 and D25145) and `/dashboard/` finally rendered in web browser.

Reviewers: O1 Blessed Committers, valerio.bozzolan

Reviewed By: O1 Blessed Committers, valerio.bozzolan

Subscribers: speck, tobiaswiese, valerio.bozzolan, Matthew, Cigaryno

Maniphest Tasks: T15295

Differential Revision: https://we.phorge.it/D25146
This commit is contained in:
Andre Klapper 2023-05-01 15:43:57 +02:00
parent f8ae17bb6a
commit bccd4f5981
4 changed files with 10 additions and 4 deletions

View file

@ -775,7 +775,7 @@ final class PhabricatorApplicationSearchController
$force_nux) { $force_nux) {
// Don't render NUX if the user has clicked away from the default page. // Don't render NUX if the user has clicked away from the default page.
if (strlen($this->getQueryKey())) { if (phutil_nonempty_string($this->getQueryKey())) {
return null; return null;
} }

View file

@ -179,7 +179,7 @@ abstract class PhabricatorApplicationSearchEngine extends Phobject {
$order = $saved->getParameter('order'); $order = $saved->getParameter('order');
$builtin = $query->getBuiltinOrderAliasMap(); $builtin = $query->getBuiltinOrderAliasMap();
if (strlen($order) && isset($builtin[$order])) { if (phutil_nonempty_string($order) && isset($builtin[$order])) {
$query->setOrder($order); $query->setOrder($order);
} else { } else {
// If the order is invalid or not available, we choose the first // If the order is invalid or not available, we choose the first

View file

@ -68,7 +68,7 @@ final class AphrontFormTokenizerControl extends AphrontFormControl {
$datasource->setViewer($this->getUser()); $datasource->setViewer($this->getUser());
$placeholder = null; $placeholder = null;
if (!strlen($this->placeholder)) { if (!phutil_nonempty_string($this->placeholder)) {
$placeholder = $datasource->getPlaceholderText(); $placeholder = $datasource->getPlaceholderText();
} }

View file

@ -19,6 +19,12 @@ final class PHUIInfoView extends AphrontTagView {
private $flush; private $flush;
private $icon; private $icon;
/**
* Set a title
*
* @param string|null $title
* @return self
*/
public function setTitle($title) { public function setTitle($title) {
$this->title = $title; $this->title = $title;
return $this; return $this;
@ -147,7 +153,7 @@ final class PHUIInfoView extends AphrontTagView {
} }
$title = $this->title; $title = $this->title;
if ($title || strlen($title)) { if ($title || phutil_nonempty_string($title)) {
$title = phutil_tag( $title = phutil_tag(
'h1', 'h1',
array( array(