1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-10-30 23:42:33 +01:00
Sonarr/NzbDrone.Common/HttpProvider.cs

117 lines
3.7 KiB
C#
Raw Normal View History

2012-02-11 01:48:20 +01:00
using System.Linq;
using System;
using System.Diagnostics;
2011-04-25 20:16:38 +02:00
using System.IO;
using System.Net;
using System.Text;
using NLog;
2010-09-28 05:40:01 +02:00
2012-02-11 01:48:20 +01:00
namespace NzbDrone.Common
2010-09-28 05:40:01 +02:00
{
2011-04-07 04:25:52 +02:00
public class HttpProvider
2010-09-28 05:40:01 +02:00
{
2012-02-11 01:48:20 +01:00
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
2011-04-25 20:16:38 +02:00
public virtual string DownloadString(string address)
{
try
{
2011-04-25 20:16:38 +02:00
return new WebClient().DownloadString(address);
}
catch (Exception ex)
{
2012-02-11 01:48:20 +01:00
logger.TraceException(ex.Message, ex);
2011-04-05 07:30:13 +02:00
throw;
}
}
2011-04-25 20:16:38 +02:00
public virtual string DownloadString(string address, string username, string password)
{
try
{
var webClient = new WebClient();
webClient.Credentials = new NetworkCredential(username, password);
2011-04-25 20:16:38 +02:00
return webClient.DownloadString(address);
}
catch (Exception ex)
{
2012-02-11 01:48:20 +01:00
logger.Warn("Failed to get response from: {0}", address);
logger.TraceException(ex.Message, ex);
2011-04-05 07:30:13 +02:00
throw;
}
2011-04-05 07:30:13 +02:00
}
public virtual Stream DownloadStream(string url, NetworkCredential credential)
2011-04-05 07:30:13 +02:00
{
2011-04-25 20:16:38 +02:00
var request = WebRequest.Create(url);
request.Credentials = credential;
2011-04-25 20:16:38 +02:00
var response = request.GetResponse();
return response.GetResponseStream();
}
2011-04-25 20:16:38 +02:00
public virtual void DownloadFile(string url, string fileName)
{
try
{
var fileInfo = new FileInfo(fileName);
if (!fileInfo.Directory.Exists)
{
fileInfo.Directory.Create();
}
2012-02-11 01:48:20 +01:00
logger.Trace("Downloading [{0}] to [{1}]", url, fileName);
var stopWatch = Stopwatch.StartNew();
var webClient = new WebClient();
webClient.DownloadFile(url, fileName);
stopWatch.Stop();
2012-02-11 01:48:20 +01:00
logger.Trace("Downloading Completed. took {0:0}s", stopWatch.Elapsed.Seconds);
}
catch (Exception ex)
{
2012-02-11 01:48:20 +01:00
logger.Warn("Failed to get response from: {0}", url);
logger.TraceException(ex.Message, ex);
throw;
}
}
public virtual string PostCommand(string address, string username, string password, string command)
{
address = String.Format("http://{0}/jsonrpc", address);
2012-02-11 01:48:20 +01:00
logger.Trace("Posting command: {0}, to {1}", command, address);
byte[] byteArray = Encoding.ASCII.GetBytes(command);
2011-09-27 19:41:36 +02:00
var request = (HttpWebRequest)WebRequest.Create(address);
request.Method = "POST";
request.Credentials = new NetworkCredential(username, password);
2011-09-27 19:41:36 +02:00
request.ContentType = "application/json";
request.Timeout = 20000;
2011-09-27 19:41:36 +02:00
request.KeepAlive = false;
2011-09-27 19:41:36 +02:00
//Used to hold the JSON response
string responseFromServer;
using (var requestStream = request.GetRequestStream())
{
requestStream.Write(byteArray, 0, byteArray.Length);
2011-09-27 19:41:36 +02:00
using (var response = request.GetResponse())
{
using (var responseStream = response.GetResponseStream())
{
using (var reader = new StreamReader(responseStream))
{
responseFromServer = reader.ReadToEnd();
}
}
}
}
return responseFromServer.Replace(" ", " ");
}
2010-09-28 05:40:01 +02:00
}
2010-09-28 07:58:49 +02:00
}