#!/usr/bin/perl -w # # # rhimport # # Copyright (C) 2009 Christian Pointner <equinox@helsinki.at> # # This file is part of rhimport. # # rhimport is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # any later version. # # rhimport is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with rhimport. If not, see <http://www.gnu.org/licenses/>. # use strict; use Getopt::Long; use DBI; use Gtk2; use Gtk2::GladeXML; use lib '/usr/share/perl5/rhimport/'; use rhimport; my $DBHOST = "airplay"; my $DBUSER = "rivendellro"; my $DBPW = "lldrivenro"; my $DB = "rivendell"; my $HELP = 0; my $FILE = ""; my $POOL = 0; my $EMPTYCARTS = 1; my $DROPBOX = ""; my $LISTALLOWED = 0; GetOptions ("help!" => \$HELP, "file=s" => \$FILE, "pool!" => \$POOL, "empty-carts!" => \$EMPTYCARTS, "dropbox=s" => \$DROPBOX, "list-allowed!" => \$LISTALLOWED, ); if($HELP) { print << "EOF"; usage: $0 --file <audio or playlist file> --pool --empty-carts --dropbox <path to dropbox> --list-allowed options: --file the media file or playlist to import --pool pool mode, import media files referneced by playlist --empty-carts emtpy out pool of carts before import --dropbox the path to the dropbox to use --list-allowed list allowed dropboxes and exit EOF exit; } my $user = $ENV{'USER'}; $user or die "Username not found in environment"; my $dbh = DBI->connect( "DBI:mysql:$DB:$DBHOST","$DBUSER","$DBPW") or die "Database Error: $DBI::errstr"; my $sql = qq{select USER_PERMS.GROUP_NAME,DROPBOXES.PATH from USER_PERMS, DROPBOXES where USER_PERMS.USER_NAME='$user' and DROPBOXES.GROUP_NAME=USER_PERMS.GROUP_NAME;}; my $sth = $dbh->prepare($sql); $sth->execute(); my @allowed_dbs; while(my ($group, $path) = $sth->fetchrow_array()) { $path =~ s/\/\*$//; my $perm = {}; $perm->{'GROUP'} = $group; $perm->{'PATH'} = $path; push @allowed_dbs, $perm; } $sth->finish(); if($LISTALLOWED) { for my $href ( @allowed_dbs ) { print "$href->{'PATH'}\n"; } $dbh->disconnect(); exit 0; } ########################################### ## GUI mode my $guixml; sub set_mode_playlist_gui() { if(!$guixml) { print STDERR "no GUI definition found!\n"; exit 0; } $POOL = 1; my $l_mode = $guixml->get_widget('l_mode'); $l_mode->set_label("<b>Musik Pool</b>"); my $cb_clear_carts = $guixml->get_widget('cb_clear_carts'); $cb_clear_carts->set_sensitive(1); my $l_file_playlist = $guixml->get_widget('l_file_playlist'); $l_file_playlist->set_label("<b>Playlist</b>"); my $filter = Gtk2::FileFilter->new; $filter->add_pattern("*.m3u"); my $filechooser = $guixml->get_widget('filechooser'); $filechooser->set_filter($filter); } sub set_mode_file_gui() { if(!$guixml) { print STDERR "no GUI definition found!\n"; exit 0; } $POOL = 0; my $l_mode = $guixml->get_widget('l_mode'); $l_mode->set_label("<b>Sendung</b>"); my $cb_clear_carts = $guixml->get_widget('cb_clear_carts'); $cb_clear_carts->set_sensitive(0); my $l_file_playlist = $guixml->get_widget('l_file_playlist'); $l_file_playlist->set_label("<b>Datei</b>"); my $filter = Gtk2::FileFilter->new; $filter->add_pattern("*"); my $filechooser = $guixml->get_widget('filechooser'); $filechooser->set_filter($filter); } sub toggle_mode_gui() { if($POOL) { set_mode_file_gui(); } else { set_mode_playlist_gui(); } } sub start_import_gui() { if(!$guixml) { print STDERR "no GUI definition found!\n"; exit 0; } my $l_status = $guixml->get_widget('l_status'); my $filechooser = $guixml->get_widget('filechooser'); my $file = $filechooser->get_filename; if(!$file || -d $file) { if($POOL) { $l_status->set_label("Keine Playlist ausgew�hlt!"); } else { $l_status->set_label("Keine Audio Datei ausgew�hlt!"); } return 0; } $filechooser->unselect_all; my $co_dropbox = $guixml->get_widget('co_dropbox'); my $dropbox = $co_dropbox->get_active_text; $l_status->set_label("importiere von $file"); my $ret; if($POOL) { $ret = rhimport::import_playlist($file, $dropbox); } else { $ret = rhimport::import_file($file, $dropbox); } return $ret; } if(!$FILE && !$DROPBOX) { Gtk2->init; $guixml = Gtk2::GladeXML->new('rhimport.glade'); $guixml or die "can't load glade xml file"; require gui_callbacks; $guixml->signal_autoconnect_from_package('gui_callbacks'); my $model = Gtk2::ListStore->new('Glib::String'); for my $href ( @allowed_dbs ) { $model->set ($model->append, 0, $href->{'PATH'}); } my $co_dropbox = $guixml->get_widget('co_dropbox'); $co_dropbox->set_model($model); my $renderer = Gtk2::CellRendererText->new; $co_dropbox->pack_start($renderer, 1); $co_dropbox->add_attribute($renderer, text => 0); $co_dropbox->set_active(0); if($POOL) { set_mode_playlist_gui(); } else { set_mode_file_gui(); } my $appwin = $guixml->get_widget('appwin'); $appwin or die "can't find Main Window"; $appwin->resize(800,600); $appwin->show; Gtk2->main; $dbh->disconnect(); exit 0; } ########################################### ## command line mode (-e "$FILE") or die "file '$FILE' not found"; if($POOL) { print "will import from playlist $FILE, with user $user\n\n"; } else { print "will import $FILE, with user $user\n\n"; } my $ret; if($POOL) { $ret = rhimport::import_playlist($FILE, $DROPBOX); } else { $ret = rhimport::import_file($FILE, $DROPBOX); } $dbh->disconnect(); exit $ret;