Ceci est une ancienne révision du document !



Mythtv

Cette page est en cours de réécriture, car elle n'est plus à jour.
Consulter le site de la communauté francophone MythTV de préférence : http://mythtv-fr.tuxfamily.org/

MYTHTV est une suite de logiciels de type centre multimédia qui permet initialement de voir et d'enregistrer la télévision. Elle permet également de voir des Dvd®, des Divx®, des photos, d'écouter des CD-audio, des mp3®, de récupérer rapidement les informations (actualité internet, météo etc…) à l'aide d'un clavier, joystick ou d'une télécommande.

Pour disposer de cette suite logicielle multimédia, vous pouvez :

- Installer uniquement le logiciel Mythtv

- Installer simplement des paquets supplémentaires dans votre installation ubuntu pour la transformer, c'est Mythbuntu.

- Faire une installation complète d'Ubuntu optimisée Mythtv.

Mythtv

Il suffit d'installer le paquet apt://mythtv-frontend pour la partie cliente et apt://mythtv-backend pour la partie serveur. Pour la configuration graphique installez aussi le paquet apt://mythbuntu-control-centre

Mythtv + Ubuntu = Mythbuntu

Il existe de nombreuses versions de Ubuntu : Ubuntu, Kubuntu, Xubuntu, Edubuntu et … Mythbuntu. Cette version est une solution gnu-linux spécialement développée pour Ubuntu permettant de transformer facilement son ordinateur en enregistreur de salon.

Il suffit d'installer le paquet apt://mythbuntu-desktop, attention ce paquet transforme complètement l'apparence de gnome en un très élégant enregistreur.

L'installation ne devrait pas poser de problème, veuillez cependant à enregistrer votre mot de passe d'accès qui sera configuré.

Pour plus de détails voir http://mythtv-fr.tuxfamily.org/wiki/mythbuntu_pas_a_pas_sur_ubuntu

Installation ubuntu optimisée Mythtv

Guide d'installation d'un serveur-client avec quelques problèmes et leurs solutions.
Pour les puristes je mettrai le signe (!) pour ce qu'il n'est pas recommandé de faire.

Partitions (système)

Lors de l'installation de Ubuntu, la principale question est le partitionnement des disques.

Il est recommandé de "voir large".

taillenomcommentaire
10 Go / (dit "racine")il est possible d'en mettre largement moins
100 Go /home (en cas de problème, cela permet de garder ses paramètres)
2 Go swap (à partir de 1Go mettre la taille de la ram ou ne pas en mettre(!) )

Activer les pilotes pour NVIDIA ou ATI : cocher une case dans Menu→Système→Administration→Pilote de périphériques

Redémarrer et… attention au plantage. Plus Ubuntu évolue moins il y en a, mais au besoin noter cette ligne de commande :

sudo dpkg-reconfigure xserver-xorg 

ou

sudo dpkg-reconfigure -phigh xserver-xorg

Activer l'auto-login (!) : Menu→SystèmeAdministration→Fenêtre de connexion → onglet [Sécurité]

Packages (initiaux)

