Added more keys to the list of bad EXIF keys. CameraID and CameraType seem to make JSON croak...
Fixed issue where bad EXIF cache would kill the entire album Added more variables for resolutions Added better handling of Pending albums and photos.
This commit is contained in:
parent
adcd560cba
commit
d43065b122
8 changed files with 180 additions and 17 deletions
|
|
@ -208,6 +208,21 @@ sub canEdit {
|
|||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 canEditIfLocked ( [userId] )
|
||||
|
||||
Override this to allow editing when locked under a different version tag.
|
||||
|
||||
=cut
|
||||
|
||||
sub canEditIfLocked {
|
||||
my $self = shift;
|
||||
my $userId = shift;
|
||||
|
||||
return $self->canEdit( $userId );
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 canView ( [userId] )
|
||||
|
||||
Returns true if the user can view this asset. C<userId> is a WebGUI user ID.
|
||||
|
|
@ -330,6 +345,42 @@ sub getCommentPaginator {
|
|||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 getCurrentRevisionDate ( session, assetId )
|
||||
|
||||
Override this to allow instanciation of "pending" GalleryFiles for those who
|
||||
are authorized to see them.
|
||||
|
||||
=cut
|
||||
|
||||
sub getCurrentRevisionDate {
|
||||
my $class = shift;
|
||||
my $session = shift;
|
||||
my $assetId = shift;
|
||||
|
||||
# Get the highest revision date, instanciate the asset, and see if
|
||||
# the permissions are enough to return the revisionDate.
|
||||
my $revisionDate
|
||||
= $session->db->quickScalar(
|
||||
"SELECT MAX(revisionDate) FROM GalleryFile WHERE assetId=?",
|
||||
[ $assetId ]
|
||||
);
|
||||
|
||||
return undef unless $revisionDate;
|
||||
|
||||
my $asset = WebGUI::Asset->new( $session, $assetId, $class, $revisionDate );
|
||||
|
||||
return undef unless $asset;
|
||||
|
||||
if ( $asset->get( 'status' ) eq "approved" || $asset->canEdit ) {
|
||||
return $revisionDate;
|
||||
}
|
||||
else {
|
||||
return $class->SUPER::getCurrentRevisionDate( $session, $assetId );
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 getGallery ( )
|
||||
|
||||
Gets the Gallery asset this GalleryFile is a member of.
|
||||
|
|
@ -338,18 +389,10 @@ Gets the Gallery asset this GalleryFile is a member of.
|
|||
|
||||
sub getGallery {
|
||||
my $self = shift;
|
||||
|
||||
# We're using getLinage instead of getParent->getParent because of the
|
||||
# overridden getParent, below.
|
||||
# We need to be able to get the Gallery WITHOUT having to get the GalleryAlbum
|
||||
my $gallery
|
||||
= $self->getLineage( ['ancestors'], {
|
||||
includeOnlyClasses => [ 'WebGUI::Asset::Wobject::Gallery' ],
|
||||
returnObjects => 1,
|
||||
invertTree => 1,
|
||||
} )->[ 0 ];
|
||||
|
||||
return $gallery;
|
||||
|
||||
# We must use getParent->getParent because brand-new assets do not
|
||||
# have a lineage, but they do get assigned a parent.
|
||||
return $self->getParent->getParent;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
|
@ -363,7 +406,7 @@ Get the parent GalleryAlbum. If the only revision of the GalleryAlbum is
|
|||
|
||||
sub getParent {
|
||||
my $self = shift;
|
||||
if ( my $album = $self->getParent ) {
|
||||
if ( my $album = $self->SUPER::getParent ) {
|
||||
return $album;
|
||||
}
|
||||
# Only get the pending version if we're allowed to see this photo in its pending status
|
||||
|
|
|
|||
|
|
@ -176,7 +176,19 @@ sub getExifData {
|
|||
my $self = shift;
|
||||
|
||||
return unless $self->get('exifData');
|
||||
return decode_json( $self->get('exifData') );
|
||||
|
||||
# Our processing and eliminating of bad / unparsable keys
|
||||
# isn't perfect, so handle errors gracefully
|
||||
my $exif = eval { decode_json( $self->get('exifData') ) };
|
||||
if ( $@ ) {
|
||||
$self->session->errorHandler->warn(
|
||||
"Could not parse JSON data for EXIF in Photo '" . $self->get('title')
|
||||
. "' (" . $self->getId . "): " . $@
|
||||
);
|
||||
return;
|
||||
}
|
||||
|
||||
return $exif;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
|
@ -394,8 +406,8 @@ sub updateExifDataFromFile {
|
|||
}
|
||||
}
|
||||
|
||||
# Remove other, pointless keys
|
||||
for my $key ( qw( Directory NativeDigest ) ) {
|
||||
# Remove other, pointless, possibly harmful keys
|
||||
for my $key ( qw( Directory NativeDigest CameraID CameraType ) ) {
|
||||
delete $info->{ $key };
|
||||
}
|
||||
|
||||
|
|
@ -505,6 +517,8 @@ sub www_edit {
|
|||
name => "title",
|
||||
value => ( $form->get("title") || $self->get("title") ),
|
||||
});
|
||||
|
||||
$self->getGallery;
|
||||
|
||||
$var->{ form_synopsis }
|
||||
= WebGUI::Form::HTMLArea( $session, {
|
||||
|
|
|
|||
|
|
@ -557,10 +557,25 @@ sub getAlbumIds {
|
|||
|
||||
my $orderBy = $options->{ orderBy } || "lineage ASC";
|
||||
|
||||
# Deal with "pending" albums.
|
||||
my %pendingRules;
|
||||
if ( $self->canEdit ) {
|
||||
$pendingRules{ statusToInclude } = [ 'pending', 'approved' ];
|
||||
}
|
||||
else {
|
||||
$pendingRules{ statusToInclude } = [ 'pending', 'approved' ];
|
||||
$pendingRules{ whereClause } = q{
|
||||
(
|
||||
status = "approved" || ownerUserId = "} . $self->session->user->userId . q{"
|
||||
)
|
||||
};
|
||||
}
|
||||
|
||||
my $assets
|
||||
= $self->getLineage(['descendants'], {
|
||||
includeOnlyClasses => ['WebGUI::Asset::Wobject::GalleryAlbum'],
|
||||
orderByClause => $orderBy,
|
||||
( %pendingRules ),
|
||||
});
|
||||
|
||||
return $assets;
|
||||
|
|
@ -873,7 +888,7 @@ sub view_listAlbums {
|
|||
$p->appendTemplateVars( $var );
|
||||
|
||||
for my $assetId ( @{ $p->getPageData } ) {
|
||||
my $asset = WebGUI::Asset->newByDynamicClass( $session, $assetId );
|
||||
my $asset = WebGUI::Asset::Wobject::GalleryAlbum->newPending( $session, $assetId );
|
||||
push @{ $var->{albums} }, $asset->getTemplateVars;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -295,6 +295,21 @@ sub canEdit {
|
|||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 canEditIfLocked ( [userId] )
|
||||
|
||||
Override this to allow editing when locked under a different version tag.
|
||||
|
||||
=cut
|
||||
|
||||
sub canEditIfLocked {
|
||||
my $self = shift;
|
||||
my $userId = shift;
|
||||
|
||||
return $self->canEdit( $userId );
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 canView ( [userId] )
|
||||
|
||||
Returns true if the user can view this asset. C<userId> is a WebGUI user ID.
|
||||
|
|
@ -350,6 +365,42 @@ sub getAutoCommitWorkflowId {
|
|||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 getCurrentRevisionDate ( session, assetId )
|
||||
|
||||
Override this to allow instanciation of "pending" GalleryAlbums for those who
|
||||
are authorized to see them.
|
||||
|
||||
=cut
|
||||
|
||||
sub getCurrentRevisionDate {
|
||||
my $class = shift;
|
||||
my $session = shift;
|
||||
my $assetId = shift;
|
||||
|
||||
# Get the highest revision date, instanciate the asset, and see if
|
||||
# the permissions are enough to return the revisionDate.
|
||||
my $revisionDate
|
||||
= $session->db->quickScalar(
|
||||
"SELECT MAX(revisionDate) FROM GalleryAlbum WHERE assetId=?",
|
||||
[ $assetId ]
|
||||
);
|
||||
|
||||
return undef unless $revisionDate;
|
||||
|
||||
my $asset = WebGUI::Asset->new( $session, $assetId, $class, $revisionDate );
|
||||
|
||||
return undef unless $asset;
|
||||
|
||||
if ( $asset->get( 'status' ) eq "approved" || $asset->canEdit ) {
|
||||
return $revisionDate;
|
||||
}
|
||||
else {
|
||||
return $class->SUPER::getCurrentRevisionDate( $session, $assetId );
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 getFileIds ( )
|
||||
|
||||
Gets an array reference of asset IDs for all the files in this album.
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue