1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-06 06:41:40 +02:00
Sonarr/NzbDrone.Common/HttpProvider.cs

142 lines
4.6 KiB
C#
Raw Normal View History

2013-04-11 02:41:45 +03:00
using System;
using System.Collections.Generic;
using System.Diagnostics;
2011-04-25 21:16:38 +03:00
using System.IO;
using System.Net;
using System.Text;
using NLog;
using NzbDrone.Common.EnvironmentInfo;
2010-09-28 06:40:01 +03:00
2012-02-11 03:48:20 +03:00
namespace NzbDrone.Common
2010-09-28 06:40:01 +03:00
{
2013-04-11 02:41:45 +03:00
public interface IHttpProvider
{
string DownloadString(string url);
string DownloadString(string url, string username, string password);
string DownloadString(string url, ICredentials identity);
2013-06-03 09:12:31 +03:00
Dictionary<string, string> GetHeader(string url);
2013-04-11 02:41:45 +03:00
Stream DownloadStream(string url, NetworkCredential credential = null);
void DownloadFile(string url, string fileName);
string PostCommand(string address, string username, string password, string command);
}
public class HttpProvider : IHttpProvider
2010-09-28 06:40:01 +03:00
{
public const string ContentLenghtHeader = "Content-Length";
2012-02-11 03:48:20 +03:00
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
private readonly string _userAgent;
public HttpProvider()
{
_userAgent = String.Format("NzbDrone {0}", BuildInfo.Version);
}
public string DownloadString(string url)
{
return DownloadString(url, null);
}
public string DownloadString(string url, string username, string password)
{
return DownloadString(url, new NetworkCredential(username, password));
}
public string DownloadString(string url, ICredentials identity)
{
try
{
var client = new WebClient { Credentials = identity };
client.Headers.Add(HttpRequestHeader.UserAgent, _userAgent);
return client.DownloadString(url);
}
catch (WebException e)
{
logger.Warn("Failed to get response from: {0} {1}", url, e.Message);
throw;
}
catch (Exception e)
{
logger.WarnException("Failed to get response from: " + url, e);
2011-04-05 08:30:13 +03:00
throw;
}
2011-04-05 08:30:13 +03:00
}
2013-06-03 09:12:31 +03:00
public Dictionary<string, string> GetHeader(string url)
{
var headers = new Dictionary<string, string>();
var request = WebRequest.Create(url);
request.Method = "HEAD";
var response = request.GetResponse();
2013-06-03 09:12:31 +03:00
foreach (var key in response.Headers.AllKeys)
{
headers.Add(key, response.Headers[key]);
}
return headers;
}
2013-04-11 02:41:45 +03:00
public Stream DownloadStream(string url, NetworkCredential credential = null)
2011-04-05 08:30:13 +03:00
{
var request = (HttpWebRequest)WebRequest.Create(url);
request.UserAgent = _userAgent;
request.Timeout = 20 * 1000;
2011-04-25 21:16:38 +03:00
request.Credentials = credential;
2011-04-25 21:16:38 +03:00
var response = request.GetResponse();
return response.GetResponseStream();
}
2011-04-25 21:16:38 +03:00
2013-04-11 02:41:45 +03:00
public void DownloadFile(string url, string fileName)
{
try
{
var fileInfo = new FileInfo(fileName);
if (fileInfo.Directory != null && !fileInfo.Directory.Exists)
{
fileInfo.Directory.Create();
}
2012-02-11 03:48:20 +03:00
logger.Trace("Downloading [{0}] to [{1}]", url, fileName);
var stopWatch = Stopwatch.StartNew();
var webClient = new WebClient();
webClient.Headers.Add(HttpRequestHeader.UserAgent, _userAgent);
webClient.DownloadFile(url, fileName);
stopWatch.Stop();
2012-02-11 03:48:20 +03:00
logger.Trace("Downloading Completed. took {0:0}s", stopWatch.Elapsed.Seconds);
}
catch (WebException e)
{
logger.Warn("Failed to get response from: {0} {1}", url, e.Message);
throw;
}
catch (Exception e)
{
logger.WarnException("Failed to get response from: " + url, e);
throw;
}
}
2013-04-11 02:41:45 +03:00
public string PostCommand(string address, string username, string password, string command)
{
address = String.Format("http://{0}/jsonrpc", address);
2012-02-11 03:48:20 +03:00
logger.Trace("Posting command: {0}, to {1}", command, address);
byte[] byteArray = Encoding.ASCII.GetBytes(command);
var wc = new WebClient();
wc.Credentials = new NetworkCredential(username, password);
var response = wc.UploadData(address, "POST", byteArray);
var text = Encoding.ASCII.GetString(response);
return text.Replace("&nbsp;", " ");
}
2010-09-28 06:40:01 +03:00
}
2010-09-28 08:58:49 +03:00
}