Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / security / system / security / cryptography / x509 / x509store.cs / 1 / x509store.cs
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
//
// X509Store.cs
//
namespace System.Security.Cryptography.X509Certificates {
using System.Globalization;
using System.Runtime.InteropServices;
using System.Security.Cryptography;
using System.Security.Permissions;
public enum StoreLocation {
CurrentUser = 0x01,
LocalMachine = 0x02
}
[Flags]
// this enum defines the Open modes. Read/ReadWrite/MaxAllowed are mutually exclusive.
public enum OpenFlags {
ReadOnly = 0x00,
ReadWrite = 0x01,
MaxAllowed = 0x02,
OpenExistingOnly = 0x04,
IncludeArchived = 0x08
}
public enum StoreName {
AddressBook = 1, // other people.
AuthRoot, // third party trusted roots.
CertificateAuthority, // intermediate CAs.
Disallowed, // revoked certificates.
My, // personal certificates.
Root, // trusted root CAs.
TrustedPeople, // trusted people (used in EFS).
TrustedPublisher, // trusted publishers (used in Authenticode).
}
public sealed class X509Store {
private string m_storeName;
private StoreLocation m_location;
private SafeCertStoreHandle m_safeCertStoreHandle = SafeCertStoreHandle.InvalidHandle;
public X509Store () : this("MY", StoreLocation.CurrentUser) {}
public X509Store (string storeName) : this (storeName, StoreLocation.CurrentUser) {}
public X509Store (StoreName storeName) : this(storeName, StoreLocation.CurrentUser) {}
public X509Store (StoreLocation storeLocation) : this ("MY", storeLocation) {}
public X509Store (StoreName storeName, StoreLocation storeLocation) {
if (storeLocation != StoreLocation.CurrentUser && storeLocation != StoreLocation.LocalMachine)
throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, SR.GetString(SR.Arg_EnumIllegalVal), "storeLocation"));
switch (storeName) {
case StoreName.AddressBook:
m_storeName = "AddressBook";
break;
case StoreName.AuthRoot:
m_storeName = "AuthRoot";
break;
case StoreName.CertificateAuthority:
m_storeName = "CA";
break;
case StoreName.Disallowed:
m_storeName = "Disallowed";
break;
case StoreName.My:
m_storeName = "My";
break;
case StoreName.Root:
m_storeName = "Root";
break;
case StoreName.TrustedPeople:
m_storeName = "TrustedPeople";
break;
case StoreName.TrustedPublisher:
m_storeName = "TrustedPublisher";
break;
default:
throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, SR.GetString(SR.Arg_EnumIllegalVal), "storeName"));
}
m_location = storeLocation;
}
public X509Store (string storeName, StoreLocation storeLocation) {
if (storeLocation != StoreLocation.CurrentUser && storeLocation != StoreLocation.LocalMachine)
throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, SR.GetString(SR.Arg_EnumIllegalVal), "storeLocation"));
m_storeName = storeName;
m_location = storeLocation;
}
// Package protected constructor for creating a chain from a HCERTSTORE
[SecurityPermissionAttribute(SecurityAction.LinkDemand, Flags=SecurityPermissionFlag.UnmanagedCode)]
[SecurityPermissionAttribute(SecurityAction.InheritanceDemand, Flags=SecurityPermissionFlag.UnmanagedCode)]
public X509Store (IntPtr storeHandle) {
if (storeHandle == IntPtr.Zero)
throw new ArgumentNullException("storeHandle");
m_safeCertStoreHandle = CAPI.CertDuplicateStore(storeHandle);
if (m_safeCertStoreHandle == null || m_safeCertStoreHandle.IsInvalid)
throw new CryptographicException(SR.GetString(SR.Cryptography_InvalidStoreHandle), "storeHandle");
}
public IntPtr StoreHandle {
[SecurityPermissionAttribute(SecurityAction.LinkDemand, Flags=SecurityPermissionFlag.UnmanagedCode)]
[SecurityPermissionAttribute(SecurityAction.InheritanceDemand, Flags=SecurityPermissionFlag.UnmanagedCode)]
get {
return m_safeCertStoreHandle.DangerousGetHandle();
}
}
public StoreLocation Location {
get { return m_location; }
}
public string Name {
get { return m_storeName; }
}
public void Open(OpenFlags flags) {
if (m_location != StoreLocation.CurrentUser && m_location != StoreLocation.LocalMachine)
throw new ArgumentException(String.Format(CultureInfo.CurrentCulture, SR.GetString(SR.Arg_EnumIllegalVal), "m_location"));
uint storeFlags = X509Utils.MapX509StoreFlags(m_location, flags);
if (!m_safeCertStoreHandle.IsInvalid)
// Free the current store handle
m_safeCertStoreHandle.Dispose();
m_safeCertStoreHandle = CAPI.CertOpenStore(new IntPtr(CAPI.CERT_STORE_PROV_SYSTEM),
CAPI.X509_ASN_ENCODING | CAPI.PKCS_7_ASN_ENCODING,
IntPtr.Zero,
storeFlags,
m_storeName);
if (m_safeCertStoreHandle == null || m_safeCertStoreHandle.IsInvalid)
throw new CryptographicException(Marshal.GetLastWin32Error());
//
// We want the store to auto-resync when requesting a snapshot so that
// updates to the store will be taken into account.
//
CAPI.CertControlStore(m_safeCertStoreHandle,
0,
CAPI.CERT_STORE_CTRL_AUTO_RESYNC,
IntPtr.Zero);
}
public void Close() {
if (m_safeCertStoreHandle != null && !m_safeCertStoreHandle.IsClosed)
m_safeCertStoreHandle.Dispose();
}
public void Add(X509Certificate2 certificate) {
if (certificate == null)
throw new ArgumentNullException("certificate");
if (!CAPI.CertAddCertificateContextToStore(m_safeCertStoreHandle,
certificate.CertContext,
CAPI.CERT_STORE_ADD_REPLACE_EXISTING_INHERIT_PROPERTIES,
SafeCertContextHandle.InvalidHandle))
throw new CryptographicException(Marshal.GetLastWin32Error());
}
public void AddRange(X509Certificate2Collection certificates) {
if (certificates == null)
throw new ArgumentNullException("certificates");
int i = 0;
try {
foreach (X509Certificate2 certificate in certificates) {
Add(certificate);
i++;
}
} catch {
for (int j=0; j
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- CoTaskMemHandle.cs
- RequestTimeoutManager.cs
- CodeSnippetCompileUnit.cs
- Glyph.cs
- SoapEnvelopeProcessingElement.cs
- DataServiceHostFactory.cs
- Pointer.cs
- PageTheme.cs
- GridItemPattern.cs
- PageThemeBuildProvider.cs
- SourceFileBuildProvider.cs
- mansign.cs
- GlobalItem.cs
- GenericTypeParameterConverter.cs
- WebConvert.cs
- MarkerProperties.cs
- SplitContainerDesigner.cs
- CodeAssignStatement.cs
- OptimalBreakSession.cs
- DataGridViewRowHeightInfoPushedEventArgs.cs
- CodeTypeConstructor.cs
- SerializationInfo.cs
- OptimalTextSource.cs
- ToolStripPanelRow.cs
- Size.cs
- EnlistmentState.cs
- WindowsListBox.cs
- EventHandlerList.cs
- LineInfo.cs
- ContainerParagraph.cs
- MarginsConverter.cs
- SponsorHelper.cs
- ConstraintEnumerator.cs
- PrintDocument.cs
- AttachedPropertyBrowsableAttribute.cs
- StyleXamlTreeBuilder.cs
- Action.cs
- RequestCache.cs
- ApplicationServiceHelper.cs
- MethodCallTranslator.cs
- QilXmlReader.cs
- CommandField.cs
- ChannelSinkStacks.cs
- Model3DGroup.cs
- DataSourceControlBuilder.cs
- XmlAutoDetectWriter.cs
- TryCatch.cs
- ProfilePropertyMetadata.cs
- XomlCompilerParameters.cs
- BitStream.cs
- baseaxisquery.cs
- DBCommand.cs
- TextSpan.cs
- PartialArray.cs
- TextServicesContext.cs
- QuadraticBezierSegment.cs
- UnsafeNativeMethods.cs
- DataGridViewColumnCollection.cs
- CroppedBitmap.cs
- LinearGradientBrush.cs
- TextWriterTraceListener.cs
- IsolatedStorage.cs
- XmlQueryOutput.cs
- Button.cs
- ResourcePropertyMemberCodeDomSerializer.cs
- LinkLabelLinkClickedEvent.cs
- XmlWriterDelegator.cs
- CacheAxisQuery.cs
- BufferedGraphicsManager.cs
- NamedElement.cs
- Parser.cs
- ReachSerializableProperties.cs
- DllHostedComPlusServiceHost.cs
- HttpEncoder.cs
- WeakReference.cs
- GetMemberBinder.cs
- HttpUnhandledOperationInvoker.cs
- PropertyKey.cs
- PropertyGeneratedEventArgs.cs
- ThreadStartException.cs
- Light.cs
- TemplateApplicationHelper.cs
- QuaternionKeyFrameCollection.cs
- WebServiceMethodData.cs
- ConnectorDragDropGlyph.cs
- HtmlInputSubmit.cs
- HtmlWindow.cs
- XmlNavigatorFilter.cs
- InputLanguageManager.cs
- DataShape.cs
- PagerSettings.cs
- PeerHelpers.cs
- CaseInsensitiveComparer.cs
- LoadWorkflowByInstanceKeyCommand.cs
- ArrayConverter.cs
- ConditionalBranch.cs
- SoapIncludeAttribute.cs
- ServerReliableChannelBinder.cs
- CodeTypeReferenceExpression.cs
- nulltextnavigator.cs