diff --git a/bridges/AnimeUltimeBridge.php b/bridges/AnimeUltimeBridge.php
new file mode 100644
index 00000000..82c2b5f7
--- /dev/null
+++ b/bridges/AnimeUltimeBridge.php
@@ -0,0 +1,109 @@
+ Type = A (Anime), D (Drama), T (Tokusatsu), or leave empty for everything
+ * @maintainer ORelio
+ * @update 2015-09-07
+ * @use1(type="A/D/T/Empty")
+ */
+class AnimeUltimeBridge extends BridgeAbstract {
+
+ private $filter = 'Releases';
+
+ public function collectData(array $param) {
+
+ //Add type filter if provided
+ $typeFilter = '';
+ if (!empty($param['type'])) {
+ if ($param['type'] == 'A' || $param['type'] == 'D' || $param['type'] == 'T') {
+ $typeFilter = $param['type'];
+ if ($typeFilter == 'A') { $this->filter = 'Anime'; }
+ if ($typeFilter == 'D') { $this->filter = 'Drama'; }
+ if ($typeFilter == 'T') { $this->filter = 'Tokusatsu'; }
+ } else $this->returnError('The provided type filter is invalid. Expecting A, D, T, or no filter', 400);
+ }
+
+ //Build date and filters for making requests
+ $thismonth = date('mY').$typeFilter;
+ $lastmonth = date('mY', mktime(0, 0, 0, date('n') - 1, 1, date('Y'))).$typeFilter;
+
+ //Process each HTML page until having 10 releases
+ $processedOK = 0;
+ foreach (array($thismonth, $lastmonth) as $requestFilter) {
+
+ //Retrive page contents
+ $website = 'http://www.anime-ultime.net/';
+ $url = $website.'history-0-1/'.$requestFilter;
+ $html = file_get_html($url) or $this->returnError('Could not request Anime-Ultime: '.$url, 404);
+
+ //Relases are sorted by day : process each day individually
+ foreach ($html->find('div.history', 0)->find('h3') as $daySection) {
+
+ //Retrieve day and build date information
+ $dateString = $daySection->plaintext;
+ $day = intval(substr($dateString, strpos($dateString, ' ') + 1, 2));
+ $item_date = strtotime(str_pad($day, 2, '0', STR_PAD_LEFT).'-'.substr($requestFilter, 0, 2).'-'.substr($requestFilter, 2, 4));
+ $release = $daySection->next_sibling()->next_sibling()->first_child(); //
day
<-- useful data in table rows
+
+ //Process each release of that day, ignoring first table row: contains table headers
+ while (!is_null($release = $release->next_sibling())) {
+ if (count($release->find('td')) > 0) {
+
+ //Retrieve metadata from table columns
+ $item_link_element = $release->find('td', 0)->find('a', 0);
+ $item_uri = $website.$item_link_element->href;
+ $item_name = html_entity_decode($item_link_element->plaintext);
+ $item_image = $website.substr($item_link_element->onmouseover, 37, strpos($item_link_element->onmouseover, ' ', 37) - 37);
+ $item_episode = html_entity_decode(str_pad($release->find('td', 1)->plaintext, 2, '0', STR_PAD_LEFT));
+ $item_fansub = $release->find('td', 2)->plaintext;
+ $item_type = $release->find('td', 4)->plaintext;
+
+ if (!empty($item_uri)) {
+
+ //Retrieve description from description page and convert relative image src info absolute image src
+ $html_item = file_get_contents($item_uri) or $this->returnError('Could not request Anime-Ultime: '.$item_uri, 404);
+ $item_description = substr($html_item, strpos($html_item, 'class="principal_contain" align="center">') + 41);
+ $item_description = substr($item_description, 0, strpos($item_description, ''));
+ $item_description = str_replace('src="images', 'src="'.$website.'images', $item_description);
+ $item_description = str_replace("\r", '', $item_description);
+ $item_description = str_replace("\n", '', $item_description);
+ $item_description = utf8_encode($item_description);
+
+ //Build and add final item
+ $item = new \Item();
+ $item->uri = $item_uri;
+ $item->title = $item_name.' '.$item_type.' '.$item_episode;
+ $item->author = $item_fansub;
+ $item->timestamp = $item_date;
+ $item->thumbnailUri = $item_image;
+ $item->content = $item_description;
+ $this->items[] = $item;
+ $processedOK++;
+
+ //Stop processing once limit is reached
+ if ($processedOK >= 10)
+ return;
+ }
+ }
+ }
+ }
+ }
+ }
+
+ public function getName() {
+ return 'Latest '.$this->filter.' - Anime-Ultime Bridge';
+ }
+
+ public function getURI() {
+ return 'http://www.anime-ultime.net/';
+ }
+
+ public function getCacheDuration() {
+ return 3600*3; // 3 hours
+ }
+
+}