commandescommentaires
sudo apt-get install pour installer les packets (pour sélectionner appuyer en même temps sur Ctrl sur firefox)
mplayer gxine vlc libdvdread3 oglelecteur vidéo et codec
flashplugin-nonfree lecteur video (flash)
tvtimepermet de tester la carte TV (existe aussi zaptv)
startupmanager permet de modifier le démarrage de l'ordinateur (multi-boot, affichage de log etc…)
lirc pour la télécommande ("creative Livedrive sequencer" pour utiliser la télécommande avec la carte son Audigy)
filezillaclient ftp (ça peut toujours servir)
samba partage réseau pour Windows
openssh-server indispensable pour utiliser putty
synergy trop bien si vous avez plus d'un PC côte à côte (un clavier/souris pour plusieurs PC) (fonctionne aussi avec tous les Windows, Vista inclus)
nvidia-settings pour configurer sa carte vidéo NVIDIA (exit aussi "envy" pour ATI et NVIDIA)
dmraidsi vous utilisez du raid
gparted pour partitionner ses disques (si vous en avez plus d'un)

Souris & Clavier bluetooth

Pour l'utilisation de clavier & souris en bluetooth.

Appuyer sur le petit bouton et taper la commande (pour chacun) :

sudo hidd --connect AA:BB:AA:BB:AA:BB

( AA:BB:… étant l'adresse indiqué au dos de l'appareil)

Après je vous recommande le GUI (l'Interface Utilisateur Graphique). Menu→Système→Préférences→Bluetooth

Ecran (carte NVIDIA)

Rechercher les spécifications techniques (balayage horizontal et vertical) sur le site web du constructeur de l'écran. Puis modifier le fichier en conséquence.

gksudo gedit /etc/X11/xorg.conf
Section "Monitor"
  Identifier     "Generic Monitor"
  HorizSync       31-81
  VertRefresh     56-76
  Option         "DPMS"
EndSection

(Option "DPMS" sert à éteindre l'écran lorsqu'il est inactif : je ferais bien de l'enlever ;-) )

Ensuite utiliser le GUI (beaucoup plus simple, mais maintenant vous pouvez cliquer sur Apply et quitter)

sudo nvidia-settings

Préférer cette ligne de commande à Menu→Système→Administration→NVIDIA X Server Settings, car dans ce cas il n'y aura pas de soucis pour enregistrer les modifications.

(Pour les cartes NVIDIA le mode "TwinView" est recommandé pour le multi-écran)

Disques durs

Pour plusieurs disques durs :

Utiliser gparted pour les identifier et les modifier (!!!). Menu→Système→Administration→Editeur de partition

Utiliser la commande mount…profiter…redémarrer… et c'est comme si rien n'avait été fait. Donc à moins que ce ne soit temporaire modifier le fichier fstab:

gksudo gedit /etc/fstab

et ajouter les lignes nécessaires :

/dev/sdc5                                 /media/MP3      ext3    relatime        0       0
/dev/mapper/sil_agaiabbifech1             /media/WXP      ntfs    uid=1000        0       0
UUID=cdd75cda-8147-41c6-923a-32dac89083d8 /media/FILMS    ext3    relatime        0       0

Explications pour chaque ligne :

1- grâce à gparted j'identifie le disque comme /dev/sdc5, je le monte/place sur /media/MP3 (que j'ai préalablement créé avec un petit "sudo mkdir /media/MP3"), de plus il est de type ext3, pour le reste je ne sais pas encore mais ça fonctionne.

2- même chose sauf que le disque est en raid (d'où le nom plus long) et le type est NTFS (pour Windows) (petit "sudo mkdir /media/WXP").

3- version moderne avec le UUID (genre "identifiant unique" pour disque dur, dans les cas précédents si on rajoute/déplace un disque/partition tout peut changer de nom /dev/sdc6), (type ext3 et petit "sudo mkdir /media/FILMS")

Pour identifier les UUID :

sudo blkid
sudo vol_id -u /dev/sda1

Il est possible de renseigner les différents emplacements dans mythtv en les séparant par ":" mais cela ne fonctionne pas toujours correctement. Avant j'utilisais dans le fichier fstab (ce qui n'accélère pas le démarrage de l'ordinateur) :

/media/FILMS/CLIPS  /media/MP3/CLIPS     none bind 0 0

J'ai évolué et j'utilise un lien maintenant. Taper directement en ligne de commande (en cas de problème de permission ajouter "sudo" devant) :

ln -s /media/MP3/CLIPS /media/FILMS/CLIPS

MYTHTV

commandescommentaires
sudo apt-get install pour installer les packets (pour sélectionner appuyer en même temps sur Ctrl sur firefox)
ubuntu-mythtv-frontend mythtv les 2 packages principaux (installeront également mysql et bien d'autres)
mysql-query-browser pour ceux qui s'y connaissent en sql
mythvideo mythmovies voir et gérer des vidéos
mythweather la météo
mythwebInterface web pour contrôler presque tout mythtv
mythstreamécouter et voir du streming
mythnewsrapide pour avoir des informations sur l'actualité
mythmusic gérer et écouter ses MP3
mythgame jouer
mythgalleryvoir ses photos
mythbrowsernavigateur internet optimisé télécommande
lame gstreamer0.10-plugins-bad gstreamer0.10-ffmpeg gstreamer0.10-plugins-good gstreamer0.10-plugins-ugly différents codec
mythpluginspour téléphoner (je ne l'utilise pas … encore)

Après leurs installations, ajouter vous au groupe mythtv et redémarrer puis lan cer : Menu?Système?Administration?MythTV Backend Setup

Renseigner les paramètres (les mêmes que ceux mis lors de l'installation des packages)

Puis : Menu→Son et vidéo→MythTV Frontend

En cas de problèmes, saisir les lignes de commandes suivantes
sudo dpkg-reconfigure mythtv-common
sudo dpkg-reconfigure mythtv-database 

Pour ceux qui apprécient les jolies animations en écoutant de la musique je recommande (par ordre descroissant) les plugins suivants :

sudo apt-get install libvisual-0.4-plugins  synaesthesia libvisual-projectm

libvisual-projectm doit être très beau mais personnellement, il n'a jamais fonctionné et a même réussi à fermer mythtv.

Mes préférés : Goom; BumpScope; LibVisual-jakdaw; LibVisual-jess; MonoScope; LibVisual-lv_gltest; LibVisual-infinite; LibVisual-corona; Synaesthesia;

Télécommande (spécificité pour Audigy Platinum eX)

Bon nombre de télécommandes fonctionnent toutes seules et le package suivant vous y aidera.

sudo apt-get install mythbuntu-lirc-generator

Ce n'est pas mon cas avec la carte son Audigy Platinum eX, pour la faire fonctionner je dois modifier certains fichiers :

gksudo gedit /etc/lirc/hardware.conf

Et ajouter le paramètre suivant : REMOTE_DEVICE="/dev/snd/midiC0D1"

Dans le fichier /usr/share/lirc/remotes/creative/lircd.conf.livedrive changer la ligne : name rm1000 –> name Creative_RM900

gksudo gedit /etc/modprobe.d/alsa-base

Ajouter : options snd-emu10k1 index=0 enable_ir=1

Pour la RM900 (comme il l'appelle) modifier le fichier suivant : gksudo gedit /etc/lirc/lircd.conf Par celui ci: lircd.conf.txt

Par défaut les paramètres de lirc sont dans $HOME/.lircrc mais mythtv se rajoute un fichier complémentaire, dans mon cas je n'utilise que celui de mythtv et j'ajoute un lien vers celui-ci:

rm $HOME/.lircrc
ln -s $HOME/.mythtv/lircrc  $HOME/.lircrc
En cas de problème

Pour tester la télécommande : irw (appuyer des touches de la télécommande)

Pour lancer (dans mon cas) : sudo lircd –driver=livedrive_midi –device=/dev

Les menus se situent dans /usr/share/mythtv. Ils sont écrits en xml.

Le principal est "mainmenu.xml" mais il en existe bien d'autres comme videomenu.xml, info_munu.xml etc…

En éditant le premier on remarque un menu caché le Shutdown ("Arrêt").

Il est donc possible possible de modifier le texte et l'image associés ainsi que l'action qu'ils effectuent. Exemple :

codecommentaire
<button> flag de début
<type>VCD_PLAY</type>type d'image
<text>Play VCD</text>texte par défaut
<text lang="FR">Lecture VCD</text>texte pour la langue française
<action>VCD_PLAY</action>action
</button>flag de fin

Je recommande un backup avant de les modifier, mais une réinstallation du package "mythtv",après leurs suppression, permet de les récupérer sans avoir besoin de tout réinstaller.

Petite astuce pour lancer un programme extérieur :

codecommentaire
<button> flag de début
<type>MUSIC_SCAN</type>type d'image
<text>My program</text>texte par défaut
<text lang="FR">Mon programme</text>texte pour la langue française
<action>EXEC monprogramme</action>action
</button>flag de fin

(voir exemple dans :Intégration dans le menu)

MYTHVIDEO

Lire un DVD protégé

(c'est malheureux de ne pas pouvoir lire un DVD que l'on a acheté en toute légalité)

sudo apt-get install libdvdcss2
Désactiver le lancement automatique à l'insertion d'un DVD ou CDrom

Lancer Nautilus :

Edition→ Préférences → onglets : Supports … et adapter.

Réduire la taille des sous-titres

Dans Mythtv : Paramètres→Paramètres médias→Paramètres Vidéos→Paramètres du lecteur

Lecteur :

mplayer -fs -zoom -quiet -vo xv -subfont-text-scale 2 %s

Internal :

mplayer vcd:// -cdrom-device %d -fs -zoom -vo xv
Reconnaissance des films (affiches, résumé et casting)

Pour l'avoir en français, changer les scripts dans Paramètres→Paramètres médias→Paramètres Vidéos→Paramètres globaux

/usr/share/mythtv/mythvideo/scripts/imdb.pl -M tv=no;video=no
->
/usr/share/mythtv/mythvideo/scripts/allocine.pl –M
/usr/share/mythtv/mythvideo/scripts/imdb.pl –P
->
/usr/share/mythtv/mythvideo/scripts/allocine.pl -P
/usr/share/mythtv/mythvideo/scripts/imdb.pl –D
->
/usr/share/mythtv/mythvideo/scripts/allocine.pl –D
Petit bug la fenêtre IMDB reste affichée
find /usr/share/mythtv/themes/ -name "video-ui.xml" -print | xargs sudo sed -i 's/enterimdb/entertmdb/g'
Petit bug dans allocine.pl lorsqu'il ne trouve pas le film
gksudo gedit /usr/share/mythtv/mythvideo/scripts/allocine.pl

En fait le script n'est plus tenu à jour. Remplacer le fichier par ceci (mythtv 0.22):

#!/usr/bin/perl -w

#
# This perl script is intended to perform movie data lookups in french based on 
# the www.allocine.fr website
#
# For more information on MythVideo's external movie lookup mechanism, see
# the README file in this directory.
#
# Original author: Xavier Hervy (maxpower44 AT tiscali DOT fr)

# changes:
#   20-10-2009: Geoffroy Geerseau ( http://www.soslinux.net : jamdess AT soslinux DOT net )
#   Modified for the new allocine templates
#   25-10-2009: Geoffroy Geerseau ( http://www.soslinux.net : jamdess AT soslinux DOT net )
#   Poster download correction
#   Userrating correction
#   02-11-2009: Geoffroy Geerseau
#   Allocine have, once again, change their templates...
   
use File::Basename;
use File::Copy;
use lib dirname($0);
use Encode;
use utf8;
use Encode 'from_to';
use MythTV::MythVideoCommon;

use vars qw($opt_h $opt_r $opt_d $opt_i $opt_v $opt_D $opt_M $opt_P $opt_originaltitle $opt_casting $opt_u_dummy);
use Getopt::Long;

$title = "Allocine Query"; 
$version = "v2.05";
$author = "Xavier Hervy";
push(@MythTV::MythVideoCommon::URL_get_extras, ($title, $version));

binmode(STDOUT, ":utf8");

# display usage
sub usage {
 print "usage: $0 -hviocMPD [parameters]\n";
 print "       -h, --help                       help\n";
 print "       -v, --version                    display version\n";
 print "       -i, --info                       display info\n";
 print "       -o, --originaltitle              concatenate title and original title\n";
 print "       -c, --casting                    with -D option, grap the complete actor list (much slower)\n";
 print "\n";
 print "       -M <query>,   --movie query>     get movie list\n";
 print "       -D <movieid>, --data <movieid>   get movie data\n";
 print "       -P <movieid>, --poster <movieid> get movie poster\n";
 exit(-1);
}

# display 1-line of info that describes the version of the program
sub version {
 print "$title ($version) by $author\n"
} 

# display 1-line of info that can describe the type of query used
sub info {
 print "Performs queries using the www.allocine.fr website.\n";
}

# display detailed help 
sub help {
 version();
 info();
 usage();
}

# returns text within 'data' without tag
sub removeTag {
 my ($data)=@_; # grab parameters

 my $ldata = lc($data);
 my $start = index($ldata, "<");
 my $finish = index($ldata, ">", $start)+1;
 while ($start != -1 && $finish != -1){
    $data = substr($data, 0, $start).substr($data, $finish, length($data));
    $ldata = lc($data);
    $start = index($ldata, "<");
    $finish = index($ldata, ">", $start)+1;
 }
 return $data;
}

# get Movie Data 
sub getMovieData {
 my ($movieid)=@_; # grab movieid parameter
 if (defined $opt_d) { printf("# looking for movie id: '%s'\n", $movieid);}

 # get the search results  page
 my $request = "http://www.allocine.fr/film/fichefilm_gen_cfilm=" . $movieid . ".html";
 if (defined $opt_d) { printf("# request: '%s'\n", $request); }
 my ($rc, $response) = myth_url_get($request);
 from_to($response,'utf-8','iso-8859-1');
 # parse title and year
 my $title = parseBetween($response, "<title>", "</title>");
 $title =~ s/\s*-\s*AlloCin.*//;
 $title =~ s/(.*)\(.*$/$1/;
 $title =~ s/^\s*(.*)\s*$/$1/;
 my $original_title = parseBetween($response, "Titre original :","<br");
 $original_title = trim(removeTag($original_title));
 if (defined $opt_originaltitle){
    if ($original_title ne  ""){
      $title = $title . " (" . $original_title . ")";
    }
 }
 
 $title = removeTag($title);
 my $year = parseBetween(parseBetween($response,"/film/tous/decennie","/a>"),'>','<');

 # parse director 
 my $tempresponse = $response;
 my $director = parseBetween($tempresponse,"Réalisé par ","</a></span>");
 $director = removeTag($director);

 # parse plot
 my $plot = parseBetween($response,"Synopsis : </span>","</p>");
 $plot =~ s/\n//g;
 $plot = trim(removeTag($plot));

 # parse user rating
 my $userrating=0;
 my $tmpratings = parseBetween(parseBetween($response,"/film/critiquepublic_gen_cfilm=$movieid.html'><img", "</span></p></div>"),'(',')');
 $tmpratings =~ s/,/./gm;
 $tmpratings =~ /^(\d+\.?\d*|\.\d+)$/;
 print $tmpratings;
 if($tmpratings ne "")
 {   
	$userrating = int($tmpratings*2.5);
 }
 else
 {
	$userrating =  "";
 }

 # parse rating
 my $movierating = parseBetween($response,"Interdit aux moins de ","ans");
 if (!($movierating eq ""))
 	{ $movierating = "Interdit aux moins de " . $movierating . "ans";}
 else
 	{
  		$movierating = parseBetween($response,"Visible ","enfants");
 		if (!($movierating eq "")){ $movierating = "Visible par des enfants";};
 	}
 

 # parse movie length

 my $runtime = trim(parseBetween($response,"Durée :","min"));
 my $heure;
 my $minutes;
 ($heure,$minutes)=($runtime=~/[^\d]*(\d+)[^\d]*(\d*)/);
 if (!$heure){ $heure = 0; }
 if (!$minutes){
    $runtime = $heure * 60;
 }else{
     $runtime = $heure * 60 + $minutes;
 }
 

 # parse cast 

 my $castchunk;

 $castchunk = parseBetween($response, "Avec ",", <a class=\"underline\" href=\"/film/casting_gen_cfilm=$movieid.html\">plus</a>");
 
 my $cast = "";
 $cast = trim(join(',', removeTag($castchunk)));
 #genres
 my $genres = parseBetween($response,"Genre :","<br");
 $genres =~ s/\s*\n*(.*)\s*$/ $1/;
 $genres = trim(removeTag($genres));
 $genres =~ s/\s*\n*(.*)\s*$/ $1/;
 
 #countries
 my $countries = parseBetween($response,"Long-métrage",".");
 $countries = trim(removeTag($countries));
 $countries =~ s/\s*(.*)\s*$/ $1/;
 $countries = trim($countries);
 $countries =~ s/\n//gm;
 $countries =~ s/\s//gm;
 $countries =~ s/,/, /gm;
 # output fields (these field names must match what MythVideo is looking for)
 print "Title:$title\n";
 if (!(defined $opt_originaltitle)){
  print "OriginalTitle:$original_title\n";
 }  
 print "Year:$year\n";
 print "Director:$director\n";
 print "Plot:$plot\n";
 print "UserRating:$userrating\n";
 print "MovieRating:$movierating\n";
 print "Runtime:$runtime\n";
 print "Cast:$cast\n";
 print "Genres:$genres\n";
 print "Countries:$countries\n";
}

# dump Movie Poster
sub getMoviePoster {
 my ($movieid)=@_; # grab movieid parameter
 if (defined $opt_d) { printf("# looking for movie id: '%s'\n", $movieid);}

 # get the search results  page
 
 my $request = "http://www.allocine.fr/film/fichefilm-".$movieid."/affiches/";
 if (defined $opt_d) { printf("# request: '%s'\n", $request); }
 my ($rc, $response) = myth_url_get($request);
 my $mediafile = parseBetween($response,"<a href=\"/film/fichefilm-".$movieid."/affiches/detail/?cmediafile=","\" >");

 $request = "http://www.allocine.fr/film/fichefilm-".$movieid."/affiches/detail/?cmediafile=".$mediafile;
 ($rc, $response) = myth_url_get($request);
 my $uri = parseBetween(parseBetween($response,"<div class=\"tac\" style=\"\">","</div>"),"<img src=\"","\" alt");
 if ($uri eq "")
 {
	$request = "http://www.allocine.fr/film/fichefilm-".$movieid."/affiches/";
	($rc, $response) = myth_url_get($request);
	my $tmp_uri = parseBetween($response, "<a href=\"/film/fichefilm-".$movieid."/affiches/\">"," alt=");
      $tmp_uri =~ s/\n/ /gm;
	$uri = trim(parseBetween($tmp_uri,"<img src='h","'"));
	if($uri ne "")
	{
		$uri = "h$uri";
	}
      print "$uri\n";
 }
 
 # if no picture was found, just download the empty poster
 if($uri eq ""){
	$uri = "http://images.allocine.fr/r_160_214/commons/emptymedia/AffichetteAllocine.gif";
 }

 my $fileName = basename($uri);
 my $BASENAME = $fileName;
 my $IMGURI = $uri;

 # system ("cd /tmp && rm -f $BASENAME && wget -q $IMGURI");
 # print "/tmp/$fileName\n";
 print "$IMGURI\n";
}

sub getMovieList {
	my ($filename, $options) = @_; # grab parameters

	my $query = cleanTitleQuery($filename);
	if (!$options) { $options = ""; }
	if (defined $opt_d) { 
		printf("# query: '%s', options: '%s'\n", $query, $options);
	}

	# get the search results  page
	my $request = "http://www.allocine.fr/recherche/1/?q=$query";
	if (defined $opt_d) { printf("# request: '%s'\n", $request); }
	my ($rc, $response) = myth_url_get($request);
	from_to($response,'utf-8','iso-8859-1');
	$response =~ s/\n//g;
	# extract possible matches
	#    possible matches are grouped in several catagories:  
	#        exact, partial, and approximate
	my $exact_matches = $response;
	# parse movie list from matches
	my $beg = "<div style=\"margin-top:-5px;\">";
	my $end = "<span class=\"fs11\">";

	my @movies;

	my $data = $exact_matches;
	if ($data eq "") {
		if (defined $opt_d) { printf("# no results\n"); }
	} else {
		my $start = index($data, $beg);
		my $finish = index($data, $end, $start);

		my $title;
		my $movienum;
		my $moviename;
		while ($start != -1) {
			$start += length($beg);
			my $sub1 = substr($data, $start, $finish - $start);
			$sub1 =~ s/(.*)\(.*$/$1/;
			$moviename = trim(removeTag($sub1));
			$movienum = parseBetween($sub1,"<a href='/film/fichefilm_gen_cfilm=",".html");
			
			$title = removeTag($moviename);
			$moviename = removeTag($moviename);
			my ($movieyear)= $moviename =~/\((\d+)\)/;
			if ($movieyear) {
				$title = $title." (".$movieyear.")";
			}
			$moviename=$title ;

			# advance data to next movie
			$data = substr($data, - (length($data) - $finish));
			$start = index($data, $beg);
			$finish = index($data, $end, $start); 

			# add to array
			push(@movies, "$movienum:$moviename");
		}

		# display array of values
		for $movie (@movies) { 
			print "$movie\n"; 
		}
	}
}  
#
# Main Program
#

# parse command line arguments 

    GetOptions( "utf8" => \$opt_u_dummy,
                "version" => \$opt_v,
                "info" => \$opt_i,
                "originaltitle" => \$opt_originaltitle,
                "casting" => \$opt_casting,
                "Data" => \$opt_D,
                "Movie" => \$opt_M,
                "Poster" => \$opt_P
                );       
            

# print out info 
if (defined $opt_v) { version(); exit 1; }
if (defined $opt_i) { info(); exit 1; }

# print out usage if needed
if (defined $opt_h || $#ARGV<0) { help(); }

if (defined $opt_D) {
   # take movieid from cmdline arg
   $movieid = shift || die "Usage : $0 -D <movieid>\n";
   getMovieData($movieid);
}

elsif (defined $opt_P) {
# take movieid from cmdline arg
 $movieid = shift || die "Usage : $0 -P <movieid>\n";
 getMoviePoster($movieid);
}

elsif (defined $opt_M) {
 # take query from cmdline arg
 #$options = shift || die "Usage : $0 -M <query>\n";
 my $query;
 my $options = '';
 foreach $key (0 .. $#ARGV) {
 	$query .= $ARGV[$key]. ' ';
 }
 getMovieList($query, $options);
}
# vim: set expandtab ts=3 sw=3 :

MYSQL

Base de données assez primaire mais tout à fait fonctionnelle.

Pour lancer un script (ne pas oublier les < >):

mysql db_name < script.sql > output.tab

Pour se connecter à la base de mythtv (celle par defaut) :

mysql --user=root --password=**** mythconverg (**** est à remplacer par son mot de passe)
Où est la base par défaut?

cd /var/lib/mysql/mythconverg (!)

Un petit script pour améliorer la base

( est à remplacer par son mot de passe).

#!/bin/bash
### mysql-settings
HOST=localhost
USER=//monutilisateur//
PASSW=//monmotdepasse//
DATABASE=//mythconverg//
SCRIPTDIR=`dirname $0`

echo "Optimize mysql mythtv (--------------------------------)"
echo "Optimize mysql mythtv (--- Start  `date +'%y/%m/%d-%H:%M.%S'` ---)"
echo "Optimize mysql mythtv (--- Part 1 `date +'%y/%m/%d-%H:%M.%S'` ---)"
mysql --user=${USER} --password=${PASSW} ${DATABASE} -B -e "
SELECT concat('analyze table ',table_schema,'.',table_name,';') as ' ' FROM information_schema.TABLES where table_schema='mythconverg'
union
SELECT concat('check table ',table_schema,'.',table_name,';') as ' ' FROM information_schema.TABLES where table_schema='mythconverg'
union
SELECT concat('optimize table ',table_schema,'.',table_name,';') as ' ' FROM information_schema.TABLES where table_schema='mythconverg'
union
SELECT concat('repair table ',table_schema,'.',table_name,';') as ' ' FROM information_schema.TABLES where table_schema='mythconverg';" >${SCRIPTDIR}/optimysqlmyth.sql
echo "Optimize mysql mythtv (--- Part 2 `date +'%y/%m/%d-%H:%M.%S'` ---)"
mysql --user=${USER} --password=${PASSW} ${DATABASE} <${SCRIPTDIR}/optimysqlmyth.sql> ${SCRIPTDIR}/optimysqlmyth.log
echo "Optimize mysql mythtv (--- End    `date +'%y/%m/%d-%H:%M.%S'` ---)"
echo "Optimize mysql mythtv (--------------------------------)"
echo "Optimize mysql mythtv (--------------------------------)"
Un petit script pour automatiser la gestion des fichiers audios
#!/bin/bash
### mysql-settings
HOST=localhost
USER=//monutilisateur//
PASSW=//monmotdepasse//
DATABASE=//mythconverg//
SCRIPTDIR=`dirname $0`

echo "Refresh MusicMetadata Browse (------------------------------------------------)"
echo "Refresh MusicMetadata Browse (-- Start  `date +'%y/%m/%d-%H:%M.%S'` --------------------)"
# Efface les playlist sauf celles par défaut
echo "Refresh MusicMetadata Browse (-- Part 1 `date +'%y/%m/%d-%H:%M.%S'` - efface playlist --)"
echo "delete from music_playlists where playlist_name <> 'default_playlist_storage' and playlist_name <> 'backup_playlist_storage';" | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST
# Ajoute les playlist : premier dossier
echo "Refresh MusicMetadata Browse (-- Part 2 `date +'%y/%m/%d-%H:%M.%S'` - crée  playlist ---)"
echo "insert into music_playlists (playlist_name,playlist_songs)
select if(left(md.path,INSTR(md.path,'/')-1)='',md.path,left(md.path,INSTR(md.path,'/')-1)) as play,''
FROM music_songs ms,music_directories md
where md.directory_id=ms.directory_id group by play;" | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST

# Ajout des musiques aux playlist
echo "Refresh MusicMetadata Browse (-- Part 3 `date +'%y/%m/%d-%H:%M.%S'` - listes titres ----)"
# echo "update music_playlists m set m.playlist_songs=(select group_concat(ms.song_id)
# FROM music_songs ms,music_directories md
# where md.directory_id=ms.directory_id
# and (left(md.path,INSTR(md.path,'/')-1)=m.playlist_name or md.path=m.playlist_name)
# group by left(md.path,CHAR_LENGTH(m.playlist_name)))" | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST

mysql --user=$USER --password=$PASSW $DATABASE <$SCRIPTDIR/rmb.sql> $SCRIPTDIR/rmb2.sql
echo "Refresh MusicMetadata Browse (-- Part 4 `date +'%y/%m/%d-%H:%M.%S'` - ajoute titres ----)"
mysql --user=$USER --password=$PASSW $DATABASE <$SCRIPTDIR/rmb2.sql>> $SCRIPTDIR/rmb.log

# Ajoute les playlist : doublon
echo "Refresh MusicMetadata Browse (-- Part 5 `date +'%y/%m/%d-%H:%M.%S'`  - Ajout doublon ---)"
echo "insert into music_playlists (playlist_name,playlist_songs) values('Doublon','');" | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST
echo "update music_playlists m set m.playlist_songs=(select group_concat(ms.song_id) FROM music_songs ms
inner join music_directories cc on ms.directory_id=cc.directory_id
left join music_directories c on c.directory_id=cc.parent_id
inner join (SELECT m.name,m.filename, count(*) as tt FROM music_songs m group by m.name,m.filename having tt>1) mm on mm.name=ms.name)
where m.playlist_name='Doublon' ; " | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST
# Ajoute les playlist : doublon

echo "Refresh MusicMetadata Browse (-- End    `date +'%y/%m/%d-%H:%M.%S'`  -------------------)"
echo "Refresh MusicMetadata Browse (------------------------------------------------)"

Avec son petit script sql

SELECT concat('update music_playlists m set m.playlist_songs=concat(m.playlist_songs,''',ms.song_id,''',',''',''',') where 
m.playlist_name=''',left(m.path,INSTR(m.path,'/')-1),'''',';') as "START TRANSACTION;"
FROM music_songs ms,music_directories m
where m.directory_id=ms.directory_id and left(m.path,INSTR(m.path,'/')-1)<>'' ;
select 'COMMIT;' as "" from dual;
SELECT concat('update music_playlists m set m.playlist_songs=concat(m.playlist_songs,''',ms.song_id,''',',''',''',') where m.playlist_name=''',m.path,'''',';') as "START TRANSACTION;"
FROM music_songs ms,music_directories m
where m.directory_id=ms.directory_id and left(m.path,INSTR(m.path,'/')-1)='' ;
select 'COMMIT;' as "" from dual;
Un petit script pour automatiser la gestion des fichiers vidéos

(enchainement des vidéos, classement des genres en fonction des dossiers et création des minin affiches pour les videos qui n'en n'ont pas)

#!/bin/bash
### Pour MYSQL 5.0 peut être moins
### mysql-settings
HOST=localhost
USER=//monutilisateur//
PASSW=//monmotdepasse//
DATABASE=//mythconverg//
SCRIPTDIR=`dirname $0`
THUMB_TIME=00:01:00
THUMB_NB=40
THUMB_DIR=/media/FILMS/.affiches

### initialise le champ coverfile si fichier inexistante
VERIF_COVER()
{
if [ ! -f "$1" ]; then
 echo 'update videometadata set coverfile="No Cover" where coverfile="'$1'"' | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST
fi
}

### Crée et affecte les couvertures
AJOUT_COVER()
{
filename="$1"
THUMB_PATH="$THUMB_DIR/`basename "${filename}"`.png"
mplayer -ss $THUMB_TIME -nosound -frames 3 -vo png:z=9 "${filename}" >> $SCRIPTDIR/rvb.log && mv -f 00000003.png "$THUMB_PATH" >> $SCRIPTDIR/rvb.log
if [ ! -f "${THUMB_PATH}" ]; then
  mplayer -nosound -frames $THUMB_NB -vo png:z=9 "${filename}" >> $SCRIPTDIR/rvb.log && mv -f 000000${THUMB_NB}.png "$THUMB_PATH" >> $SCRIPTDIR/rvb.log
fi
if [ -f "${THUMB_PATH}" ]; then
  echo "UPDATE  videometadata SET coverfile=\"${THUMB_PATH}\"  WHERE filename=\"${filename}\" ;" | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST
fi
rm 000000??.png >> $SCRIPTDIR/rvb.log
}

### MAIN ###
echo " "> $SCRIPTDIR/rvb.log
echo "Refresh Videometadata Browse (---------------------------------------------)"
echo "Refresh Videometadata Browse (-- Start  `date +'%y/%m/%d-%H:%M.%S'` -----------------)"
### RAZ des couvertures inexistantes
echo "Refresh Videometadata Browse (-- Part 1 `date +'%y/%m/%d-%H:%M.%S'` - affiche RAZ ---)"
echo "select coverfile as ' ' from videometadata 
WHERE  coverfile<>'No Cover' ;  " | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST >"$SCRIPTDIR"/list_cover.txt
while read ligne
do
 VERIF_COVER "$ligne"
done <$SCRIPTDIR/list_cover.txt

### Recherche des couvertures manquantes
echo "Refresh Videometadata Browse (-- Part 2 `date +'%y/%m/%d-%H:%M.%S'` - ?? affiches ---)"
echo "select v.filename as ' ' from videometadata v 
WHERE v.coverfile='No Cover' and LOWER(right(v.filename,3)) not like 'ifo' 
and LOWER(right(v.filename,3)) not like 'bup' and LOWER(right(v.filename,3)) not like 'srt' 
and LOWER(right(v.filename,3)) not like 'idx' and LOWER(right(v.filename,3)) not like 'sub'; " | mysql -u $USER --password=$PASSW -D $DATABASE -h $HOST >"$SCRIPTDIR"/list_file.txt
### Creation et affectation des couvertures manquantes
# incompatible avec mplayer
# do
#   echo  -e "$ligne\n"
#   AJOUT_COVER "$ligne"
# done <$SCRIPTDIR/list_file.txt
echo "Refresh Videometadata Browse (-- Part 3 `date +'%y/%m/%d-%H:%M.%S'` - crée affiche  --)"
oldIFS=$IFS     # sauvegarde du séparateur de champ
IFS=$'\n'     # nouveau séparateur de champ, le caractère fin de ligne
for ligne in $(cat $SCRIPTDIR/list_file.txt)
do
   AJOUT_COVER "$ligne"
done
IFS=$old_IFS     # rétablissement du séparateur de champ par défautwhile read ligne

echo "Refresh Videometadata Browse (-- Part 4 `date +'%y/%m/%d-%H:%M.%S'` - prep script --)"
mysql --user=$USER --password=$PASSW $DATABASE <$SCRIPTDIR/rvb.sql> $SCRIPTDIR/rvb2.sql
echo "Refresh Videometadata Browse (--- Part 2 `date +'%y/%m/%d-%H:%M.%S'` - exec scripts --)"
mysql --user=$USER --password=$PASSW $DATABASE <$SCRIPTDIR/rvb2.sql>> $SCRIPTDIR/rvb.log
echo "Refresh Videometadata Browse (--- End    `date +'%y/%m/%d-%H:%M.%S'` -----------------)"
echo "Refresh Videometadata Browse (---------------------------------------------)"
exit

Avec son petit script sql (qui efface toutes les playlists!!!) :

# Efface les categories de video
truncate videocategory;

# Ajout des categories
# 14 = CHAR_LENGTH('/media/FILMS/')
START TRANSACTION;
insert into videocategory (category) select distinct mid(videometadata.filename,14,INSTR(mid(videometadata.filename,14), "/")-1) from videometadata;
COMMIT;

# création du second script sql

# Affectation des categories
# 14 = CHAR_LENGTH('/media/FILMS/')
select concat('update videometadata set category=',videocategory.intid,' where intid=',videometadata.intid,';') as "START TRANSACTION; " 
from videometadata,videocategory where mid(videometadata.filename,14,INSTR(mid(videometadata.filename,14), "/")-1)=videocategory.category;
select 'COMMIT;' as "";

# Enchainement des videos (recherche de la derniere) (avec le debut de transaction)
SELECT  concat('update videometadata set browse=0 ,childid=',v.intid,' ') as "START TRANSACTION; "
FROM videometadata v where LOWER(right(v.filename,3)) not like 'ifo' and LOWER(right(v.filename,3)) not like 'bup' 
and LOWER(right(v.filename,3)) not like 'srt' and LOWER(right(v.filename,3)) not like 'idx' and LOWER(right(v.filename,3)) not like 'sub' 
and v.filename=(select min(vv.filename) from videometadata vv);
# Enchainement des videos
SELECT  concat(' where intid=',v.intid, '; update videometadata set browse=0 ,childid=',v.intid) as " "
FROM videometadata v where LOWER(right(v.filename,3)) not like 'ifo' and LOWER(right(v.filename,3)) not like 'bup' 
and LOWER(right(v.filename,3)) not like 'srt' and LOWER(right(v.filename,3)) not like 'idx' and LOWER(right(v.filename,3)) not like 'sub' 
order by v.filename desc;
# Enchainement des videos (recherche de la derniere)
SELECT  concat(' where intid=',v.intid,'; ') as " "
FROM videometadata v where LOWER(right(v.filename,3)) not like 'ifo' and LOWER(right(v.filename,3)) not like 'bup' 
and LOWER(right(v.filename,3)) not like 'srt' and LOWER(right(v.filename,3)) not like 'idx' and LOWER(right(v.filename,3)) not like 'sub'
and v.filename=(select max(vv.filename) from videometadata vv);
# pour la fin de transaction
select 'COMMIT;' as "" ;
quit

(Pourquoi c'est long ? il y a beaucoup de fichiers et la machine n'est pas rapide)

(Pourquoi ça plante ? erreur de lecture/écriture, erreur de mot de passe etc…regarder la log : rvb.log ou optimysqlmyth.log. ou simplement un mauvais codec pour créer les miniatures)

Intégration dans un menu
sudo vi /usr/share/mythtv/util_menu.xml

Ajouter à l'avant-dernière ligne (le fichier commençant par <mythmenu> doit finir par </mythmenu> ):

 <button>
     <type>MUSIC_SCAN</type>
     <text>r.v.b.</text>
     <text lang="FR">r.v.b.</text>
     <action>EXEC gnome-terminal -e /home/mythtv/scripts/rvb.sh</action>
 </button>
 <button>
     <type>MUSIC_SCAN</type>
     <text>optimysqlmyth</text>
     <text lang="FR">optimysqlmyth</text>
     <action>EXEC gnome-terminal -e /home/mythtv/scripts/optimysqlmyth.sh</action>
 </button>
Autre méthode

faire dans le dossier des vidéos

dir * > all_videos.pls

ou

find  /media/CLIPS/ -type f -name "*"   -type f -print > /media/CLIPS/all_videos.pls

(fait la liste de tout les videos qui se trouve dans /media/CLIPS/)

Pour créer sa playlist.

Ajouter au Paramètres→Paramètres médias→Paramètres Vidéos→Type de fichiers une extension pls et la commande :

mplayer -fs -zoom -quiet -vo xv -playlist %s

DEMARRAGE AUTO

Dans Système→Préférences→Sessions :

mythbackend (est parfois inutile : ps -ef |grep mythbackend)

mythfrontend - -service

irexec –d (à rajouter à la fin, voire à enlever et remettre…)

Rien à voir mais ça peut toujours servir

Arrêter démarrer le backend :

sudo /etc/init.d/mythtv-backend stop
sudo /etc/init.d/mythtv-backend start

Arrêter démarrer mysql :

sudo /etc/init.d/mysql stop
sudo /etc/init.d/mysql start

SAMBA

Avoir une bibliothèque multimédia c'est bien, la partager c'est mieux…

sudo smbpasswd -a `whoami`

gksudo gedit /etc/samba/smb.conf

MYTHTV GALERIE

Pas grand chose à faire, à part le setup : indiquer l'emplacement des photos. Pour son utilisation regarder "Configurer les touches".

ARRET et REBOOT de Mythtv (!)

La commande pour rebooter ou arrêter l'ordinateur peut ne pas fonctionner (car nécessite une commande sudo reboot…).

Pour remédier à cela ajouter son_utilisateur au fichier /etc/sudoers:

(problème : le fichier doit être en lecture seul. Solution : l'écraser)

sudo cp /etc/sudoers /etc/sudoers.new
sudo chmod 777 /etc/sudoers.new
gksudo gedit /etc/sudoers.new

ajouter en fin de fichier (son_utilisateur = myth):

mythtv	ALL=NOPASSWD:/sbin/halt,/sbin/reboot,/bin/mount,/bin/umount

Puis écraser par le nouveau fichier

sudo chmod 440 /etc/sudoers.new
sudo cp /etc/sudoers.new /etc/sudoers

En cas de problème redémarrer en mode (recovery mode) et supprimer cette ligne précédemment ajoutée.

Cette methode n'a plus l'air de fonctionner sur Jaunty, pour y remédier :

sudo chmod u+s /sbin/halt
sudo chmod u+s /sbin/reboot

(la différence avec la précédente méthode est dans le premier cas seul un utilisateur peut executer la commande, dans la seconde c'est permis pour tout le monde)

  • mythtv.1290331727.txt.gz
  • Dernière modification: Le 18/04/2011, 14:57
  • (modification externe)