48 lines
2.6 KiB
C#
48 lines
2.6 KiB
C#
using System.Net.Http;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using System.Net;
|
|
using MusicStore.Mocks.Common;
|
|
|
|
namespace MusicStore.Mocks.Facebook
|
|
{
|
|
/// <summary>
|
|
/// Summary description for FacebookMockBackChannelHttpHandler
|
|
/// </summary>
|
|
public class FacebookMockBackChannelHttpHandler : HttpMessageHandler
|
|
{
|
|
protected async override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
|
|
{
|
|
var response = new HttpResponseMessage();
|
|
var queryParameters = request.RequestUri.ParseQueryString();
|
|
|
|
if (request.RequestUri.AbsoluteUri.StartsWith("https://graph.facebook.com/oauth/access_token"))
|
|
{
|
|
if (queryParameters["grant_type"] == "authorization_code")
|
|
{
|
|
if (queryParameters["code"] == "ValidCode")
|
|
{
|
|
Helpers.ThrowIfConditionFailed(() => queryParameters["redirect_uri"].EndsWith("signin-facebook"), "Redirect URI is not ending with /signin-facebook");
|
|
Helpers.ThrowIfConditionFailed(() => queryParameters["client_id"] == "[AppId]", "Invalid client Id received");
|
|
Helpers.ThrowIfConditionFailed(() => queryParameters["client_secret"] == "[AppSecret]", "Invalid client secret received");
|
|
response.Content = new StringContent("access_token=ValidAccessToken&expires=100");
|
|
}
|
|
}
|
|
}
|
|
else if (request.RequestUri.AbsoluteUri.StartsWith("https://graph.facebook.com/me"))
|
|
{
|
|
Helpers.ThrowIfConditionFailed(() => queryParameters["appsecret_proof"] != null, "appsecret_proof is null");
|
|
if (queryParameters["access_token"] == "ValidAccessToken")
|
|
{
|
|
response.Content = new StringContent("{\"id\":\"Id\",\"name\":\"AspnetvnextTest AspnetvnextTest\",\"first_name\":\"AspnetvnextTest\",\"last_name\":\"AspnetvnextTest\",\"link\":\"https:\\/\\/www.facebook.com\\/myLink\",\"username\":\"AspnetvnextTest.AspnetvnextTest.7\",\"gender\":\"male\",\"email\":\"AspnetvnextTest\\u0040gmail.com\",\"timezone\":-7,\"locale\":\"en_US\",\"verified\":true,\"updated_time\":\"2013-08-06T20:38:48+0000\",\"CertValidatorInvoked\":\"ValidAccessToken\"}");
|
|
}
|
|
else
|
|
{
|
|
response.Content = new StringContent("{\"error\":{\"message\":\"Invalid OAuth access token.\",\"type\":\"OAuthException\",\"code\":190}}");
|
|
}
|
|
}
|
|
|
|
return await Task.FromResult(response);
|
|
}
|
|
}
|
|
} |