1
0
mirror of https://github.com/RSS-Bridge/rss-bridge.git synced 2025-01-17 14:18:35 +01:00

feat: new bridge RumbleBridge (#3150)

This commit is contained in:
Dag 2022-11-17 18:06:35 +01:00 committed by GitHub
parent 130212fba5
commit 3ee2c7f918
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

56
bridges/RumbleBridge.php Normal file
View File

@ -0,0 +1,56 @@
<?php
class RumbleBridge extends BridgeAbstract
{
const NAME = 'rumble.com bridge';
const URI = 'https://rumble.com';
const DESCRIPTION = 'Fetches the latest channel/user videos';
const MAINTAINER = 'dvikan';
const CACHE_TIMEOUT = 60 * 60; // 1h
const PARAMETERS = [
[
'account' => [
'name' => 'Account',
'type' => 'text',
'required' => true,
'defaultValue' => 'bjornandreasbullhansen',
],
'type' => [
'type' => 'list',
'name' => 'Type',
'values' => [
'Channel' => 'channel',
'User' => 'user',
]
],
]
];
public function collectData()
{
$account = $this->getInput('account');
$type = $this->getInput('type');
if ($type === 'channel') {
$url = "https://rumble.com/c/$account";
}
if ($type === 'user') {
$url = "https://rumble.com/user/$account";
}
$dom = getSimpleHTMLDOM($url);
foreach ($dom->find('li.video-listing-entry') as $video) {
$this->items[] = [
'title' => $video->find('h3', 0)->plaintext,
'uri' => self::URI . $video->find('a', 0)->href,
'author' => $account . '@rumble.com',
'content' => defaultLinkTo($video, self::URI)->innertext,
];
}
}
public function getName()
{
return 'Rumble.com ' . $this->getInput('account');
}
}