sonarr-repo-only/NzbDrone.Services/NzbDrone.Services.Service/Controllers/ReportingController.cs

72 lines
1.8 KiB
C#
Raw Normal View History

using System;
using System.Linq;
using System.Web.Mvc;
2012-02-16 06:16:57 +00:00
using NLog;
using NzbDrone.Common;
using NzbDrone.Common.Contract;
using NzbDrone.Services.Service.Repository.Reporting;
using PetaPoco;
namespace NzbDrone.Services.Service.Controllers
{
public class ReportingController : Controller
{
private readonly IDatabase _database;
2012-02-16 06:16:57 +00:00
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
private const string OK = "OK";
public ReportingController(IDatabase database)
{
_database = database;
}
[HttpPost]
public JsonResult ParseError(ParseErrorReport parseErrorReport)
{
2012-02-16 06:16:57 +00:00
logger.Trace(parseErrorReport.NullCheck());
if (ParseErrorExists(parseErrorReport.Title))
return Json(OK);
var row = new ParseErrorRow();
row.LoadBase(parseErrorReport);
row.Title = parseErrorReport.Title;
_database.Insert(row);
return Json(OK);
}
private bool ParseErrorExists(string title)
{
return _database.Exists<ParseErrorRow>("WHERE Title = @0", title);
}
[HttpPost]
public JsonResult ReportException(ExceptionReport exceptionReport)
{
2012-02-16 06:16:57 +00:00
try
{
var row = new ExceptionRow();
row.LoadBase(exceptionReport);
row.LogMessage = exceptionReport.LogMessage;
row.Logger = exceptionReport.Logger;
row.String = exceptionReport.String;
row.Type = exceptionReport.Type;
2012-02-16 06:16:57 +00:00
_database.Insert(row);
2012-02-16 06:16:57 +00:00
return Json(OK);
}
catch(Exception)
{
logger.Trace(exceptionReport.NullCheck());
throw;
}
}
}
}