Major changes to support common configuration file for organize_videos scripts.
authorAlan J. Pippin <alan@pippins.net>
Sun, 23 Sep 2012 17:42:11 +0000 (11:42 -0600)
committerAlan J. Pippin <ajp@pippins.net>
Sun, 23 Sep 2012 17:42:11 +0000 (11:42 -0600)
Fixed bug in "already running" pid check.
Fixed bug in directory parsing to determine which dirs to recreate playlists in.

make_mkv
merge_videos_by_day
organize_videos
organize_videos.conf [new file with mode: 0644]

index 00e1ce304dfdd537d0423f9e4846512921dc8a3e..c3a23987ada1b60fb104d5708d4046218dbf55bf 100755 (executable)
--- a/make_mkv
+++ b/make_mkv
@@ -17,20 +17,12 @@ use DateTime::Duration;
 use DateTime::Format::Duration;
 
 ####################################################################################################
-# Configuration parameters - CHANGE THESE TO SUITE YOUR NEEDS
-my $mkvmerge='mkvmerge';
-my $ffmpeg='ffmpeg';
-my $handbrake='HandBrakeCLI';
-my $handbrake_options='--strict-anamorphic --crop 0:0:0:0 -E ac3';
-my $tmpfile = `tempfile`; chomp($tmpfile);
-my $chapter_file = $tmpfile;
-my $input_file_options = "-S";
-my $output_file_options = "--chapters $chapter_file --compression -1:none";
-my $timezone = `cat /etc/timezone`; chomp($timezone);
-my $interlaced_requantize_quality=0.85;
-my $progressive_requantize_quality=0.7;
-####################################################################################################
-
+# Configuration parameters
+$mydir = `cd \$(dirname $0) 2>/dev/null; pwd`; chomp($mydir); unshift @INC,("$mydir");
+# Default configuration values
+require "organize_videos.conf";
+# Override defaults with local customizations
+if( -f "$mydir/organize_videos.conf.local") { require "organize_videos.conf.local"; }
 
 ####################################################################################################
 # Command Line Options
index 4d96b93be7438260d6106c056831a9f01b247d4f..6dce13c1eb54d88f48b340c8693622ddceb1ef07 100755 (executable)
@@ -13,21 +13,13 @@ getopts("qkh:tvs:");
 my $srcpathname = $opt_s;
 
 ####################################################################################################
