public async Task<ActionResult> ExternalLoginConfirmation(ExternalLoginConfirmationViewModel model, string returnUrl)
		{
			if (User.Identity.IsAuthenticated)
			{
				return RedirectToAction("Index", "Manage");
			}

			if (ModelState.IsValid)
			{
				// Get the information about the user from the external login provider
				var info = await AuthenticationManager.GetExternalLoginInfoAsync();
				if (info == null)
				{
					return View("ExternalLoginFailure");
				}
				var user = new ApplicationUser
				{
					UserName = model.Email,
					Email = model.Email,
					FirstName = model.FirstName,
					LastName = model.LastName,
					PhoneNumber = model.Phone
				};

				var result = await UserManager.CreateAsync(user);
				if (result.Succeeded)
				{
					result = await UserManager.AddLoginAsync(user.Id, info.Login);
					if (result.Succeeded)
					{
						await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false);

						// Send an email with this link
						string emailCode = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
						var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = emailCode }, protocol: Request.Url.Scheme);
						await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");

						if (!string.IsNullOrEmpty(model.Phone))
						{
							// Generate the sms token and send it
							var smsCode = await UserManager.GenerateChangePhoneNumberTokenAsync(user.Id, model.Phone);
							if (UserManager.SmsService != null)
							{
								var message = new IdentityMessage
								{
									Destination = model.Phone,
									Body = "Your security code is: " + smsCode
								};
								await UserManager.SmsService.SendAsync(message);
							}
						}

						return RedirectToLocal(returnUrl);
					}
				}
				AddErrors(result);
			}

			ViewBag.ReturnUrl = returnUrl;
			return View(model);
		}
		public async Task<ActionResult> Register(RegisterViewModel model)
		{
			if (ModelState.IsValid)
			{
				var user = new ApplicationUser { UserName = model.Email, Email = model.Email, FirstName = model.FirstName, LastName = model.LastName };
				var result = await UserManager.CreateAsync(user, model.Password);
				if (result.Succeeded)
				{
					await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false);

					// Send an email with this link
					string emailCode = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
					var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = emailCode }, protocol: Request.Url.Scheme);
					await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");

					if (!string.IsNullOrEmpty(model.PhoneNumber))
					{
						// Generate the sms token and send it
						var smsCode = await UserManager.GenerateChangePhoneNumberTokenAsync(user.Id, model.PhoneNumber);
						if (UserManager.SmsService != null)
						{
							var message = new IdentityMessage
							{
								Destination = model.PhoneNumber,
								Body = "Your security code is: " + smsCode
							};
							await UserManager.SmsService.SendAsync(message);
						}
					}

                    return RedirectToAction("Index", "Manage");
				}

				AddErrors(result);
			}

			// If we got this far, something failed, redisplay form
			return View(model);
		}