DSInternals/Src/DSInternals.DataStore/AttributeMetadata.cs
2015-12-26 23:44:43 +01:00

110 lines
3.9 KiB
C#

using System;
using System.Runtime.InteropServices;
namespace DSInternals.DataStore
{
/// <summary>
/// The AttributeMetadata class is used to contain replication metadata for an Active Directory Domain Services attribute.
/// </summary>
/// <see>https://msdn.microsoft.com/en-us/library/system.directoryservices.activedirectory.attributemetadata.aspx</see>
public class AttributeMetadata
{
// TODO: Rename parameters to match field names
public AttributeMetadata(int attributeId, Guid invocationId, DateTime time, long usn)
{
this.AttributeId = attributeId;
this.Version = 1;
this.LastOriginatingChangeTime = time;
this.LastOriginatingInvocationId = invocationId;
this.OriginatingChangeUsn = usn;
this.LocalChangeUsn = usn;
}
public AttributeMetadata(int attributeId, int version, long timestamp, Guid originatingDSA, long originatingUSN, long localUSN)
{
this.AttributeId = attributeId;
this.Version = version;
this.LastOriginatingChangeTimestamp = timestamp;
this.LastOriginatingInvocationId = originatingDSA;
this.OriginatingChangeUsn = originatingUSN;
this.LocalChangeUsn = localUSN;
}
/// <summary>
/// Gets the identifier of the attribute.
/// </summary>
public int AttributeId
{
get;
private set;
}
/// <summary>
/// Gets or sets the version number of this attribute.
/// </summary>
public int Version
{
get;
private set;
}
/// <summary>
/// Gets the timestamp at which the last originating change was made to this attribute.
/// </summary>
public long LastOriginatingChangeTimestamp
{
get;
private set;
}
/// <summary>
/// Gets or sets the invocation identifier of the server on which the last change was made to this attribute.
/// </summary>
public Guid LastOriginatingInvocationId
{
get;
private set;
}
/// <summary>
/// Gets or sets the update sequence number (USN) on the originating server at which the last change to this attribute was made.
/// </summary>
public long OriginatingChangeUsn
{
get;
private set;
}
/// <summary>
/// Gets or sets the update sequence number (USN) on the destination server at which the last change to this attribute was applied.
/// </summary>
public long LocalChangeUsn
{
get;
private set;
}
/// <summary>
/// Gets or sets the time at which the last originating change was made to this attribute.
/// </summary>
public DateTime LastOriginatingChangeTime
{
get
{
DateTime result = DateTime.FromFileTime(this.LastOriginatingChangeTimestamp * ADConstants.GeneralizedTimeCoefficient);
return result;
}
private set
{
this.LastOriginatingChangeTimestamp = value.ToFileTime() / ADConstants.GeneralizedTimeCoefficient;
}
}
public void Update(Guid invocationId, DateTime time, long usn)
{
this.LastOriginatingInvocationId = invocationId;
this.LocalChangeUsn = usn;
this.OriginatingChangeUsn = usn;
this.LastOriginatingChangeTime = time;
this.Version++;
}
public override string ToString()
{
return String.Format("AttId: {0}, Ver: {1}, USN: {2}, Time: {3}, DSA: {4}", this.AttributeId, this.Version, this.OriginatingChangeUsn, this.LastOriginatingChangeTime, this.LastOriginatingInvocationId);
}
}
}