You've already forked linux-packaging-mono
Imported Upstream version 3.10.0
Former-commit-id: 172c8e3c300b39d5785c7a3e8dfb08ebdbc1a99b
This commit is contained in:
@ -0,0 +1,109 @@
|
||||
//
|
||||
// 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.
|
||||
//
|
||||
#if NET_4_5
|
||||
|
||||
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 ();
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
Reference in New Issue
Block a user