Jo Shields 3c1f479b9d Imported Upstream version 4.0.0~alpha1
Former-commit-id: 806294f5ded97629b74c85c09952f2a74fe182d9
2015-04-07 09:35:12 +01:00

108 lines
4.8 KiB
C#

//
// SessionSecurityToken.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.ObjectModel;
using System.Runtime.Serialization;
using System.Security.Claims;
using System.Xml;
namespace System.IdentityModel.Tokens
{
[Serializable]
public class SessionSecurityToken : SecurityToken
{
private ReadOnlyCollection<SecurityKey> securityKeys;
private DateTime validFrom;
private DateTime validTo;
public ClaimsPrincipal ClaimsPrincipal { get; private set; }
public string Context { get; private set; }
public UniqueId ContextId { get; private set; }
public string EndpointId { get; private set; }
[MonoTODO]
public override string Id { get { throw new NotImplementedException (); } }
public bool IsPersistent { get; set; }
public bool IsReferenceMode { get; set; }
public DateTime KeyEffectiveTime { get; private set; }
public DateTime KeyExpirationTime { get; private set; }
public UniqueId KeyGeneration { get; private set; }
public Uri SecureConversationVersion { get; private set; }
public override ReadOnlyCollection<SecurityKey> SecurityKeys { get { return securityKeys; } }
public override DateTime ValidFrom { get { return validFrom; } }
public override DateTime ValidTo { get { return validTo; } }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal)
: this (claimsPrincipal, null)
{ }
protected SessionSecurityToken (SerializationInfo info, StreamingContext context) {
throw new NotImplementedException ();
}
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, string context)
: this (claimsPrincipal, context, DateTime.UtcNow, DateTime.UtcNow + SessionSecurityTokenHandler.DefaultTokenLifetime)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, TimeSpan lifetime)
: this (claimsPrincipal, null, DateTime.UtcNow, DateTime.UtcNow + lifetime)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, string context, DateTime? validFrom, DateTime? validTo)
: this (claimsPrincipal, new UniqueId (), context, String.Empty, validFrom, validTo, null)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, string context, string endpointId, DateTime? validFrom, DateTime? validTo)
: this(claimsPrincipal, new UniqueId (), context, endpointId, validFrom, validTo, null)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, UniqueId contextId, string context, string endpointId, TimeSpan lifetime, SymmetricSecurityKey key)
: this (claimsPrincipal, contextId, context, endpointId, DateTime.UtcNow, lifetime, key)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, UniqueId contextId, string context, string endpointId, DateTime validFrom, TimeSpan lifetime, SymmetricSecurityKey key)
: this (claimsPrincipal, contextId, context, endpointId, validFrom, validFrom + lifetime, key)
{ }
public SessionSecurityToken (ClaimsPrincipal claimsPrincipal, UniqueId contextId, string context, string endpointId, DateTime? validFrom, DateTime? validTo, SymmetricSecurityKey key) {
ClaimsPrincipal = claimsPrincipal;
ContextId = contextId;
Context = context;
EndpointId = endpointId;
validFrom = (validFrom.HasValue) ? validFrom.Value.ToUniversalTime () : DateTime.UtcNow;
validTo = (validTo.HasValue) ? validTo.Value.ToUniversalTime () : ValidFrom + SessionSecurityTokenHandler.DefaultTokenLifetime;
securityKeys = new ReadOnlyCollection<SecurityKey> (new SecurityKey[] { new InMemorySymmetricSecurityKey ((key == null) ? null : key.GetSymmetricKey ()) });
}
[MonoTODO]
public virtual void GetObjectData (SerializationInfo info, StreamingContext context) {
throw new NotImplementedException ();
}
}
}