// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. // Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information. using System; using System.Collections.Generic; using System.Diagnostics.CodeAnalysis; using System.Net.Http; using Microsoft.AspNet.Http; using Microsoft.AspNet.Http.Security; namespace Microsoft.AspNet.Security.Facebook { /// /// Configuration options for . /// public class FacebookAuthenticationOptions : AuthenticationOptions { /// /// Initializes a new . /// [SuppressMessage("Microsoft.Globalization", "CA1303:Do not pass literals as localized parameters", MessageId = "Microsoft.AspNet.Security.Facebook.FacebookAuthenticationOptions.set_Caption(System.String)", Justification = "Not localizable.")] public FacebookAuthenticationOptions() : base(FacebookAuthenticationDefaults.AuthenticationType) { Caption = FacebookAuthenticationDefaults.AuthenticationType; CallbackPath = new PathString("/signin-facebook"); AuthenticationMode = AuthenticationMode.Passive; Scope = new List(); BackchannelTimeout = TimeSpan.FromSeconds(60); SendAppSecretProof = true; } /// /// Gets or sets the Facebook-assigned appId. /// public string AppId { get; set; } /// /// Gets or sets the Facebook-assigned app secret. /// public string AppSecret { get; set; } #if ASPNET50 /// /// Gets or sets the a pinned certificate validator to use to validate the endpoints used /// in back channel communications belong to Facebook. /// /// /// The pinned certificate validator. /// /// If this property is null then the default certificate checks are performed, /// validating the subject name and if the signing chain is a trusted party. public ICertificateValidator BackchannelCertificateValidator { get; set; } #endif /// /// Gets or sets timeout value in milliseconds for back channel communications with Facebook. /// /// /// The back channel timeout in milliseconds. /// public TimeSpan BackchannelTimeout { get; set; } /// /// The HttpMessageHandler used to communicate with Facebook. /// This cannot be set at the same time as BackchannelCertificateValidator unless the value /// can be downcast to a WebRequestHandler. /// public HttpMessageHandler BackchannelHttpHandler { get; set; } /// /// Get or sets the text that the user can display on a sign in user interface. /// public string Caption { get { return Description.Caption; } set { Description.Caption = value; } } /// /// The request path within the application's base path where the user-agent will be returned. /// The middleware will process this request when it arrives. /// Default value is "/signin-facebook". /// public PathString CallbackPath { get; set; } /// /// Gets or sets the name of another authentication middleware which will be responsible for actually issuing a user . /// public string SignInAsAuthenticationType { get; set; } /// /// Gets or sets the used to handle authentication events. /// public IFacebookAuthenticationNotifications Notifications { get; set; } /// /// Gets or sets the type used to secure data handled by the middleware. /// public ISecureDataFormat StateDataFormat { get; set; } /// /// A list of permissions to request. /// public IList Scope { get; private set; } /// /// Gets or sets if the appsecret_proof should be generated and sent with Facebook API calls. /// This is enabled by default. /// public bool SendAppSecretProof { get; set; } } }