Ceci est une ancienne révision du document !
Mythtv
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.
Différentes solutions
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.
Installations
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".
taille | nom | commentaire |
---|---|---|
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)
commandes | commentaires |
---|---|
sudo apt-get install | pour installer les packets (pour sélectionner appuyer en même temps sur Ctrl sur firefox) |
mplayer gxine vlc libdvdread3 ogle | lecteur vidéo et codec |
flashplugin-nonfree | lecteur video (flash) |
tvtime | permet 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) |
filezilla | client 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) |
dmraid | si 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
commandes | commentaires |
---|---|
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 | voir et gérer des vidéos |
mythweather | la météo |
mythweb | Interface web pour contrôler presque tout mythtv |
mythstream | écouter et voir du streming |
mythnews | rapide pour avoir des informations sur l'actualité |
mythmusic | gérer et écouter ses MP3 |
mythgame | jouer |
mythgallery | voir ses photos |
mythbrowser | navigateur internet optimisé télécommande |
lame gstreamer0.10-plugins-bad gstreamer0.10-ffmpeg gstreamer0.10-plugins-good gstreamer0.10-plugins-ugly | différents codec |
pour 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
Menus
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 :
code | commentaire |
---|---|
<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 :
code | commentaire |
---|---|
<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)
Liens
- Toutes les informations de la mise en place de Mythbuntu sous Ubuntu (Wiki francophone des utilisateurs de Mythtv)
http://mythtv-fr.tuxfamily.org/
http://doc.ubuntu-fr.org/media_center
http://www.mythtv.org/modules.php?name=MythFeatures
http://doc.ubuntu-fr.org/imprimante_brother_dcp-130c
https://help.ubuntu.com/ubuntu/serverguide/fr/configuring-samba.html
http://dev.mysql.com/doc/refman/5.0/fr/index.html
Merci, thank you, vielen Dank aux autres
Contributeurs : yurek, L.Bellegarde