468663ddbb
Former-commit-id: 1d6753294b2993e1fbf92de9366bb9544db4189b
215 lines
5.5 KiB
C#
215 lines
5.5 KiB
C#
//
|
|
// System.Web.Security.FormsAuthenticationTicket
|
|
//
|
|
// Authors:
|
|
// Gonzalo Paniagua Javier (gonzalo@ximian.com)
|
|
//
|
|
// (C) 2002 Ximian, Inc (http://www.ximian.com)
|
|
// Copyright (c) 2005 Novell, Inc (http://www.novell.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.IO;
|
|
using System.Security.Permissions;
|
|
|
|
namespace System.Web.Security
|
|
{
|
|
// CAS - no InheritanceDemand here as the class is sealed
|
|
[AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
|
|
// attributes
|
|
[Serializable]
|
|
public sealed class FormsAuthenticationTicket
|
|
{
|
|
int version;
|
|
bool persistent;
|
|
DateTime issue_date;
|
|
DateTime expiration;
|
|
string name;
|
|
string cookie_path;
|
|
string user_data;
|
|
|
|
/*
|
|
internal void ToStr ()
|
|
{
|
|
Console.WriteLine ("version: {0}", version);
|
|
Console.WriteLine ("persistent: {0}", persistent);
|
|
Console.WriteLine ("issue_date: {0}", issue_date);
|
|
Console.WriteLine ("expiration: {0}", expiration);
|
|
Console.WriteLine ("name: {0}", name);
|
|
Console.WriteLine ("cookie_path: {0}", cookie_path);
|
|
Console.WriteLine ("user_data: {0}", user_data);
|
|
}
|
|
*/
|
|
|
|
internal byte [] ToByteArray ()
|
|
{
|
|
MemoryStream ms = new MemoryStream ();
|
|
BinaryWriter writer = new BinaryWriter (ms);
|
|
writer.Write (version);
|
|
writer.Write (persistent);
|
|
writer.Write (issue_date.Ticks);
|
|
writer.Write (expiration.Ticks);
|
|
writer.Write (name != null);
|
|
if (name != null)
|
|
writer.Write (name);
|
|
|
|
writer.Write (cookie_path != null);
|
|
if (cookie_path != null)
|
|
writer.Write (cookie_path);
|
|
|
|
writer.Write (user_data != null);
|
|
if (user_data != null)
|
|
writer.Write (user_data);
|
|
|
|
writer.Flush ();
|
|
return ms.ToArray ();
|
|
}
|
|
|
|
internal static FormsAuthenticationTicket FromByteArray (byte [] bytes)
|
|
{
|
|
if (bytes == null)
|
|
throw new ArgumentNullException ("bytes");
|
|
|
|
MemoryStream ms = new MemoryStream (bytes);
|
|
BinaryReader reader = new BinaryReader (ms);
|
|
FormsAuthenticationTicket ticket = new FormsAuthenticationTicket ();
|
|
ticket.version = reader.ReadInt32 ();
|
|
ticket.persistent = reader.ReadBoolean ();
|
|
ticket.issue_date = new DateTime (reader.ReadInt64 ());
|
|
ticket.expiration = new DateTime (reader.ReadInt64 ());
|
|
if (reader.ReadBoolean ())
|
|
ticket.name = reader.ReadString ();
|
|
|
|
if (reader.ReadBoolean ())
|
|
ticket.cookie_path = reader.ReadString ();
|
|
|
|
if (reader.ReadBoolean ())
|
|
ticket.user_data = reader.ReadString ();
|
|
|
|
return ticket;
|
|
}
|
|
|
|
FormsAuthenticationTicket ()
|
|
{
|
|
}
|
|
|
|
public FormsAuthenticationTicket (int version,
|
|
string name,
|
|
DateTime issueDate,
|
|
DateTime expiration,
|
|
bool isPersistent,
|
|
string userData)
|
|
{
|
|
this.version = version;
|
|
this.name = name;
|
|
this.issue_date = issueDate;
|
|
this.expiration = expiration;
|
|
this.persistent = isPersistent;
|
|
this.user_data = userData;
|
|
this.cookie_path = "/";
|
|
}
|
|
|
|
public FormsAuthenticationTicket (int version,
|
|
string name,
|
|
DateTime issueDate,
|
|
DateTime expiration,
|
|
bool isPersistent,
|
|
string userData,
|
|
string cookiePath)
|
|
{
|
|
this.version = version;
|
|
this.name = name;
|
|
this.issue_date = issueDate;
|
|
this.expiration = expiration;
|
|
this.persistent = isPersistent;
|
|
this.user_data = userData;
|
|
this.cookie_path = cookiePath;
|
|
}
|
|
|
|
public FormsAuthenticationTicket (string name, bool isPersistent, int timeout)
|
|
{
|
|
this.version = 1;
|
|
this.name = name;
|
|
this.issue_date = DateTime.Now;
|
|
this.persistent = isPersistent;
|
|
if (persistent)
|
|
expiration = issue_date.AddYears (50);
|
|
else
|
|
expiration = issue_date.AddMinutes ((double) timeout);
|
|
|
|
this.user_data = "";
|
|
this.cookie_path = "/";
|
|
}
|
|
|
|
internal void SetDates (DateTime issue_date, DateTime expiration)
|
|
{
|
|
this.issue_date = issue_date;
|
|
this.expiration = expiration;
|
|
}
|
|
|
|
internal FormsAuthenticationTicket Clone ()
|
|
{
|
|
return new FormsAuthenticationTicket (version,
|
|
name,
|
|
issue_date,
|
|
expiration,
|
|
persistent,
|
|
user_data,
|
|
cookie_path);
|
|
}
|
|
|
|
public string CookiePath {
|
|
get { return cookie_path; }
|
|
}
|
|
|
|
public DateTime Expiration {
|
|
get { return expiration; }
|
|
}
|
|
|
|
public bool Expired {
|
|
get { return DateTime.UtcNow > expiration.ToUniversalTime(); }
|
|
}
|
|
|
|
public bool IsPersistent {
|
|
get { return persistent; }
|
|
}
|
|
|
|
public DateTime IssueDate {
|
|
get { return issue_date; }
|
|
}
|
|
|
|
public string Name {
|
|
get { return name; }
|
|
}
|
|
|
|
public string UserData {
|
|
get { return user_data; }
|
|
}
|
|
|
|
public int Version {
|
|
get { return version; }
|
|
}
|
|
}
|
|
}
|
|
|