Merge pull request #7642 from annando/fix-twitter
Fetch avatar and name on Twitter discovery
This commit is contained in:
commit
cc617e42a3
|
@ -1504,12 +1504,41 @@ class Probe
|
||||||
$data['baseurl'] = 'https://twitter.com';
|
$data['baseurl'] = 'https://twitter.com';
|
||||||
|
|
||||||
$curlResult = Network::curl($data['url'], false);
|
$curlResult = Network::curl($data['url'], false);
|
||||||
if ($curlResult->isSuccess()) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return $data;
|
|
||||||
}
|
|
||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$body = $curlResult->getBody();
|
||||||
|
$doc = new DOMDocument();
|
||||||
|
@$doc->loadHTML($body);
|
||||||
|
$xpath = new DOMXPath($doc);
|
||||||
|
|
||||||
|
$list = $xpath->query('//img[@class]');
|
||||||
|
foreach ($list as $node) {
|
||||||
|
$img_attr = [];
|
||||||
|
if ($node->attributes->length) {
|
||||||
|
foreach ($node->attributes as $attribute) {
|
||||||
|
$img_attr[$attribute->name] = $attribute->value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($img_attr['class'])) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strpos($img_attr['class'], 'ProfileAvatar-image') !== false) {
|
||||||
|
if (!empty($img_attr['src'])) {
|
||||||
|
$data['photo'] = $img_attr['src'];
|
||||||
|
}
|
||||||
|
if (!empty($img_attr['alt'])) {
|
||||||
|
$data['name'] = $img_attr['alt'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Check page for feed link
|
* @brief Check page for feed link
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue
Block a user