parent
fe83d763a3
commit
1584636e5b
1 changed files with 54 additions and 0 deletions
54
bridges/TinyLetterBridge.php
Normal file
54
bridges/TinyLetterBridge.php
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
<?php
|
||||||
|
class TinyLetterBridge extends BridgeAbstract {
|
||||||
|
const NAME = 'Tiny Letter';
|
||||||
|
const URI = 'https://tinyletter.com/';
|
||||||
|
const DESCRIPTION = 'Tiny Letter is a mailing list service';
|
||||||
|
const MAINTAINER = 'somini';
|
||||||
|
const PARAMETERS = array(
|
||||||
|
array(
|
||||||
|
'username' => array(
|
||||||
|
'name' => 'User Name',
|
||||||
|
'exampleValue' => 'forwards',
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
public function getName() {
|
||||||
|
$username = $this->getInput('username');
|
||||||
|
if (!is_null($username)) {
|
||||||
|
return static::NAME . ' | ' . $username;
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getURI() {
|
||||||
|
$username = $this->getInput('username');
|
||||||
|
if (!is_null($username)) {
|
||||||
|
return static::URI . urlencode($username);
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getURI();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function collectData() {
|
||||||
|
$archives = self::getURI() . '/archive';
|
||||||
|
$html = getSimpleHTMLDOMCached($archives)
|
||||||
|
or returnServerError('Could not load content');
|
||||||
|
|
||||||
|
foreach($html->find('.message-list li') as $element) {
|
||||||
|
$item = array();
|
||||||
|
|
||||||
|
$snippet = $element->find('p.message-snippet', 0);
|
||||||
|
$link = $element->find('.message-link', 0);
|
||||||
|
|
||||||
|
$item['title'] = $link->plaintext;
|
||||||
|
$item['content'] = $snippet->innertext;
|
||||||
|
$item['uri'] = $link->href;
|
||||||
|
$item['timestamp'] = strtotime($element->find('.message-date', 0)->plaintext);
|
||||||
|
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue