/
LoginThroughMySpace.aspx.cs
110 lines (102 loc) · 4.52 KB
/
LoginThroughMySpace.aspx.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using AspNetDating.Classes;
using AspNetDating.Classes.MySpace;
using AuthorizationRequiredException=AspNetDating.Classes.AuthorizationRequiredException;
using Config=AspNetDating.Classes.Config;
using NotFoundException=AspNetDating.Classes.NotFoundException;
namespace AspNetDating
{
public partial class LoginThroughMySpace : PageBase
{
public LoginThroughMySpace()
{
RequiresAuthorization = false;
}
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
if (Config.Misc.EnableMySpaceIntegration)
{
UserData userData = null;
try
{
userData = DataAvailability.GetUserData(Context, Context.Request.Url);
}
catch (AuthorizationRequiredException authex)
{
Context.Response.Redirect(authex.AuthorizationUri.AbsoluteUri);
}
catch(OAuth.Net.Common.OAuthRequestException)
{
DataAvailability.RevokeAccess(Context);
Response.Redirect("~/LoginThroughMySpace.aspx");
}
if (userData != null)
{
string[] usernames = Classes.User.FetchUsernamesByMySpaceID(new[] { userData.ID });
StatusPageMessage =
"There is no user associated with your MySpace account!".Translate();
if (usernames.Length == 0)
{
DataAvailability.RevokeAccess(Context);
Context.Response.Redirect("ShowStatus.aspx");
}
else
{
UserSession userSession;
try
{
userSession = new UserSession(usernames[0]);
//user.StealthMode = cbStealthMode.Checked;
Classes.User.AuthorizeByMySpaceID(userData.ID);
userSession.Authorize(Session.SessionID);
}
catch (NotFoundException err)
{
DataAvailability.RevokeAccess(Context);
StatusPageMessage = err.Message;
Response.Redirect("ShowStatus.aspx");
return;
}
catch (AccessDeniedException err)
{
DataAvailability.RevokeAccess(Context);
StatusPageMessage = err.Message;
Response.Redirect("ShowStatus.aspx");
return;
}
catch (SmsNotConfirmedException)
{
Response.Redirect("SmsConfirm.aspx?username=" + usernames[0]);
return;
}
catch (ArgumentException err)
{
DataAvailability.RevokeAccess(Context);
StatusPageMessage = err.Message;
Response.Redirect("ShowStatus.aspx");
return;
}
catch (Exception err)
{
DataAvailability.RevokeAccess(Context);
Global.Logger.LogWarning(err);
StatusPageMessage = err.Message;
Response.Redirect("ShowStatus.aspx");
return;
}
CurrentUserSession = userSession;
Response.Redirect("Home.aspx");
}
}
}
}
}
}
}