1
0
mirror of https://github.com/RSS-Bridge/rss-bridge.git synced 2025-10-24 21:16:06 +02:00

[BridgeAbstract] Update constant definition

LogMANOriginal
2016-09-09 13:09:21 +02:00
parent ecd21a22c6
commit 8d7e8fbbd6

@@ -1,8 +1,7 @@
`BridgeAbstract` is a base class intended for standard Bridges that need to filter HTML pages for content. `BridgeAbstract` is a base class intended for standard Bridges that need to filter HTML pages for content.
To create a new Bridge extending `BridgeAbstract` you must implement following functions: To create a new Bridge extending `BridgeAbstract` you must specify some [basic metadata](#basic-metadata) implement following functions:
- [`loadMetadatas`](#the-loadmetadatas-function) (**required**)
- [`collectData`](#the-collectdata-function) (**required**) - [`collectData`](#the-collectdata-function) (**required**)
- [`getName`](#the-getname-function) - [`getName`](#the-getname-function)
- [`getURI`](#the-geturi-function) - [`getURI`](#the-geturi-function)
@@ -10,59 +9,54 @@ To create a new Bridge extending `BridgeAbstract` you must implement following f
Find a [template](#template) at the end of this file. Find a [template](#template) at the end of this file.
## The `loadMetadatas` function ## Basic metadata
This function is used by **RSS-Bridge** to determine the name, maintainer name, website, last updated date... of the bridge, and the user parameters.
### Basic metadata
The basic metadata are : The basic metadata are :
```PHP ```PHP
$this->maintainer // Name of the maintainer const NAME // Name of the Bridge
$this->name // Name of the bridge const URI // URI to the target website of the bridge ("http://....")
$this->uri // URI to the target website of the bridge ("http://....") const DESCRIPTION // A brief description of the Bridge
$this->description // A brief description of the bridge const MAINTAINER // Name of the maintainer
$this->parameters // (optional) Definition of additional parameters const PARAMETERS // (optional) Definition of additional parameters
``` ```
Find a description of `$this->parameters` [below](#parameters) Find a description of `const PARAMETERS` [below](#parameters)
The default values are : The default values are :
```PHP ```PHP
$this->maintainer = 'No maintainer'; const NAME = "Unnamed bridge";
$this->name = "Unnamed bridge"; const URI = "";
$this->uri = ""; const DESCRIPTION = 'No description provided';
$this->description = 'No description provided'; const MAINTAINER = 'No maintainer';
$this->parameters = array(); const PARAMETERS = array();
``` ```
### Parameters ### Parameters
Parameters are defined in an array, which is used to generate an HTML `<form>` by **RSS-Bridge**. Parameters are defined in an array, which is used to generate an HTML `<form>` by **RSS-Bridge**.
The `$this->parameters` array is not mandatory if your bridge doesn't take any parameter. The `const PARAMETERS` array is not mandatory if your bridge doesn't take any parameter.
The first level of this array describes every possible usage of a bridge. The first level of this array describes every possible usage of a bridge.
The array can be a key-based array, but it is not necessary. The following syntaxes are hereby correct : The array can be a key-based array, but it is not necessary. The following syntaxes are hereby correct :
```PHP ```PHP
$this->parameters[] = ... const PARAMETERS = array(array(...), array(...));
$this->parameters['First usage of my bridge'] = ... const PARAMETERS = array('First usage' => array(...), 'Second usage' => array(...));
``` ```
It is worth mentioning that you can also define a set of parameters that will be applied to every possible utilization of your bridge. It is worth mentioning that you can also define a set of parameters that will be applied to every possible utilization of your bridge. To do this, just create a parameter array with the `global` key :
To do this, just create a parameter array with the `global` key :
```PHP ```PHP
$this->parameters['global'] = ... const PARAMETERS = array('global' => array(...));
``` ```
### Format specifications ### Format specifications
`$this->parameters[]` element is an associative array whose key is the input field identifier, and the value is another array containing all input fields names and values. `const PARAMETERS` element is an associative array whose key is the input field identifier, and the value is another array containing all input fields names and values.
Following elements are supported : Following elements are supported :
@@ -81,9 +75,9 @@ Hence, the most basic parameter definition is the following :
```PHP ```PHP
... ...
$this->parameters[] = array( const PARAMETERS = array(
'u'=>array('name'=>'Username') 'u' => array('name' => 'Username')
) );
... ...
``` ```
@@ -103,10 +97,10 @@ List values are defined in an associative array where keys are the string displa
```PHP ```PHP
... ...
'type'=>'list', 'type' => 'list',
'values'=>array( 'values' => array(
'Item A'=>'itemA' 'Item A' => 'itemA'
'Item B'=>'itemB' 'Item B' => 'itemB'
) )
... ...
``` ```
@@ -114,25 +108,24 @@ List values are defined in an associative array where keys are the string displa
If a more complex organization is required to display the values, the above key/value can be used to set a title as a key and another array as a value: If a more complex organization is required to display the values, the above key/value can be used to set a title as a key and another array as a value:
```PHP ```PHP
... ...
'type'=>'list', 'type' => 'list',
'values'=>array( 'values' => array(
'Item A'=>'itemA', 'Item A' => 'itemA',
'List 1'=>array( 'List 1' => array(
'Item C'=>'itemC', 'Item C' => 'itemC',
'Item D'=>'itemD' 'Item D' => 'itemD'
), ),
'List 2'=>array( 'List 2' => array(
'Item E'=>'itemE', 'Item E' => 'itemE',
'Item F'=>'itemF' 'Item F' => 'itemF'
), ),
'Item B'=>'itemB' 'Item B' => 'itemB'
) )
... ...
``` ```
## The `collectData` function ## The `collectData` function
This function takes as a parameter an array called `$param`, that is automatically filled with values from the user, according to the values defined in the parameters array in `loadMetadatas`.
This function is the place where all the website scrapping and the RSS feed generation process must be implemented. This function is the place where all the website scrapping and the RSS feed generation process must be implemented.
RSS elements collected by this function must be stored in the class variable `items[]`. RSS elements collected by this function must be stored in the class variable `items[]`.
@@ -172,7 +165,7 @@ Parameter | ATOM | HTML | (M)RSS
This function returns the name of the bridge as it will be displayed on the main page of **RSS-Bridge** or on top of the feed output (HTML, ATOM, etc...). This function returns the name of the bridge as it will be displayed on the main page of **RSS-Bridge** or on top of the feed output (HTML, ATOM, etc...).
**Notice:** **RSS-Bridge** will by default return `$this->name` which is defined in the [`loadMetadatas`](#the-loadmetadatas-function) function, so you only have to implement this function if you require different behavior! **Notice:** **RSS-Bridge** will by default return `const NAME` which is defined in the [`loadMetadatas`](#the-loadmetadatas-function) function, so you only have to implement this function if you require different behavior!
```PHP ```PHP
public function getName(){ public function getName(){
@@ -184,7 +177,7 @@ This function returns the name of the bridge as it will be displayed on the main
This function returns the URI to the destination site of the bridge. It will be used on the main page of rss-bridge when clicking your bridge name. This function returns the URI to the destination site of the bridge. It will be used on the main page of rss-bridge when clicking your bridge name.
**Notice:** **RSS-Bridge** will by default return `$this->uri` which is defined in the [`loadMetadatas`](#the-loadmetadatas-function) function, so you only have to implement this function if you require different behavior! **Notice:** **RSS-Bridge** will by default return `const URI` which is defined in the [`loadMetadatas`](#the-loadmetadatas-function) function, so you only have to implement this function if you require different behavior!
```PHP ```PHP
public function getURI(){ public function getURI(){
@@ -261,16 +254,14 @@ This is the minimum template for a new bridge:
```PHP ```PHP
<?php <?php
class MySiteBridge extends BridgeAbstract{ class MySiteBridge extends BridgeAbstract {
public function loadMetadatas(){ const NAME = 'Unnamed bridge';
$this->maintainer = 'No maintainer'; const URI = '';
$this->name = 'Unnamed bridge'; const DESCRIPTION = 'No description provided';
$this->uri = ''; const MAINTAINER = 'No maintainer';
$this->description = 'No description provided'; const PARAMETERS = array();
$this->parameters = array();
}
public function collectData(array $params){ public function collectData(){
// Implement your bridge here! // Implement your bridge here!
} }
} }