diff --git a/NzbDrone.Core.Test/Files/SceneMappings.csv b/NzbDrone.Core.Test/Files/SceneMappings.csv
deleted file mode 100644
index 4238b2ebb..000000000
--- a/NzbDrone.Core.Test/Files/SceneMappings.csv
+++ /dev/null
@@ -1,5 +0,0 @@
-csinewyork,73696,CSI
-csiny,73696,CSI
-csi,72546,CSI
-csilasvegas,72546,CSI
-archer,110381,Archer
\ No newline at end of file
diff --git a/NzbDrone.Core.Test/Files/SceneMappings.json b/NzbDrone.Core.Test/Files/SceneMappings.json
new file mode 100644
index 000000000..a914ecdc9
--- /dev/null
+++ b/NzbDrone.Core.Test/Files/SceneMappings.json
@@ -0,0 +1,27 @@
+[
+ {
+ "CleanTitle": "csinewyork",
+ "Id": "73696",
+ "Title": "CSI"
+ },
+ {
+ "CleanTitle": "csiny",
+ "Id": "73696",
+ "Title": "CSI"
+ },
+ {
+ "CleanTitle": "csi",
+ "Id": "72546",
+ "Title": "CSI"
+ },
+ {
+ "CleanTitle": "csilasvegas",
+ "Id": "72546",
+ "Title": "CSI"
+ },
+ {
+ "CleanTitle": "archer",
+ "Id": "110381",
+ "Title": "Archer"
+ }
+]
\ No newline at end of file
diff --git a/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj b/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
index db25df83f..24241cdaf 100644
--- a/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
+++ b/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
@@ -235,7 +235,7 @@
Designer
Always
-
+
Always
diff --git a/NzbDrone.Core.Test/ProviderTests/SceneMappingProviderTest.cs b/NzbDrone.Core.Test/ProviderTests/SceneMappingProviderTest.cs
index a400776ba..9a9a37160 100644
--- a/NzbDrone.Core.Test/ProviderTests/SceneMappingProviderTest.cs
+++ b/NzbDrone.Core.Test/ProviderTests/SceneMappingProviderTest.cs
@@ -17,16 +17,16 @@ namespace NzbDrone.Core.Test.ProviderTests
// ReSharper disable InconsistentNaming
public class SceneMappingProviderTest : CoreTest
{
- private const string SceneMappingUrl = "http://www.nzbdrone.com/SceneMappings.csv";
+ private const string SceneMappingUrl = "http://services.nzbdrone.com/SceneMapping/Active";
- private void WithValidCsv()
+ private void WithValidJson()
{
Mocker.GetMock()
.Setup(s => s.DownloadString(SceneMappingUrl))
- .Returns(File.ReadAllText(@".\Files\SceneMappings.csv"));
+ .Returns(File.ReadAllText(@".\Files\SceneMappings.json"));
}
- private void WithErrorDownloadingCsv()
+ private void WithErrorDownloadingJson()
{
Mocker.GetMock()
.Setup(s => s.DownloadString(SceneMappingUrl))
@@ -163,13 +163,13 @@ public void UpdateMappings_should_add_all_mappings_to_database()
{
//Setup
WithRealDb();
- WithValidCsv();
+ WithValidJson();
//Act
Mocker.Resolve().UpdateMappings();
//Assert
- Mocker.Verify(v => v.DownloadString(It.IsAny()), Times.Once());
+ Mocker.Verify(v => v.DownloadString(SceneMappingUrl), Times.Once());
var result = Db.Fetch();
result.Should().HaveCount(5);
}
@@ -185,14 +185,14 @@ public void UpdateMappings_should_overwrite_existing_mappings()
.Build();
WithRealDb();
- WithValidCsv();
+ WithValidJson();
Db.Insert(fakeMap);
//Act
Mocker.Resolve().UpdateMappings();
//Assert
- Mocker.Verify(v => v.DownloadString(It.IsAny()), Times.Once());
+ Mocker.Verify(v => v.DownloadString(SceneMappingUrl), Times.Once());
var result = Db.Fetch();
result.Should().HaveCount(5);
}
@@ -208,14 +208,14 @@ public void UpdateMappings_should_not_delete_if_csv_download_fails()
.Build();
WithRealDb();
- WithErrorDownloadingCsv();
+ WithErrorDownloadingJson();
Db.Insert(fakeMap);
//Act
Mocker.Resolve().UpdateMappings();
//Assert
- Mocker.Verify(v => v.DownloadString(It.IsAny()), Times.Once());
+ Mocker.Verify(v => v.DownloadString(SceneMappingUrl), Times.Once());
var result = Db.Fetch();
result.Should().HaveCount(1);
}
@@ -237,7 +237,7 @@ public void UpdateIfEmpty_should_not_update_if_count_is_not_zero()
Mocker.Resolve().UpdateIfEmpty();
//Assert
- Mocker.Verify(v => v.DownloadString(It.IsAny()), Times.Never());
+ Mocker.Verify(v => v.DownloadString(SceneMappingUrl), Times.Never());
}
[Test]
@@ -245,7 +245,7 @@ public void UpdateIfEmpty_should_update_if_count_is_zero()
{
//Setup
WithRealDb();
- WithValidCsv();
+ WithValidJson();
//Act
Mocker.Resolve().UpdateIfEmpty();
diff --git a/NzbDrone.Core/Providers/SceneMappingProvider.cs b/NzbDrone.Core/Providers/SceneMappingProvider.cs
index 313d0c6b5..82ca68809 100644
--- a/NzbDrone.Core/Providers/SceneMappingProvider.cs
+++ b/NzbDrone.Core/Providers/SceneMappingProvider.cs
@@ -2,6 +2,7 @@
using System.Collections.Generic;
using System.IO;
using NLog;
+using Newtonsoft.Json;
using NzbDrone.Core.Providers.Core;
using NzbDrone.Core.Repository;
using PetaPoco;
@@ -29,32 +30,16 @@ public virtual bool UpdateMappings()
{
try
{
- var mapping = _httpProvider.DownloadString("http://www.nzbdrone.com/SceneMappings.csv");
- var newMaps = new List();
-
- using (var reader = new StringReader(mapping))
- {
- string line;
- while ((line = reader.ReadLine()) != null)
- {
- var split = line.Split(',');
- int seriesId;
- Int32.TryParse(split[1], out seriesId);
-
- var map = new SceneMapping();
- map.CleanTitle = split[0];
- map.SeriesId = seriesId;
- map.SceneName = split[2];
-
- newMaps.Add(map);
- }
- }
+ const string url = "http://services.nzbdrone.com/SceneMapping/Active";
+
+ var mappingsJson = _httpProvider.DownloadString(url);
+ var mappings = JsonConvert.DeserializeObject>(mappingsJson);
Logger.Debug("Deleting all existing Scene Mappings.");
_database.Delete(String.Empty);
Logger.Debug("Adding Scene Mappings");
- _database.InsertMany(newMaps);
+ _database.InsertMany(mappings);
}
catch (Exception ex)
diff --git a/NzbDrone.Core/Repository/SceneMapping.cs b/NzbDrone.Core/Repository/SceneMapping.cs
index 5cec317c2..73bf07705 100644
--- a/NzbDrone.Core/Repository/SceneMapping.cs
+++ b/NzbDrone.Core/Repository/SceneMapping.cs
@@ -1,4 +1,5 @@
-using PetaPoco;
+using Newtonsoft.Json;
+using PetaPoco;
namespace NzbDrone.Core.Repository
{
@@ -8,8 +9,10 @@ public class SceneMapping
{
public string CleanTitle { get; set; }
+ [JsonProperty(PropertyName = "Id")]
public int SeriesId { get; set; }
+ [JsonProperty(PropertyName = "Title")]
public string SceneName { get; set; }
}
}
\ No newline at end of file