Page MenuHomePhorge

D25157.1737346302.diff
No OneTemporary

D25157.1737346302.diff

diff --git a/src/view/phui/PHUIObjectItemView.php b/src/view/phui/PHUIObjectItemView.php
--- a/src/view/phui/PHUIObjectItemView.php
+++ b/src/view/phui/PHUIObjectItemView.php
@@ -83,11 +83,29 @@
return $this->object;
}
+ /**
+ * Set the href attribute
+ *
+ * @param string|PhutilURI|null $href
+ * @return self
+ */
public function setHref($href) {
+
+ // We have not a very clear idea about what this method should receive
+ // We suspect that PhutilURI should be allowed... but let's log everything!
+ // https://we.phorge.it/T15316
+ self::logAlienHref($href, 'href');
+
$this->href = $href;
return $this;
}
+ /**
+ * Get the href attribute
+ *
+ * @see PHUIObjectItemView::setHref()
+ * @return string|PhutilURI|null
+ */
public function getHref() {
return $this->href;
}
@@ -136,7 +154,19 @@
return $this;
}
+ /**
+ * Set the image href attribute
+ *
+ * @param string|PhutilURI|null $image_href
+ * @return self
+ */
public function setImageHref($image_href) {
+
+ // We have not a very clear idea about what this method should receive
+ // We suspect that PhutilURI should be allowed... but let's log stuff!
+ // https://we.phorge.it/T15316
+ self::logAlienHref($image_href, 'image_href');
+
$this->imageHref = $image_href;
return $this;
}
@@ -659,8 +689,8 @@
$this->getImageIcon());
}
- if ($image && (phutil_nonempty_string($this->href) ||
- phutil_nonempty_string($this->imageHref))) {
+ if ($image && (phutil_nonempty_stringlike($this->href) ||
+ phutil_nonempty_stringlike($this->imageHref))) {
$image_href = ($this->imageHref) ? $this->imageHref : $this->href;
$image = phutil_tag(
'a',
@@ -899,4 +929,26 @@
return javelin_tag('span', $options, '');
}
+
+ /**
+ * Receive a href attribute and check if it has expected values
+ *
+ * TODO: Feel free to remove after 2023, if no more new reports arrive.
+ *
+ * https://we.phorge.it/T15316
+ *
+ * @param mixed $href
+ * @param string $variable_name
+ */
+ private static function logAlienHref($href, $variable_name) {
+ if (is_object($href) && !($href instanceof PhutilURI)) {
+ phlog(sprintf(
+ 'The variable %s received an unexpected type: %s. '.
+ 'Please share your stack trace as comment in Task %s',
+ $variable_name,
+ get_class($href),
+ 'https://we.phorge.it/T15316'));
+ }
+ }
+
}

File Metadata

Mime Type
text/plain
Expires
Mon, Jan 20, 04:11 (17 h, 30 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
1135647
Default Alt Text
D25157.1737346302.diff (2 KB)

Event Timeline