(See README.en.md
for an English version.)
NOTE: En date du 25 septembre 2019, pytoutv ne fonctionne pas avec l'API de TOU.TV et n'est donc pas fonctionnel (voir problème #134.
pytoutv est une librairie écrite en Python 3 qui implémente un client pour TOU.TV.
Ce dépôt contient aussi une interface en ligne de commande.
pytoutv, grâce à l'API publique de TOU.TV (voir
toutv/config.py
pour les URL publiques), est en
mesure de récupérer les listes d'émissions et d'épisodes, obtenir des
informations sur des émissions ou des épisodes ou télécharger n'importe quel
fichier vidéo distribué publiquement par le service TOU.TV. Les informations
téléchargées, incluant les fichiers vidéo, sont destinées à un usage personnel
et ne devraient pas être redistribuées, à moins d'une autorisation préalable
fournie par les propriétaires de TOU.TV.
Le projet pytoutv n'est pas affilié, connecté ou associé à la Société Radio-Canada ou à CBFT-DT. La Société Radio-Canada ou CBFT-DT ne parrainent pas, n'approuvent pas ou n'endossent pas le projet pytoutv.
Note : bien qu'on parle de pytoutv 2, il n'existe pas de version 1 de pytoutv. Ce projet était auparavant connu sous le nom Tou.tv-console-application et ciblait Python 2. Son réusinage et son changement de nom vers pytoutv a mené à sa version 2. L'interface en ligne de commande demeure assez compatible avec la version précédente.
pytoutv requiert :
- Python 3.3+, avec :
Dépendances facultatives :
- termcolor (disponible sur PyPI): couleurs dans le terminal (CLI)
- PyQt4: interface Qt
pytoutv est réputé fonctionner sur Ubuntu, Debian, Fedora, Arch Linux et Mac OS X.
Il existe plusieurs méthodes pour installer pytoutv, la plus facile étant en passant par l'outil pip.
Veuillez noter que Python 3.3+ est requis peu importe la méthode utilisée.
Les méthodes d'installation avec pip et setup.py
vont automatiquement installer
les dépendances Python pour vous. Ceci dit, il peut être préférable de les
installer avec le gestionnaire de paquetages de votre distribution :
Sur Debian et Ubuntu, voici comment faire :
$ sudo aptitude install python3-crypto python3-requests python3-setuptools
Sur Fedora:
$ sudo yum install python3-crypto python3-requests python3-setuptools
Sur Arch Linux :
$ sudo pacman -Sy python-crypto python-requests python-setuptools
Assurez-vous d'avoir pip et setuptools. Votre distribution favorite devrait fournir une façon d'obtenir ces paquetages.
Installez ensuite pytoutv à l'aide de pip :
$ sudo pip install pytoutv
Sur Debian et Ubuntu, pip utilise par défaut les dépendances en Python 2. Pour régler ce problème, vous pouvez télécharger la version Python 3 de pip :
$ sudo aptitude install python3-pip
Par la suite, il ne suffit que de lancer l'installation avec ce paquet:
$ sudo pip3 install pytoutv
Sur Fedora, pip utilise par défaut les dépendances en Python 2. Pour régler ce problème, vous pouvez télécharger la version Python 3 de pip :
$ sudo yum install python3-pip
Par la suite, il ne suffit que de lancer l'installation avec ce paquet:
$ sudo python3-pip install pytoutv
Apple fournissent leur propre version de Python 2.7, pré-installé avec le système d'exploitation. C'est bien, mais nous avons besoin de 3.3 minimum.
Rendez-vous sur https://www.python.org/download/ pour télécharger la dernière version de Python compatible avec votre système.
Installez-le et ouvrez votre terminal. Si l'exécution de "python3.X" (X étant la sous-version installée, comme 3.3 ou 3.4) vous ouvre le mode de commande de Python 3.3+, tout est correct.
Quittez Python et exécutez:
"sudo pip3 install pytoutv"
Si tout se passe bien, vous devriez ensuite pouvoir l'exécuter!
À NOTER: Il semble que le script d'installation ne place pas de chemin global. Ajoutez: "/Library/Frameworks/Python.framework/Versions/3.4/bin" à "/etc/paths".
Tant que vous avez setuptools,
vous pouvez installer pytoutv directement en utilisant son script setup.py
:
-
Clonez le dépôt :
$ git clone https://github.com/bvanheu/pytoutv && cd pytoutv
-
Lancez le script d'installation :
$ sudo ./setup.py install
La documentation de la librairie n'est pas encore disponible.
L'outil en ligne de commande se nomme simplement toutv
. Les commandes les
plus couramment utilisées sont:
list
: afficher les émissions ou les épisodes d'une émission donnéeinfo
: afficher les informations d'une émission ou d'un épisodefetch
: télécharger un épisode ou tous les épisodes d'une émission donnéesearch
: chercher un mot-clé parmi les émissions et épisodeslogin
: fournir les informations de connexion pour Tou.TV Extra
Utilisez toutv -h
et toutv <commande> -h
pour obtenir plus d'informations à
propos des commandes et de leur utilisation.
Veuillez noter que toutv
honore les variables d'environnement HTTP_PROXY
et
HTTPS_PROXY
, qui devraient contenir les URL complètes des proxies à utiliser,
incluant le schéma (http://
, https://
).
Voici quelques exemples d'utilisation de l'interface en ligne de commande.
Ceci est requis pour pouvoir télécharger la version 720p des vidéos, et pour télécharger les émissions qui sont exclusives aux membres de la section Extra. Pour les autres cas, le login est optionnel.
$ toutv login <USERNAME>
Password: <PASSWORD>
Login successful
Token: c3458d85-6094-4030-9454-114380b2dec0
Note: toutes les émissions, incluant celles qui sont exclusives aux membres de la section Extra.
$ toutv list
2416249839: 2030, Le Big Bang démographique
2424965959: 26 lettres
1735242576: 30 vies
2415880603: Ainsi soient-ils
2284422575: Air de famille (Un)
2424965905: Alain Bashung faisons envie
2424966134: Alfred Hitchcock : Agent secret
2424966154: Alfred Hitchcock : Aventure malgache
...
$ toutv list 'physique ou chimie'
Physique ou chimie:
* 2160477711: S01E01 Des choses à faire avant de mourir
* 2160477623: S01E02 Agir ou laisser faire
* 2160483636: S01E03 Uniquement sexuel
* 2160483351: S01E04 Dommages collatéraux
* 2160490365: S01E05 Une victoire très curieuse
* 2160490718: S01E06 Il en faut du courage
* 2160497332: S01E07 Aller de l’avant
* 2160497534: S01E08 Le prix de la liberté
* 2161200777: S01E09 Égoïsme raisonnable
* 2161201111: S01E10 Réactions en chaîne
...
$ toutv info 'physique ou chimie'
Physique ou chimie [Unknown country]
Blanche, Irène, Jonathan et Rock, professeurs au Collège Zurbarán à Madrid, sont
censés servir de guides à leurs étudiants, alors qu'eux-mêmes ont une vie
compliquée. Ils découvriront assez rapidement qu'enseigner est la meilleure
façon d'apprendre la vie. Entre amours, amitiés, trahisons et déceptions, la
série espagnole Physique ou chimie met de l’avant les hauts et les bas que
vivent les élèves et les professeurs.
Infos:
* Tags: jeunesse, rogers
$ toutv info 'Série noire' S01E08
Série noire
Épisode 8 [S01E08]
Ébranlés par les récentes découvertes, Denis et Patrick tentent d’en savoir
davantage sur l’identité de la mystérieuse femme corpulente. Charlène et Judith
les aideront-elles à éclaircir cette nouvelle piste? Victimes d’un kidnapping,
Denis et Patrick découvrent, au péril de leur vie, les motivations étonnantes de
l’organisation criminelle de Bruno.
Infos:
* Air date: 2014-03-03
* Available bitrates:
* 461 kbps
* 561 kbps
* 925 kbps
* 1324 kbps
$ toutv fetch Enquete S2014E11
Enquête.S2014E11.La.guerre.d... 28.8 MiB 24/260 [##-----------------] 9%
$ toutv fetch -q MAX 'série noire' s01e05
Série.noire.S01E05.Épisode.5... 63.7 MiB 38/260 [###----------------] 14%
$ toutv fetch 'en audition avec simon'
En.audition.avec.Simon.S01E01... 16.5 MiB 15/15 [####################] 100%
En.audition.avec.Simon.S03E47... 24.9 MiB 23/23 [####################] 100%
En.audition.avec.Simon.S01E17... 9.9 MiB 9/27 [#######-------------] 33%
...
Vous pouvez utiliser un URL tou.tv au lieu d'un nom pour une émission ou un épisode, pour les commandes fetch
, info
, et list
.
$ toutv fetch http://ici.tou.tv/le-show-cache-2
$ toutv fetch http://ici.tou.tv/le-show-cache-2/S2014E02
$ toutv info http://ici.tou.tv/le-show-cache-2
$ toutv info http://ici.tou.tv/le-show-cache-2/S2014E02
$ toutv list http://ici.tou.tv/le-show-cache-2
$ toutv search politique
Effective query: politique
Episode: Loi 101 : Le malaise de René Lévesque (1re partie) [1481687502]
* Air date: 2010-04-27
* Emission ID: 1480980995
En 1976, le Parti québécois remporte pour la première fois les élections sur
la promesse d’être un bon gouvernement. Sans avoir mis la question de la
langue au cœur du débat électoral, René Lévesque avait promis de revoir la loi
22. Il confie ce mandat à Camille Laurin.
Episode: Loi 101 : le combat de Camille Laurin (2e partie) [1485812723]
* Air date: 2010-05-04
* Emission ID: 1480980995
La loi 101 sera, pour Camille Laurin, le combat de sa vie. Il s’entoure
d’abord des meilleurs esprits de son temps pour rédiger la Charte de la langue
française. René Lévesque lui demande d’aller convaincre la population
québécoise. Il affronte alors la colère de la communauté anglaise. À force de
ruse et de détermination, Camille Laurin dépose finalement le projet de loi
qui transformera le paysage linguistique du Québec.
Episode: Sommet des Amériques et Sommet des peuples [1498400939]
* Air date: 2010-05-18
* Emission ID: 1480980995
En 2001, un sommet parallèle s’organise dans la basse-ville de Québec pour
répliquer aux négociations officielles d’un traité de libre-échange des trois
Amériques. Le Sommet des peuples accueille 2000 représentants syndicaux, des
organismes sociaux et féministes, d’ici et d’ailleurs en Amérique. Cinquante
mille personnes sortent dans la rue pour s’opposer pacifiquement. D’autres
manifestants préfèrent affronter la police.
Episode: L'humour politique II : Les années 70 [1573008143]
* Air date: 2010-08-17
* Emission ID: 1480980995
Les années 70 sont fertiles en bouleversements. C’est l’ère des imitateurs, de
la montée du féminisme et le début de l’humour au féminin. Invités : Jean-Guy
Moreau, Claude Landré et Clémence DesRochers.
...
pytoutv est réputé fonctionner en date du dernier commit de ce dépôt. Si vous rencontrez un bogue quelconque, nous vous saurons gré de créer un problème et de fournir le plus de détails possibles à propos de votre situation, en plus de spécifier ce qui ne fonctionne pas tel que prévu.
Afin de contribuer à n'importe quelle composante de ce projet, envoyez-nous un pull request GitHub. Assurez-vous que votre code Python suive PEP-8, sauf pour de très longues lignes qui ne peuvent pas être cassées (longues chaines, par exemple).
La meilleure façon de développer pytoutv localement sans avoir à l'installer globalement est de créer un virtualenv. Si vous n'avez pas virtualenv, procurez-vous le (la plupart des distributions le fournissent en tant que paquetage).
-
Dans la racine du dépôt, créez le virtualenv :
$ virtualenv virt
-
Activez le virtualenv :
$ . ./virt/bin/activate
-
Utilisez la commande
develop
du scriptsetup.py
:$ ./setup.py develop
La première fois que ceci s'exécute, si vous n'avez pas toutes les dépendances du projet, elles seront téléchargées et installées (localement, dans
virt
).
Suite à l'étape 3, vous pouvez exécuter toutv
(qui pointe maintenant vers la
version locale de la commande). Vous pouvez aussi lancer ipython et importer
des modules de toutv
; les versions locales seront importées.
pytoutv suit un versionnage sémantique. Si vous soumettez un simple correctif, nous incrémenterons la version de patch. Si vous soumettez une nouvelle fonctionnalité, nous incrémenterons la version mineure. Aucune version 3 de pytoutv n'est prévu pour l'instant.
Nous tenons à remercier spécialement :