summaryrefslogtreecommitdiff
path: root/bridges/CollegeDeFranceBridge.php
blob: 1f8168329b5ae931ee735402fbd00be8da8aca46 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php
class CollegeDeFranceBridge extends BridgeAbstract {

	const MAINTAINER = 'pit-fgfjiudghdf';
	const NAME = 'CollegeDeFrance';
	const URI = 'http://www.college-de-france.fr/';
	const CACHE_TIMEOUT = 10800; // 3h
	const DESCRIPTION = 'Returns the latest audio and video from CollegeDeFrance';

	public function collectData(){
		$months = array(
			'01' => 'janv.',
			'02' => 'févr.',
			'03' => 'mars',
			'04' => 'avr.',
			'05' => 'mai',
			'06' => 'juin',
			'07' => 'juil.',
			'08' => 'août',
			'09' => 'sept.',
			'10' => 'oct.',
			'11' => 'nov.',
			'12' => 'déc.'
		);

		// The "API" used by the site returns a list of partial HTML in this form
		/* <li>
		 * 	<a href="/site/thomas-romer/guestlecturer-2016-04-15-14h30.htm" data-target="after">
		 * 		<span class="date"><span class="list-icon list-icon-video"></span>
		 * 		<span class="list-icon list-icon-audio"></span>15 avr. 2016</span>
		 * 		<span class="lecturer">Christopher Hays</span>
		 * 		<span class='title'>Imagery of Divine Suckling in the Hebrew Bible and the Ancient Near East</span>
		 * 	</a>
		 * </li>
		 */
		$html = getSimpleHTMLDOM(self::URI
		. 'components/search-audiovideo.jsp?fulltext=&siteid=1156951719600&lang=FR&type=all')
			or returnServerError('Could not request CollegeDeFrance.');

		foreach($html->find('a[data-target]') as $element) {
			$item = array();
			$item['title'] = $element->find('.title', 0)->plaintext;

			// Most relative URLs contains an hour in addition to the date, so let's use it
			// <a href="/site/yann-lecun/course-2016-04-08-11h00.htm" data-target="after">
			//
			// Sometimes there's an __1, perhaps it signifies an update
			// "/site/patrick-boucheron/seminar-2016-05-03-18h00__1.htm"
			//
			// But unfortunately some don't have any hours info
			// <a href="/site/institut-physique/
			// The-Mysteries-of-Decoherence-Sebastien-Gleyzes-[Video-3-35].htm" data-target="after">
			$timezone = new DateTimeZone('Europe/Paris');

			// strpos($element->href, '201') will break in 2020 but it'll
			// probably break prior to then due to site changes anyway
			$d = DateTime::createFromFormat(
				'!Y-m-d-H\hi',
				substr($element->href, strpos($element->href, '201'), 16),
				$timezone
			);

			if(!$d) {
				$d = DateTime::createFromFormat(
					'!d m Y',
					trim(str_replace(
						array_values($months),
						array_keys($months),
						$element->find('.date', 0)->plaintext
					)),
					$timezone
				);
			}

			$item['timestamp'] = $d->format('U');
			$item['content'] = $element->find('.lecturer', 0)->innertext
			. ' - '
			. $element->find('.title', 0)->innertext;

			$item['uri'] = self::URI . $element->href;
			$this->items[] = $item;
		}
	}
}