I\'ve overridden the CredentialsAuthProvider like so:
public override bool TryAuthenticate(IServiceBase authService, string userName, string password)
{
mythz,
Good call on making this OSS. :)
You are correct regarding the order of precedence:
So in my example, I didn't have the Continue QueryString, Form Data or Request DTO variable, and I didn't have the CallbackUrl, and certainly not the Session.ReferrerUrl because this is the first post of the Session.
From AuthService.cs
:
var referrerUrl = request.Continue
?? session.ReferrerUrl
?? this.RequestContext.GetHeader("Referer")
?? oAuthConfig.CallbackUrl;
By default referrerUrl will have the Referer header value from the request. And that is what is going to be assigned to the Location header further down the Post
method of the AuthService.cs
:
if (!(response is IHttpResult))
{
return new HttpResult(response) {
Location = referrerUrl
};
}
Once authenticated, and the session.ReferrerUrl
is set here the response will be sent to the client with the Location property above set to the original referrer, not the value below:
public override void OnAuthenticated(IServiceBase authService, IAuthSession session, IOAuthTokens tokens, Dictionary authInfo)
{
session.ReferrerUrl = "http://www.msn.com";
}
It's only on the second POST of the same session will the client navigate to www.msn.com (in this example) because the session has already been populated. I think this:
var referrerUrl = request.Continue
?? session.ReferrerUrl
?? this.RequestContext.GetHeader("Referer")
?? oAuthConfig.CallbackUrl;
Needs to be determined after the call to auth.