-# Configuration parameters - CHANGE THESE TO SUITE YOUR NEEDS
-my $compute_host = "pippin.pippins.net"; # I need this since this script is run from a virtual machine 
-my $use_compute_host = 1; # Set to 1 to use a remote compute host to run the mkvmerge command. Set to 0 to use the local host to run it.
-my $make_mkv = "/naspool/videos/bin/make_mkv"; # Update this to be the path to the make_mkv script
-my $requantize_input_video=1; # This will dramatically decrease the size of the video with minimal compute processing requirements.
-my $owner = "ajp"; # The owner of the files after they are moved
-my $group = "pip"; # The group of the files after they are moved
-my $mode = "664"; # The mode to set on each file after they are moved
-my $video_suffix = "000"; # What number to start with when adding an incrementing suffix to the end of the video clip to avoid name collisons
-my $video_title_prefix = "HomeVideos:"; # What text to put on the front of the title for the merged video being created
-my $find_cmd = "find \"$srcpathname/\" -iregex \".*\.mov\" -o -iregex \".*\.3gp\" -o -iregex \".*\.mp4\" -o -iregex \".*\.mts\"";
-my $handbrake='HandBrakeCLI';
-my $handbrake_options='--strict-anamorphic --crop 0:0:0:0 -E ac3';
-my $interlaced_requantize_quality=0.85;
-my $progressive_requantize_quality=0.7;
+# Configuration parameters
+$mydir = `cd \$(dirname $0) 2>/dev/null; pwd`; chomp($mydir); unshift @INC,("$mydir");
+# Default configuration values
+require "organize_videos.conf";
+# Override defaults with local customizations
+if( -f "$mydir/organize_videos.conf.local") { require "organize_videos.conf.local"; }
+
 ####################################################################################################
 
 sub usage {
index 0b252eab0cfbb6d362c421653f4bd1bc42965869..4e1ad7ff95bd95c29ffb28cd442304680a820592 100755 (executable)
@@ -10,19 +10,13 @@ use Time::localtime;
 use File::Pid;
 
 ####################################################################################################
-# Configuration parameters - CHANGE THESE TO SUITE YOUR NEEDS
-my $srcpathname = "/naspool/pictures/New Photos"; # Path to look for videos to move from
-my $dstpathname = "/naspool/videos/HomeVideos"; # Path to move the videos to
-my $merge_videos_by_day = "/naspool/videos/bin/merge_videos_by_day";
-my $minage = "+15"; # Video file creation dates must not have changed in the last X minutes to process any of the video files
-my $owner = "ajp"; # The owner of the files after they are moved
-my $group = "pip"; # The group of the files after they are moved
-my $mode = "664"; # The mode to set on each file after they are moved
-my $playlist_extension = "pls"; # The extension to use when creating playlist files
-my $video_suffix = "000"; # What number to start with when adding an incrementing suffix to the end of the final video clip to avoid name collisions
-my $movie_file_ext = "-iregex \".*\.mov\" -o -iregex \".*\.3gp\" -o -iregex \".*\.mp4\" -o -iregex \".*\.mts\" -o -iregex \".*\.mkv\"";
-my $find_changed_cmd = "find  \"$srcpathname/\" -not -cmin $minage -a \\( $movie_file_ext \\)";
-my $find_cmd = "find \"$srcpathname/\" $movie_file_ext";
+# Configuration parameters
+$mydir = `cd \$(dirname $0) 2>/dev/null; pwd`; chomp($mydir); unshift @INC,("$mydir");
+# Default configuration values
+require "organize_videos.conf";
+# Override defaults with local customizations
+if( -f "$mydir/organize_videos.conf.local") { require "organize_videos.conf.local"; }
+
 ####################################################################################################
 
 # Sanity check
@@ -82,7 +76,7 @@ sub is_folder_empty {
 sub create_playlists {
     my ($dstdirs) = @_;
     
-    foreach $dstdir (@{$dstdirs}) {
+    foreach $dstdir (keys %{$dstdirs}) {
        print "-> Recreating playlists in: $dstdir\n";
        print "-> Creating playlists for each month & year of clips from this directory: $video_directory\n";
        opendir(VIDEODIR, "$dstdir") or die "-E- could not open: $dstdir\n";
@@ -114,8 +108,8 @@ sub create_playlists {
 if(defined $opt_h) { usage(); exit 1; }
 if(defined $opt_p) {
     if(defined $opt_d) {
-       my @dstdirs = ("$opt_d"); 
-       create_playlists(\@dstdirs);
+       my %dstdirs = ("$opt_d",1); 
+       create_playlists(\%dstdirs);
     } else {
        die "-E- You must specify the -d <dir> option when using the -p option\n"; 
     }
@@ -123,7 +117,7 @@ if(defined $opt_p) {
 }
 
 # Only proceed if there are video files to organize
-$video_files_found=`$find_cmd`;
+$video_files_found=`$find_cmd_with_mkv`;
 if(!$video_files_found) { exit 0; }
 
 # Only proceed if no files have changed in the past $cmin minutes
@@ -131,7 +125,7 @@ $changed_files_found=`$find_changed_cmd`;
 if($changed_files_found) { exit 0; }
 
 # Only one instance of this script running at a time
-my $pidfile = File::Pid->new({file => "/tmp/organize_videos.pid"});
+my $pidfile = File::Pid->new({file => "$pid_file", pid => "$$"});
 exit if $pidfile->running();
 $pidfile->write();
 
@@ -155,10 +149,10 @@ if(defined $opt_n) {
 }
 
 # Copy the videos over to the destination path
-my @dstdirs;
+my %dstdirs;
 chdir "$srcpathname";
-print "$find_cmd\n" if($opt_v);
-foreach $file (`$find_cmd`) {
+print "$find_cmd_with_mkv\n" if($opt_v);
+foreach $file (`$find_cmd_with_mkv`) {
 
     chomp($file);
     $srcdir = dirname($file);
@@ -182,6 +176,13 @@ foreach $file (`$find_cmd`) {
        $monthnum = $month;
        $monthname = lc($month2monthname{$month});
     }
+    elsif($srcfile =~ /^(\d\d\d\d)(\d\d)(\d\d)/) {
+        $year = $1;
+        $month = $2;
+        $day = sprintf("%02d",$3);
+        $monthnum = $month;
+        $monthname = lc($month2monthname{$month});
+    }
     # Get the date taken from the modification time
     elsif($date_taken =~ /\S+\s+(\S+)\s+(\d+)\s+\S+\s+(\d+)/) {
        $year = $3;
@@ -196,7 +197,7 @@ foreach $file (`$find_cmd`) {
 
     # We are ready to pick a destination folder to put the video in
     $dstdir = $dstpathname . "/" . $year;
-    push(@dstdirs,$dstdir);
+    $dstdirs[$dstdir] = 1;
     $dstfile = $dstdir . "/" . $year . "-" . $monthnum . "-" . $day;
 
     # Check for duplicate filenames at the destination
@@ -248,7 +249,7 @@ foreach $file (`$find_cmd`) {
 }
 
 # For each destination dir we copied new content into, recreate the playlists
-create_playlists(\@dstdirs);
+create_playlists(\%dstdirs);
 
 $pidfile->remove();
 
diff --git a/organize_videos.conf b/organize_videos.conf
new file mode 100644 (file)
index 0000000..09b4a5f
--- /dev/null
@@ -0,0 +1,102 @@
+# Force Emacs Perl Mode
+# Local Variables: 
+# mode: perl 
+# End:
+
+################################################################################
+# This is a perl module included by the perl scripts for this application.
+# You must modify these values to match your system configuration.
+# Create a new file called "organize_videos.conf.local" in the same dir as "organize_videos.conf"
+# and only put in it the variables you wish to override.
+# This will prevent your localized settings from being overwritten by future code updates.
+################################################################################
+
+# Path to look for videos to move from
+$srcpathname = "/naspool/pictures/New Photos";
+
+# Path to move the videos to
+$dstpathname = "/naspool/videos/HomeVideos";
+
+# Path to merge_videos_by_day script
+$merge_videos_by_day = "/naspool/videos/bin/merge_videos_by_day";
+
+# Path to the make_mkv script
+$make_mkv = "/naspool/videos/bin/make_mkv";
+
+# mkvmerge path/command name
+$mkvmerge = 'mkvmerge';
+
+# ffmpeg path/command name
+$ffmpeg = 'ffmpeg';
+
+# handbrake path/command name
+$handbrake = 'HandBrakeCLI';
+
+# The pid file to use to indicate organize_videos is running
+$pid_file = "/tmp/organize_videos.pid";
+
+# The owner of the files after they are moved
+$owner = "ajp";
+
+# The group of the files after they are moved
+$group = "pip";
+
+# The mode to set on each file after they are moved
+$mode = "664";
+
+# The extension to use when creating playlist files
+$playlist_extension = "pls";
+
+# What number to start with when adding an incrementing suffix to the end of the final video clip to avoid name collisions
+$video_suffix = "000";
+
+# Which movie file extensions should be considered for merging
+# NOTE: Script does not support merging multiple mkv files into a single mkv file
+$movie_file_ext = "-iregex \".*\.mov\" -o -iregex \".*\.3gp\" -o -iregex \".*\.mp4\" -o -iregex \".*\.mts\" -o -iregex \".*\.m4v\"";
+
+# Video file creation dates must not have changed in the last X minutes to process any of the video files
+# This is done to ensure that all videos from a given upload from a camera have completed prior to looking for videos to merge
+$minage = "+30";
+
+# What command should be used to find files that have changed (are at least $minage old) 
+$find_changed_cmd = "find  \"$srcpathname/\" -not -cmin $minage -a \\( $movie_file_ext \\)";
+
+# What command should be used to find all movie files
+$find_cmd = "find \"$srcpathname/\" $movie_file_ext";
+$find_cmd_with_mkv = "find \"$srcpathname/\" $movie_file_ext -o -iregex \".*\.mkv\"";
+
+# Set the tmpfile to use
+$tmpfile = `tempfile`; chomp($tmpfile);
+
+# Set the timezone to use
+$timezone = `cat /etc/timezone`; chomp($timezone);
+
+# handbrake options used when re-encoding the videos
+$handbrake_options='--strict-anamorphic --crop 0:0:0:0 -E ac3';
+
+# tmp chapter file used by handbrake when creating mkv
+$chapter_file = $tmpfile;
+
+# handbrake input file options
+$input_file_options = "-S";
+
+# handbrake output file options
+$output_file_options = "--chapters $chapter_file --compression -1:none";
+
+# handbrake quantization levels
+$interlaced_requantize_quality=0.85;
+$progressive_requantize_quality=0.75;
+
+# Remote compute host to farm handbrake encode job off to (I need this since this script is run from a virtual machine)
+$compute_host = "pippin.pippins.net";
+
+# Set to 1 to use a remote compute host to run the mkvmerge command. Set to 0 to use the local host to run it.
+$use_compute_host = 1;
+
+# This will dramatically decrease the size of the video with minimal compute processing requirements.
+$requantize_input_video=1; 
+
+# What text to put on the front of the title for the merged video being created
+$video_title_prefix = "HomeVideos:";
+
+####################################################################################################