Metadata bug fixes

Fixed: Don't link XBMC episode images to Roksbox
Fixed: Don't scan for metadata until files are imported
pull/3113/head
Mark McDowall 11 years ago
parent 1f40bef249
commit 9355c9d9f1

@ -0,0 +1,14 @@
using NzbDrone.Core.Datastore.Migration.Framework;
using FluentMigrator;
namespace NzbDrone.Core.Datastore.Migration
{
[Migration(49)]
public class add_hash_to_metadata_files : NzbDroneMigrationBase
{
protected override void MainDbUpgrade()
{
Alter.Table("MetadataFiles").AddColumn("Hash").AsString().Nullable();
}
}
}

@ -96,7 +96,7 @@ namespace NzbDrone.Core.Metadata.Consumers.Roksbox
}; };
//Series and season images are both named folder.jpg, only season ones sit in season folders //Series and season images are both named folder.jpg, only season ones sit in season folders
if (String.Compare(filename, parentdir.Name, true) == 0) if (String.Compare(filename, parentdir.Name, StringComparison.InvariantCultureIgnoreCase) == 0)
{ {
var seasonMatch = SeasonImagesRegex.Match(parentdir.Name); var seasonMatch = SeasonImagesRegex.Match(parentdir.Name);
if (seasonMatch.Success) if (seasonMatch.Success)
@ -128,16 +128,22 @@ namespace NzbDrone.Core.Metadata.Consumers.Roksbox
if (parseResult != null && if (parseResult != null &&
!parseResult.FullSeason) !parseResult.FullSeason)
{ {
switch (Path.GetExtension(filename).ToLowerInvariant()) var extension = Path.GetExtension(filename).ToLowerInvariant();
if (extension == ".xml")
{ {
case ".xml": metadata.Type = MetadataType.EpisodeMetadata;
metadata.Type = MetadataType.EpisodeMetadata; return metadata;
return metadata; }
case ".jpg":
if (extension == ".jpg")
{
if (!Path.GetFileNameWithoutExtension(filename).EndsWith("-thumb"))
{
metadata.Type = MetadataType.EpisodeImage; metadata.Type = MetadataType.EpisodeImage;
return metadata; return metadata;
} }
}
} }
return null; return null;

@ -147,7 +147,7 @@ namespace NzbDrone.Core.Metadata
new MetadataFile new MetadataFile
{ {
SeriesId = series.Id, SeriesId = series.Id,
Consumer = GetType().Name, Consumer = consumer.GetType().Name,
Type = MetadataType.SeriesMetadata, Type = MetadataType.SeriesMetadata,
}; };
@ -196,7 +196,7 @@ namespace NzbDrone.Core.Metadata
{ {
SeriesId = series.Id, SeriesId = series.Id,
EpisodeFileId = episodeFile.Id, EpisodeFileId = episodeFile.Id,
Consumer = GetType().Name, Consumer = consumer.GetType().Name,
Type = MetadataType.EpisodeMetadata, Type = MetadataType.EpisodeMetadata,
RelativePath = relativePath RelativePath = relativePath
}; };
@ -233,7 +233,7 @@ namespace NzbDrone.Core.Metadata
new MetadataFile new MetadataFile
{ {
SeriesId = series.Id, SeriesId = series.Id,
Consumer = GetType().Name, Consumer = consumer.GetType().Name,
Type = MetadataType.SeriesImage, Type = MetadataType.SeriesImage,
RelativePath = relativePath RelativePath = relativePath
}; };
@ -269,7 +269,7 @@ namespace NzbDrone.Core.Metadata
{ {
SeriesId = series.Id, SeriesId = series.Id,
SeasonNumber = season.SeasonNumber, SeasonNumber = season.SeasonNumber,
Consumer = GetType().Name, Consumer = consumer.GetType().Name,
Type = MetadataType.SeasonImage, Type = MetadataType.SeasonImage,
RelativePath = relativePath RelativePath = relativePath
}; };
@ -317,7 +317,7 @@ namespace NzbDrone.Core.Metadata
{ {
SeriesId = series.Id, SeriesId = series.Id,
EpisodeFileId = episodeFile.Id, EpisodeFileId = episodeFile.Id,
Consumer = GetType().Name, Consumer = consumer.GetType().Name,
Type = MetadataType.EpisodeImage, Type = MetadataType.EpisodeImage,
RelativePath = DiskProviderBase.GetRelativePath(series.Path, image.Path) RelativePath = DiskProviderBase.GetRelativePath(series.Path, image.Path)
}; };

@ -5,14 +5,14 @@ using NLog;
using NzbDrone.Common; using NzbDrone.Common;
using NzbDrone.Common.Disk; using NzbDrone.Common.Disk;
using NzbDrone.Core.MediaFiles; using NzbDrone.Core.MediaFiles;
using NzbDrone.Core.MediaFiles.Events;
using NzbDrone.Core.Messaging.Events; using NzbDrone.Core.Messaging.Events;
using NzbDrone.Core.Metadata.Files; using NzbDrone.Core.Metadata.Files;
using NzbDrone.Core.Parser; using NzbDrone.Core.Parser;
using NzbDrone.Core.Tv.Events;
namespace NzbDrone.Core.Metadata namespace NzbDrone.Core.Metadata
{ {
public class ExistingMetadataService : IHandle<SeriesUpdatedEvent> public class ExistingMetadataService : IHandle<SeriesScannedEvent>
{ {
private readonly IDiskProvider _diskProvider; private readonly IDiskProvider _diskProvider;
private readonly IMetadataFileService _metadataFileService; private readonly IMetadataFileService _metadataFileService;
@ -33,7 +33,7 @@ namespace NzbDrone.Core.Metadata
_consumers = consumers.ToList(); _consumers = consumers.ToList();
} }
public void Handle(SeriesUpdatedEvent message) public void Handle(SeriesScannedEvent message)
{ {
if (!_diskProvider.FolderExists(message.Series.Path)) return; if (!_diskProvider.FolderExists(message.Series.Path)) return;

@ -194,6 +194,7 @@
<Compile Include="Datastore\Migration\046_fix_nzb_su_url.cs" /> <Compile Include="Datastore\Migration\046_fix_nzb_su_url.cs" />
<Compile Include="Datastore\Migration\047_add_published_date_blacklist_column.cs" /> <Compile Include="Datastore\Migration\047_add_published_date_blacklist_column.cs" />
<Compile Include="Datastore\Migration\048_add_title_to_scenemappings.cs" /> <Compile Include="Datastore\Migration\048_add_title_to_scenemappings.cs" />
<Compile Include="Datastore\Migration\049_add_hash_to_metadata_files.cs" />
<Compile Include="Datastore\Migration\Framework\MigrationContext.cs" /> <Compile Include="Datastore\Migration\Framework\MigrationContext.cs" />
<Compile Include="Datastore\Migration\Framework\MigrationController.cs" /> <Compile Include="Datastore\Migration\Framework\MigrationController.cs" />
<Compile Include="Datastore\Migration\Framework\MigrationExtension.cs" /> <Compile Include="Datastore\Migration\Framework\MigrationExtension.cs" />

Loading…
Cancel
Save