Files
OwinOAuthProviders/src/Owin.Security.Providers.LinkedIn/Provider/LinkedInAuthenticatedContext.cs

184 lines
6.4 KiB
C#

// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.
using System;
using System.Globalization;
using System.Security.Claims;
using Microsoft.Owin;
using Microsoft.Owin.Security;
using Microsoft.Owin.Security.Provider;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
namespace Owin.Security.Providers.LinkedIn
{
/// <summary>
/// Contains information about the login session as well as the user <see cref="System.Security.Claims.ClaimsIdentity"/>.
/// </summary>
public class LinkedInAuthenticatedContext : BaseContext
{
/// <summary>
/// Initializes a <see cref="LinkedInAuthenticatedContext"/>
/// </summary>
/// <param name="context">The OWIN environment</param>
/// <param name="user">The JSON-serialized user</param>
/// <param name="accessToken">LinkedIn Access token</param>
/// <param name="expires">Seconds until expiration</param>
public LinkedInAuthenticatedContext(IOwinContext context, JObject user, string accessToken, string expires)
: base(context)
{
this.User = user;
this.AccessToken = accessToken;
int expiresValue;
if (int.TryParse(expires, NumberStyles.Integer, CultureInfo.InvariantCulture, out expiresValue))
{
this.ExpiresIn = TimeSpan.FromSeconds(expiresValue);
}
this.Id = TryGetValue(user, "id");
this.FamilyName = TryGetLocalizedValue(user, "lastName");
this.GivenName = TryGetLocalizedValue(user, "firstName");
if (this.FamilyName != null || this.GivenName != null)
{
this.Name = string.Join(" ", this.GivenName, this.FamilyName);
}
}
/// <summary>
/// Initializes a <see cref="LinkedInAuthenticatedContext"/>
/// </summary>
/// <param name="context">The OWIN environment</param>
/// <param name="user">The JSON-serialized user</param>
/// <param name="accessToken">LinkedIn Access token</param>
/// <param name="expires">Seconds until expiration</param>
/// <param name="expires">User email returned from dedicated endpoint</param>
public LinkedInAuthenticatedContext(IOwinContext context, JObject user, string accessToken, string expires, string email) : this(context, user, accessToken, expires)
{
this.Email = email;
}
/// <summary>
/// Gets the JSON-serialized user
/// </summary>
/// <remarks>
/// Contains the LinkedIn user obtained from the endpoint https://api.linkedin.com/v1/people/~
/// </remarks>
public JObject User { get; private set; }
/// <summary>
/// Gets the LinkedIn access token
/// </summary>
public string AccessToken { get; private set; }
/// <summary>
/// Gets the LinkedIn access token expiration time
/// </summary>
public TimeSpan? ExpiresIn { get; set; }
/// <summary>
/// Gets the LinkedIn user ID
/// </summary>
public string Id { get; private set; }
/// <summary>
/// Gets the user's name
/// </summary>
public string Name { get; private set; }
/// <summary>
/// Gets the LinkedIn username
/// </summary>
[Obsolete("LinkedIn doesn't return a username claim. Use Name instead.")]
public string UserName { get; private set; }
/// <summary>
/// Get the user's first name
/// </summary>
public string GivenName { get; private set; }
/// <summary>
/// Get the user's last name
/// </summary>
public string FamilyName { get; private set; }
/// <summary>
/// Describes the users membership profile
/// </summary>
[Obsolete("LinkedIn doesn't return this claim anymore.")]
public string Summary { get; private set; }
/// <summary>
/// Industry the member belongs to
/// https://developer.linkedin.com/docs/reference/industry-codes
/// </summary>
[Obsolete("LinkedIn doesn't return this claim anymore.")]
public string Industry { get; set; }
/// <summary>
/// The members headline
/// </summary>
[Obsolete("LinkedIn doesn't return this claim anymore.")]
public string Headline { get; set; }
/// <summary>
/// Member's current positions
/// https://developer.linkedin.com/docs/fields/positions
/// </summary>
[Obsolete("LinkedIn doesn't return this claim anymore.")]
public string Positions { get; set; }
[Obsolete("LinkedIn doesn't return this claim anymore.")]
public string Link { get; private set; }
/// <summary>
/// Gets the LinkedIn email
/// </summary>
public string Email { get; private set; }
/// <summary>
/// Gets the <see cref="ClaimsIdentity"/> representing the user
/// </summary>
public ClaimsIdentity Identity { get; set; }
/// <summary>
/// Gets or sets a property bag for common authentication properties
/// </summary>
public AuthenticationProperties Properties { get; set; }
private static string TryGetValue(JObject user, string propertyName)
{
JToken value;
return user.TryGetValue(propertyName, out value) ? value.ToString() : null;
}
private static string TryGetValueAndSerialize(JObject user, string propertyName)
{
JToken value;
return user.TryGetValue(propertyName, out value) ? JsonConvert.SerializeObject(value) : null;
}
private static string TryGetLocalizedValue(JObject container, string propertyName)
{
var localizedValues = container.SelectToken(propertyName + ".localized") as JObject;
if (localizedValues == null)
{
return null;
}
var defaultValue = TryGetValue(localizedValues, "en-US");
if (defaultValue != null)
{
return defaultValue;
}
if (localizedValues.HasValues)
{
return localizedValues.First.First.Value<string>();
}
return null;
}
}
}