147 lines
5.0 KiB
C#
147 lines
5.0 KiB
C#
|
//
|
|||
|
// SessionSecurityTokenHandler.cs
|
|||
|
//
|
|||
|
// Author:
|
|||
|
// Noesis Labs (Ryan.Melena@noesislabs.com)
|
|||
|
//
|
|||
|
// Copyright (C) 2014 Noesis Labs, LLC https://noesislabs.com
|
|||
|
//
|
|||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
|||
|
// a copy of this software and associated documentation files (the
|
|||
|
// "Software"), to deal in the Software without restriction, including
|
|||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
|||
|
// permit persons to whom the Software is furnished to do so, subject to
|
|||
|
// the following conditions:
|
|||
|
//
|
|||
|
// The above copyright notice and this permission notice shall be
|
|||
|
// included in all copies or substantial portions of the Software.
|
|||
|
//
|
|||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||
|
//
|
|||
|
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.Collections.ObjectModel;
|
|||
|
using System.IdentityModel.Selectors;
|
|||
|
using System.Security.Claims;
|
|||
|
using System.Xml;
|
|||
|
|
|||
|
namespace System.IdentityModel.Tokens
|
|||
|
{
|
|||
|
public class SessionSecurityTokenHandler : SecurityTokenHandler
|
|||
|
{
|
|||
|
public static readonly ReadOnlyCollection<CookieTransform> DefaultCookieTransforms;
|
|||
|
public static readonly TimeSpan DefaultLifetime = TimeSpan.FromHours (10);
|
|||
|
|
|||
|
private bool canValidateToken;
|
|||
|
private bool canWriteToken;
|
|||
|
private string cookieElementName;
|
|||
|
private string cookieNamespace;
|
|||
|
private Type tokenType;
|
|||
|
|
|||
|
public override bool CanValidateToken { get { return canValidateToken; } }
|
|||
|
public override bool CanWriteToken { get { return canWriteToken; } }
|
|||
|
public virtual string CookieElementName { get { return cookieElementName; } }
|
|||
|
public virtual string CookieNamespace { get { return cookieNamespace; } }
|
|||
|
public static TimeSpan DefaultTokenLifetime { get { return SessionSecurityTokenHandler.DefaultLifetime; } }
|
|||
|
public virtual TimeSpan TokenLifetime { get; set; }
|
|||
|
public override Type TokenType { get { return tokenType; } }
|
|||
|
public ReadOnlyCollection<CookieTransform> Transforms { get; private set; }
|
|||
|
|
|||
|
public SessionSecurityTokenHandler ()
|
|||
|
: this (SessionSecurityTokenHandler.DefaultCookieTransforms)
|
|||
|
{ }
|
|||
|
|
|||
|
public SessionSecurityTokenHandler (ReadOnlyCollection<CookieTransform> transforms)
|
|||
|
: this (transforms, SessionSecurityTokenHandler.DefaultLifetime)
|
|||
|
{ }
|
|||
|
|
|||
|
public SessionSecurityTokenHandler (ReadOnlyCollection<CookieTransform> transforms, TimeSpan tokenLifetime) {
|
|||
|
Transforms = transforms;
|
|||
|
TokenLifetime = tokenLifetime;
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
protected virtual byte[] ApplyTransforms (byte[] cookie, bool outbound) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override bool CanReadToken (XmlReader reader) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public virtual SessionSecurityToken CreateSessionSecurityToken (ClaimsPrincipal principal, string context, string endpointId, DateTime validFrom, DateTime validTo) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override SecurityToken CreateToken (SecurityTokenDescriptor tokenDescriptor) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override string[] GetTokenTypeIdentifiers () {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override void LoadCustomConfiguration (XmlNodeList customConfigElements) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override SecurityToken ReadToken (XmlReader reader) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public virtual SecurityToken ReadToken (byte[] token, SecurityTokenResolver tokenResolver) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override SecurityToken ReadToken(XmlReader reader, SecurityTokenResolver tokenResolver) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
protected void SetTransforms (IEnumerable<CookieTransform> transforms) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
protected virtual void ValidateSession (SessionSecurityToken securityToken) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override ReadOnlyCollection<ClaimsIdentity> ValidateToken (SecurityToken token) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public virtual ReadOnlyCollection<ClaimsIdentity> ValidateToken (SessionSecurityToken token, string endpointId) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public virtual byte[] WriteToken (SessionSecurityToken sessionToken) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
|
|||
|
[MonoTODO]
|
|||
|
public override void WriteToken (XmlWriter writer, SecurityToken token) {
|
|||
|
throw new NotImplementedException ();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|