mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2025-04-04 16:49:35 +00:00
[Gab] feat: add new bridge GabBridge (#2920)
This commit is contained in:
parent
5b5f3b4254
commit
0a060b2ad6
57
bridges/GabBridge.php
Normal file
57
bridges/GabBridge.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
final class GabBridge extends BridgeAbstract
|
||||||
|
{
|
||||||
|
const NAME = 'Gab';
|
||||||
|
const URI = 'https://gab.com/';
|
||||||
|
const DESCRIPTION = 'Gab is an American alt-tech microblogging and social networking service';
|
||||||
|
const MAINTAINER = 'dvikan';
|
||||||
|
const PARAMETERS = [
|
||||||
|
[
|
||||||
|
'username' => [
|
||||||
|
'name' => 'username',
|
||||||
|
'type' => 'text',
|
||||||
|
'defaultValue' => 'realdonaldtrump',
|
||||||
|
],
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
public function collectData()
|
||||||
|
{
|
||||||
|
$username = $this->getUsername();
|
||||||
|
$response = json_decode(getContents(sprintf('https://gab.com/api/v1/account_by_username/%s', $username)));
|
||||||
|
$id = $response->id;
|
||||||
|
$gabs = json_decode(getContents(sprintf('https://gab.com/api/v1/accounts/%s/statuses?exclude_replies=true', $id)));
|
||||||
|
foreach ($gabs as $gab) {
|
||||||
|
if ($gab->reblog) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$this->items[] = [
|
||||||
|
'title' => $gab->content ?: 'Untitled',
|
||||||
|
'author' => $username,
|
||||||
|
'uri' => $gab->url ?? sprintf('https://gab.com/%s', $username),
|
||||||
|
'content' => $gab->content,
|
||||||
|
'timestamp' => (new \DateTime($gab->created_at))->getTimestamp(),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getName()
|
||||||
|
{
|
||||||
|
return 'Gab - ' . $this->getUsername();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getURI()
|
||||||
|
{
|
||||||
|
return 'https://gab.com/' . $this->getUsername();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getUsername(): string
|
||||||
|
{
|
||||||
|
$username = ltrim($this->getInput('username') ?? '', '@');
|
||||||
|
if (preg_match('#https?://gab\.com/(\w+)#', $username, $m)) {
|
||||||
|
return $m[1];
|
||||||
|
}
|
||||||
|
return $username;
|
||||||
|
}
|
||||||
|
}
|
@ -207,7 +207,7 @@ class FeedItem
|
|||||||
if (!is_string($title)) {
|
if (!is_string($title)) {
|
||||||
Debug::log('Title must be a string!');
|
Debug::log('Title must be a string!');
|
||||||
} else {
|
} else {
|
||||||
$this->title = trim($title);
|
$this->title = truncate(trim($title));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -50,6 +50,15 @@ function raw(string $s): string
|
|||||||
return $s;
|
return $s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function truncate(string $s, int $length = 150, $marker = '...'): string
|
||||||
|
{
|
||||||
|
$s = trim($s);
|
||||||
|
if (mb_strlen($s) <= $length) {
|
||||||
|
return $s;
|
||||||
|
}
|
||||||
|
return mb_substr($s, 0, $length) . $marker;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes unwanted tags from a given HTML text.
|
* Removes unwanted tags from a given HTML text.
|
||||||
*
|
*
|
||||||
|
19
tests/UtilsTest.php
Normal file
19
tests/UtilsTest.php
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace RssBridge\Tests;
|
||||||
|
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
final class UtilsTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testTruncate()
|
||||||
|
{
|
||||||
|
$this->assertSame('f...', truncate('foo', 1));
|
||||||
|
$this->assertSame('fo...', truncate('foo', 2));
|
||||||
|
$this->assertSame('foo', truncate('foo', 3));
|
||||||
|
$this->assertSame('foo', truncate('foo', 4));
|
||||||
|
$this->assertSame('fo[...]', truncate('foo', 2, '[...]'));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user