File: MS\Internal\Documents\DigitalSignature.cs
Web Access
Project: src\src\Microsoft.DotNet.Wpf\src\PresentationUI\PresentationUI_pidb1sva_wpftmp.csproj (PresentationUI)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
 
// Description:    
//   The DigitalSignature class represents a digital signature or signature
//   request.
 
using System;
using System.Collections.Generic;
using System.Security.Cryptography.X509Certificates;
using System.IO.Packaging;
using System.Security; // for SecurityCritical attributes
using System.Windows.Xps.Packaging; // for XpsDigitalSignature
 
namespace MS.Internal.Documents
{
    /// <summary>
    /// The DigitalSignature class represents a digital signature or signature
    /// request.
    /// </summary>
    internal sealed class DigitalSignature
    {
        #region Constructor
 
        internal DigitalSignature()
        {
        }
 
        #endregion Constructor
 
        #region Internal properties
 
        /// <summary>
        /// Gets or sets the status of signature (Valid, Invalid, NotSigned ...)
        /// </summary>
        internal SignatureStatus SignatureState
        {
            get
            {
                return _signatureState.Value;
            }
 
            set
            {
                _signatureState.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the friendly name of the signer (obtained from the cert.
        /// </summary>
        internal string SubjectName
        {
            get
            {
                return _subjectName.Value;
            }
 
            set
            {
                _subjectName.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the intent (from the Signature Definition)
        /// </summary>
        internal string Reason
        {
            get
            {
                return _reason.Value;
            }
 
            set
            {
                _reason.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets when this signature was applied (not a trusted time)
        /// </summary>
        internal DateTime? SignedOn
        {
            get
            {
                return _signedOn.Value;
            }
            set
            {
                _signedOn.Value = value;
            }
        }
 
        /// <security>
        /// Gets or sets the location field (what signer type into signature definition)
        /// </security>
        internal string Location
        {
            get
            {
                return _location.Value;
            }
 
            set
            {
                _location.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the restriction on document properties
        /// </summary>
        internal bool IsDocumentPropertiesRestricted
        {
            get
            {
                return _isDocumentPropertiesRestricted.Value;
            }
 
            set
            {
                _isDocumentPropertiesRestricted.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets whether adding signatures will invalidate this signature
        /// </summary>
        internal bool IsAddingSignaturesRestricted
        {
            get
            {
                return _isAddingSignaturesRestricted.Value;
            }
 
            set
            {
                _isAddingSignaturesRestricted.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the Signature ID
        /// </summary>
        internal Guid? GuidID
        {
            get
            {
                return _guidID.Value;
            }
 
            set
            {
                _guidID.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the X.509 Certificate
        /// </summary>
        internal X509Certificate2 Certificate
        {
            get
            {
                return _x509Certificate2.Value;
            }
 
            set
            {
                _x509Certificate2.Value = value;
            }
        }
 
        /// <summary>
        /// Gets or sets the XpsDigitalSignature associated with this signature.
        /// This value is expected to be left null for signature requests.
        /// </summary>
        internal XpsDigitalSignature XpsDigitalSignature
        {
            get
            {
                return _xpsDigitalSignature.Value;
            }
 
            set
            {
                _xpsDigitalSignature.Value = value;
            }
        }
 
        #endregion Internal properties
 
        #region Private data
 
        /// <summary>
        /// Status of signature (Valid, Invalid, NotSigned ...)
        /// </summary>
        private SecurityCriticalDataForSet<SignatureStatus> _signatureState;
 
        /// <summary>
        /// Friendly name of the signer (obtained from the certificate)
        /// </summary>
        private SecurityCriticalDataForSet<string> _subjectName;
 
        /// <summary>
        /// Intent:  From the Signature Definition
        /// </summary>
        private SecurityCriticalDataForSet<string> _reason;
 
        /// <summary>
        /// When this signature was applied (not a trusted time)
        /// </summary>
        private SecurityCriticalDataForSet<DateTime?> _signedOn;
 
        /// <summary>
        /// Location field (what signer type into signature definition)
        /// </summary>
        private SecurityCriticalDataForSet<string> _location;
 
        /// <summary>
        /// Whether or not document properties changes are restricted by this signature
        /// </summary>
        private SecurityCriticalDataForSet<bool> _isDocumentPropertiesRestricted;
 
        /// <summary>
        /// Whether or not adding signatures will invalidate this signature
        /// </summary>
        private SecurityCriticalDataForSet<bool> _isAddingSignaturesRestricted;
 
        /// <summary>
        /// SignatureID
        /// </summary>
        private SecurityCriticalDataForSet<Guid?> _guidID;
 
        private SecurityCriticalDataForSet<X509Certificate2> _x509Certificate2;
 
        /// <summary>
        /// The XpsDigitalSignature associated with this signature
        /// </summary>
        private SecurityCriticalDataForSet<XpsDigitalSignature> _xpsDigitalSignature;
 
        #endregion Private data
    }
}