2022-03-22 21:33:29 +01:00
# getInput
The `getInput` function is used to receive a value for a parameter, specified in `const PARAMETERS`
```PHP
$this->getInput('your input name here');
```
2023-09-10 21:50:15 +02:00
`getInput` will either return the value for your parameter
or `null` if the parameter is unknown or not specified.
2022-03-22 21:33:29 +01:00
2024-04-04 19:28:56 +02:00
[Defined in lib/BridgeAbstract.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/BridgeAbstract.php )
2023-03-06 20:01:51 +01:00
# getKey
2023-09-10 21:50:15 +02:00
The `getKey` function is used to receive the key name to a selected list
value given the name of the list, specified in `const PARAMETERS`
2023-03-06 20:01:51 +01:00
Is able to work with multidimensional list arrays.
```PHP
// Given a multidimensional array like this
const PARAMETERS = [[
'country' => [
'name' => 'Country',
'type' => 'list',
'values' => [
'North America' => [
'Mexico' => 'mx',
'United States' => 'us'
],
'South America' => [
'Uruguay' => 'uy',
'Venezuela' => 've'
],
]
]
]],
// Provide the list name to the function
$this->getKey('country');
// if the selected value was "ve", this function will return "Venezuela"
```
2023-09-10 21:50:15 +02:00
`getKey` will either return the key name for your parameter or `null` if the parameter
is unknown or not specified.
2023-03-06 20:01:51 +01:00
2024-04-04 19:28:56 +02:00
[Defined in lib/BridgeAbstract.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/BridgeAbstract.php )
2022-03-22 21:33:29 +01:00
# getContents
The `getContents` function uses [cURL ](https://secure.php.net/manual/en/book.curl.php ) to acquire data from the specified URI while respecting the various settings defined at a global level by RSS-Bridge (i.e., proxy host, user agent, etc.). This function accepts a few parameters:
| Parameter | Type | Optional | Description
| --------- | ------ | ---------- | ----------
| `url` | string | *required* | The URL of the contents to acquire
| `header` | array | *optional* | An array of HTTP header fields to set, in the format `array('Content-type: text/plain', 'Content-length: 100')` , see [CURLOPT_HTTPHEADER ](https://secure.php.net/manual/en/function.curl-setopt.php )
| `opts` | array | *optional* | An array of cURL options in the format `array(CURLOPT_POST => 1);` , see [curl_setopt ](https://secure.php.net/manual/en/function.curl-setopt.php ) for a complete list of options.
2022-10-28 21:30:49 -04:00
| `returnFull` | boolean | *optional* | Specifies whether to return the response body from cURL (default) or the response body, code, headers, etc.
2022-03-22 21:33:29 +01:00
```PHP
$header = array('Content-type:text/plain', 'Content-length: 100');
$opts = array(CURLOPT_POST => 1);
$html = getContents($url, $header, $opts);
```
2024-04-04 19:28:56 +02:00
[Defined in lib/contents.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/contents.php )
2022-03-22 21:33:29 +01:00
# getSimpleHTMLDOM
2023-09-10 21:50:15 +02:00
The `getSimpleHTMLDOM` function is a wrapper for the
[simple_html_dom ](https://simplehtmldom.sourceforge.io/ ) [file_get_html ](https://simplehtmldom.sourceforge.io/docs/1.9/api/file_get_html/ ) function in order to provide context by design.
2022-03-22 21:33:29 +01:00
```PHP
$html = getSimpleHTMLDOM('your URI');
```
2024-04-04 19:28:56 +02:00
[Defined in lib/contents.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/contents.php )
2022-03-22 21:33:29 +01:00
# getSimpleHTMLDOMCached
2023-09-10 21:50:15 +02:00
The `getSimpleHTMLDOMCached` function does the same as the
[`getSimpleHTMLDOM` ](#getsimplehtmldom ) function,
except that the content received for the given URI is stored in a cache
and loaded from cache on the next request if the specified cache duration
was not reached.
2022-03-22 21:33:29 +01:00
2023-09-10 21:50:15 +02:00
Use this function for data that is very unlikely to change between consecutive requests to **RSS-Bridge** .
This function allows to specify the cache duration with the second parameter.
2022-03-22 21:33:29 +01:00
```PHP
2023-09-10 21:50:15 +02:00
$html = getSimpleHTMLDOMCached('your URI', 86400); // Duration 24h
2022-03-22 21:33:29 +01:00
```
2024-04-04 19:28:56 +02:00
[Defined in lib/contents.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/contents.php )
2022-03-22 21:33:29 +01:00
# returnClientError
2023-09-10 21:50:15 +02:00
The `returnClientError` function aborts execution of the current bridge
and returns the given error message with error code **400** :
2022-03-22 21:33:29 +01:00
```PHP
returnClientError('Your error message')
```
Use this function when the user provided invalid parameter or a required parameter is missing.
2024-04-04 19:28:56 +02:00
[Defined in lib/utils.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/utils.php )
2022-03-22 21:33:29 +01:00
# returnServerError
The `returnServerError` function aborts execution of the current bridge and returns the given error message with error code **500** :
```PHP
returnServerError('Your error message')
```
2023-09-10 21:50:15 +02:00
Use this function when a problem occurs that has nothing to do with the parameters provided by the user.
(like: Host service gone missing, empty data received, etc...)
2022-03-22 21:33:29 +01:00
2024-04-04 19:28:56 +02:00
[Defined in lib/utils.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/utils.php )
2022-03-22 21:33:29 +01:00
# defaultLinkTo
2023-09-10 21:50:15 +02:00
Automatically replaces any relative URL in a given string or DOM object
(i.e. the one returned by [getSimpleHTMLDOM ](#getsimplehtmldom )) with an absolute URL.
2022-03-22 21:33:29 +01:00
```php
defaultLinkTo ( mixed $content, string $server ) : object
```
Returns a DOM object (even if provided a string).
**Remarks**
* Only handles `<a>` and `<img>` tags.
**Example**
```php
$html = '< img src = "/blob/master/README.md" > ';
$html = defaultLinkTo($html, 'https://www.github.com/rss-bridge/rss-bridge'); // Using custom server
$html = defaultLinkTo($html, $this->getURI()); // Using bridge URL
// Output
// < img src = "https://www.github.com/rss-bridge/rss-bridge/blob/master/README.md" >
2022-05-10 03:37:53 -04:00
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2022-05-10 03:37:53 -04:00
# backgroundToImg
Replaces tags with styles of `backgroud-image` by `<img />` tags.
```php
backgroundToImg(mixed $htmlContent) : object
```
Returns a DOM object (even if provided a string).
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2022-05-10 03:37:53 -04:00
# extractFromDelimiters
Extract the first part of a string matching the specified start and end delimiters.
```php
function extractFromDelimiters(string $string, string $start, string $end) : mixed
```
Returns the extracted string if delimiters were found and false otherwise.
**Example**
```php
$string = '< div > Post author: John Doe< / div > ';
$start = 'author: ';
$end = '< ';
$extracted = extractFromDelimiters($string, $start, $end);
// Output
// 'John Doe'
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2022-05-10 03:37:53 -04:00
# stripWithDelimiters
2022-12-27 18:34:49 -05:00
Remove one or more part(s) of a string using a start and end delimiter.
2022-05-10 03:37:53 -04:00
It is the inverse of `extractFromDelimiters` .
```php
function stripWithDelimiters(string $string, string $start, string $end) : string
```
Returns the cleaned string, even if no delimiters were found.
**Example**
```php
$string = 'foo< script > superscript ( ) < / script > bar';
$start = '< script > ' ;
$end = '< / script > ';
$cleaned = stripWithDelimiters($string, $start, $end);
// Output
// 'foobar'
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2022-05-10 03:37:53 -04:00
# stripRecursiveHTMLSection
Remove HTML sections containing one or more sections using the same HTML tag.
```php
function stripRecursiveHTMLSection(string $string, string $tag_name, string $tag_start) : string
```
**Example**
```php
$string = 'foo< div class = "ads" > < div > ads< / div > ads< / div > bar';
$tag_name = 'div';
$tag_start = '< div class = "ads" > ';
$cleaned = stripRecursiveHTMLSection($string, $tag_name, $tag_start);
// Output
// 'foobar'
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2022-05-10 03:37:53 -04:00
# markdownToHtml
Converts markdown input to HTML using [Parsedown ](https://parsedown.org/ ).
2023-05-11 14:24:12 -05:00
| Parameter | Type | Optional | Description
| --------- | ------ | ---------- | ----------
| `string` | string | *required* | The URL of the contents to acquire
| `config` | array | *optional* | An array of Parsedown options in the format `['breaksEnabled' => true]`
Valid options:
| Option | Default | Description
| --------------- | ------- | -----------
| `breaksEnabled` | `false` | Enable automatic line breaks
| `markupEscaped` | `false` | Escape inline markup (HTML)
| `urlsLinked` | `true` | Automatically convert URLs to links
2022-05-10 03:37:53 -04:00
```php
2023-05-11 14:24:12 -05:00
function markdownToHtml(string $string, array $config = []) : string
2022-05-10 03:37:53 -04:00
```
**Example**
```php
$input = < < < EOD
RELEASE-2.8
* Share QR code of a token
* Dark mode improvemnet
* Fix some layout issues
* Add shortcut to launch the app with screenshot mode on
* Translation improvements
EOD;
$html = markdownToHtml($input);
// Output:
// < p > RELEASE-2.8< / p >
// < ul >
// < li > Share QR code of a token< / li >
// < li > Dark mode improvemnet< / li >
// < li > Fix some layout issues< / li >
// < li > Add shortcut to launch the app with screenshot mode on< / li >
// < li > Translation improvements< / li >
// < / ul >
```
2024-03-31 03:44:10 +02:00
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2024-03-31 03:44:10 +02:00
# e
The `e` function is used to convert special characters to HTML entities
```PHP
e('0 < 1 and 2 > 1');
```
`e` will return the content of the string escape that can be rendered as is in HTML
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2024-03-31 03:44:10 +02:00
# truncate
The `truncate` function is used to shorten a string if exceeds a certain length, and add a string indicating that the string has been shortened.
```PHP
truncate('Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed a neque nunc. Nam nibh sem.', 20 , '...');
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2024-03-31 03:44:10 +02:00
# sanitize
The `sanitize` function is used to remove some tags from a given HTML text.
```PHP
$html = '< head > < title > Sample Page< / title > < / head >
< body > < p > Lorem ipsum dolor sit amet, consectetur adipiscing elit...< / p >
< iframe src = "https://www.example.com" width = "600" height = "400" frameborder = "0" allowfullscreen > < / iframe >
< / body >
< / html > ';
$tags_to_remove = ['script', 'iframe', 'input', 'form'];
$attributes_to_keep = ['title', 'href', 'src'];
$text_to_keep = [];
sanitize($html, $tags_to_remove, $attributes_to_keep, $text_to_keep);
```
This function returns a simplehtmldom object of the remaining contents.
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2024-03-31 03:44:10 +02:00
# convertLazyLoading
The `convertLazyLoading` function is used to convert onvert lazy-loading images and frames (video embeds) into static elements. It accepts the HTML content as HTML objects or string objects. It returns the HTML content with fixed image/frame URLs (same type as input).
```PHP
$html = '< html >
< body style = "background-image: url('bgimage.jpg');" >
< h1 > Hello world!< / h1 >
< / body >
< / html >
backgroundToImg($html);
```
2024-04-04 19:28:56 +02:00
[Defined in lib/html.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/html.php )
2024-03-31 03:44:10 +02:00
# Json::encode
The `Json::encode` function is used to encode a value as à JSON string.
```PHP
$array = [
"foo" => "bar",
"bar" => "foo",
];
Json::encode($array, true, true);
```
2024-04-04 19:28:56 +02:00
[Defined in lib/utils.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/utils.php )
2024-03-31 03:44:10 +02:00
# Json::decode
The `Json::decode` function is used to decode a JSON string into à PHP variable.
```PHP
$json = '{
"foo": "bar",
"bar": "foo"
}';
Json::decode($json);
```
2024-04-04 19:28:56 +02:00
[Defined in lib/utils.php ](https://github.com/RSS-Bridge/rss-bridge/blob/master/lib/utils.php )