Create a new class Storage and use it to handle figureing out where the event is actually stored.
This commit is contained in:
parent
09c75e2363
commit
3121e5550c
|
@ -30,6 +30,7 @@ use warnings;
|
||||||
|
|
||||||
require Exporter;
|
require Exporter;
|
||||||
require ZoneMinder::Base;
|
require ZoneMinder::Base;
|
||||||
|
require ZoneMinder::Storage;
|
||||||
|
|
||||||
our @ISA = qw(Exporter ZoneMinder::Base);
|
our @ISA = qw(Exporter ZoneMinder::Base);
|
||||||
|
|
||||||
|
@ -200,29 +201,13 @@ sub getEventPath
|
||||||
{
|
{
|
||||||
my $event = shift;
|
my $event = shift;
|
||||||
|
|
||||||
my $event_path = "";
|
my $Storage = new ZoneMinder::Storage( $$event{Id} );
|
||||||
if ( $Config{ZM_USE_DEEP_STORAGE} )
|
my $event_path = join( '/',
|
||||||
{
|
$Storage->Path(),
|
||||||
$event_path = $Config{ZM_DIR_EVENTS}
|
$event->{MonitorId},
|
||||||
.'/'.$event->{MonitorId}
|
( $Config{ZM_USE_DEEP_STORAGE} ? strftime( "%y/%m/%d/%H/%M/%S", localtime($event->{Time}) ) : $event->{Id} ),
|
||||||
.'/'.strftime( "%y/%m/%d/%H/%M/%S",
|
);
|
||||||
localtime($event->{Time})
|
|
||||||
)
|
|
||||||
;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$event_path = $Config{ZM_DIR_EVENTS}
|
|
||||||
.'/'.$event->{MonitorId}
|
|
||||||
.'/'.$event->{Id}
|
|
||||||
;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( index($Config{ZM_DIR_EVENTS},'/') != 0 ){
|
|
||||||
$event_path = $Config{ZM_PATH_WEB}
|
|
||||||
.'/'.$event_path
|
|
||||||
;
|
|
||||||
}
|
|
||||||
return( $event_path );
|
return( $event_path );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,10 +217,8 @@ sub createEventPath
|
||||||
# WARNING assumes running from events directory
|
# WARNING assumes running from events directory
|
||||||
#
|
#
|
||||||
my $event = shift;
|
my $event = shift;
|
||||||
my $eventRootPath = ($Config{ZM_DIR_EVENTS}=~m|/|)
|
my $Storage = new ZoneMinder::Storage( $$event{Id} );
|
||||||
? $Config{ZM_DIR_EVENTS}
|
my $eventPath = $Storage->Path() . '/'.$event->{MonitorId};
|
||||||
: ($Config{ZM_PATH_WEB}.'/'.$Config{ZM_DIR_EVENTS});
|
|
||||||
my $eventPath = $eventRootPath.'/'.$event->{MonitorId};
|
|
||||||
|
|
||||||
if ( $Config{ZM_USE_DEEP_STORAGE} )
|
if ( $Config{ZM_USE_DEEP_STORAGE} )
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,160 @@
|
||||||
|
# ==========================================================================
|
||||||
|
#
|
||||||
|
# ZoneMinder Storage Module, $Date$, $Revision$
|
||||||
|
# Copyright (C) 2001-2008 Philip Coombes
|
||||||
|
#
|
||||||
|
# This program 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 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program 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 this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
#
|
||||||
|
# ==========================================================================
|
||||||
|
#
|
||||||
|
# This module contains the common definitions and functions used by the rest
|
||||||
|
# of the ZoneMinder scripts
|
||||||
|
#
|
||||||
|
package ZoneMinder::Storage;
|
||||||
|
|
||||||
|
use 5.006;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
require Exporter;
|
||||||
|
require ZoneMinder::Base;
|
||||||
|
|
||||||
|
our @ISA = qw(Exporter ZoneMinder::Base);
|
||||||
|
|
||||||
|
# Items to export into callers namespace by default. Note: do not export
|
||||||
|
# names by default without a very good reason. Use EXPORT_OK instead.
|
||||||
|
# Do not simply export all your public functions/methods/constants.
|
||||||
|
|
||||||
|
# This allows declaration use ZoneMinder ':all';
|
||||||
|
# If you do not need this, moving things directly into @EXPORT or @EXPORT_OK
|
||||||
|
# will save memory.
|
||||||
|
our %EXPORT_TAGS = (
|
||||||
|
'functions' => [ qw(
|
||||||
|
) ]
|
||||||
|
);
|
||||||
|
push( @{$EXPORT_TAGS{all}}, @{$EXPORT_TAGS{$_}} ) foreach keys %EXPORT_TAGS;
|
||||||
|
|
||||||
|
our @EXPORT_OK = ( @{ $EXPORT_TAGS{'all'} } );
|
||||||
|
|
||||||
|
our @EXPORT = qw();
|
||||||
|
|
||||||
|
our $VERSION = $ZoneMinder::Base::VERSION;
|
||||||
|
|
||||||
|
# ==========================================================================
|
||||||
|
#
|
||||||
|
# General Utility Functions
|
||||||
|
#
|
||||||
|
# ==========================================================================
|
||||||
|
|
||||||
|
use ZoneMinder::Config qw(:all);
|
||||||
|
use ZoneMinder::Logger qw(:all);
|
||||||
|
use ZoneMinder::Database qw(:all);
|
||||||
|
|
||||||
|
use POSIX;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ( $parent, $id, $data ) = @_;
|
||||||
|
|
||||||
|
my $self = {};
|
||||||
|
bless $self, $parent;
|
||||||
|
if ( ( $$self{id} = $id ) or $data ) {
|
||||||
|
#$log->debug("loading $parent $id") if $debug or DEBUG_ALL;
|
||||||
|
$self->load( $data );
|
||||||
|
}
|
||||||
|
} # end sub new
|
||||||
|
|
||||||
|
sub load {
|
||||||
|
my ( $self, $data ) = @_;
|
||||||
|
my $type = ref $self;
|
||||||
|
if ( ! $data ) {
|
||||||
|
#$log->debug("Object::load Loading from db $type");
|
||||||
|
$data = $ZoneMinder::dbh->selectrow_hashref( 'SELECT * FROM Storage WHERE Id=?', {}, $$self{Id} );
|
||||||
|
if ( ! $data ) {
|
||||||
|
if ( $ZoneMinder::dbh->errstr ) {
|
||||||
|
Error( "Failure to load Storage record for $$self{id}: Reason: " . $ZoneMinder::dbh->errstr );
|
||||||
|
} # end if
|
||||||
|
} # end if
|
||||||
|
} # end if ! $data
|
||||||
|
if ( $data and %$data ) {
|
||||||
|
@$self{keys %$data} = values %$data;
|
||||||
|
} # end if
|
||||||
|
} # end sub load
|
||||||
|
|
||||||
|
sub Path {
|
||||||
|
if ( @_ > 1 ) {
|
||||||
|
$_[0]{Path} = $_[1];
|
||||||
|
}
|
||||||
|
return $_[0]{Path};
|
||||||
|
} # end sub Path
|
||||||
|
|
||||||
|
sub Name {
|
||||||
|
if ( @_ > 1 ) {
|
||||||
|
$_[0]{Name} = $_[1];
|
||||||
|
}
|
||||||
|
return $_[0]{Name};
|
||||||
|
} # end sub Path
|
||||||
|
|
||||||
|
1;
|
||||||
|
__END__
|
||||||
|
# Below is stub documentation for your module. You'd better edit it!
|
||||||
|
|
||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
ZoneMinder::Database - Perl extension for blah blah blah
|
||||||
|
|
||||||
|
=head1 SYNOPSIS
|
||||||
|
|
||||||
|
use ZoneMinder::Storage;
|
||||||
|
blah blah blah
|
||||||
|
|
||||||
|
=head1 DESCRIPTION
|
||||||
|
|
||||||
|
Stub documentation for ZoneMinder, created by h2xs. It looks like the
|
||||||
|
author of the extension was negligent enough to leave the stub
|
||||||
|
unedited.
|
||||||
|
|
||||||
|
Blah blah blah.
|
||||||
|
|
||||||
|
=head2 EXPORT
|
||||||
|
|
||||||
|
None by default.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
=head1 SEE ALSO
|
||||||
|
|
||||||
|
Mention other useful documentation such as the documentation of
|
||||||
|
related modules or operating system documentation (such as man pages
|
||||||
|
in UNIX), or any relevant external documentation such as RFCs or
|
||||||
|
standards.
|
||||||
|
|
||||||
|
If you have a mailing list set up for your module, mention it here.
|
||||||
|
|
||||||
|
If you have a web site set up for your module, mention it here.
|
||||||
|
|
||||||
|
=head1 AUTHOR
|
||||||
|
|
||||||
|
Philip Coombes, E<lt>philip.coombes@zoneminder.comE<gt>
|
||||||
|
|
||||||
|
=head1 COPYRIGHT AND LICENSE
|
||||||
|
|
||||||
|
Copyright (C) 2001-2008 Philip Coombes
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or modify
|
||||||
|
it under the same terms as Perl itself, either Perl version 5.8.3 or,
|
||||||
|
at your option, any later version of Perl 5 you may have available.
|
||||||
|
|
||||||
|
|
||||||
|
=cut
|
Loading…
Reference in New Issue