// // X509StoreManager.cs: X.509 store manager. // // Author: // Sebastien Pouliot // // (C) 2004 Novell (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; using System.Collections; using System.IO; using Mono.Security.X509.Extensions; namespace Mono.Security.X509 { #if INSIDE_CORLIB || INSIDE_SYSTEM internal #else public #endif sealed class X509StoreManager { static private string _userPath; static private string _localMachinePath; static private string _newUserPath; static private string _newLocalMachinePath; static private X509Stores _userStore; static private X509Stores _machineStore; static private X509Stores _newUserStore; static private X509Stores _newMachineStore; private X509StoreManager () { } internal static string CurrentUserPath { get { if (_userPath == null) { _userPath = Path.Combine ( Environment.GetFolderPath (Environment.SpecialFolder.ApplicationData), ".mono"); _userPath = Path.Combine (_userPath, "certs"); } return _userPath; } } internal static string LocalMachinePath { get { if (_localMachinePath == null) { _localMachinePath = Path.Combine ( Environment.GetFolderPath (Environment.SpecialFolder.CommonApplicationData), ".mono"); _localMachinePath = Path.Combine (_localMachinePath, "certs"); } return _localMachinePath; } } internal static string NewCurrentUserPath { get { if (_newUserPath == null) { _newUserPath = Path.Combine ( Environment.GetFolderPath (Environment.SpecialFolder.ApplicationData), ".mono"); _newUserPath = Path.Combine (_newUserPath, "new-certs"); } return _newUserPath; } } internal static string NewLocalMachinePath { get { if (_newLocalMachinePath == null) { _newLocalMachinePath = Path.Combine ( Environment.GetFolderPath (Environment.SpecialFolder.CommonApplicationData), ".mono"); _newLocalMachinePath = Path.Combine (_newLocalMachinePath, "new-certs"); } return _newLocalMachinePath; } } static public X509Stores CurrentUser { get { if (_userStore == null) _userStore = new X509Stores (CurrentUserPath, false); return _userStore; } } static public X509Stores LocalMachine { get { if (_machineStore == null) _machineStore = new X509Stores (LocalMachinePath, false); return _machineStore; } } static public X509Stores NewCurrentUser { get { if (_newUserStore == null) _newUserStore = new X509Stores (NewCurrentUserPath, true); return _newUserStore; } } static public X509Stores NewLocalMachine { get { if (_newMachineStore == null) _newMachineStore = new X509Stores (NewLocalMachinePath, true); return _newMachineStore; } } // Merged stores collections // we need to look at both the user and the machine (entreprise) // certificates/CRLs when building/validating a chain static public X509CertificateCollection IntermediateCACertificates { get { X509CertificateCollection intermediateCerts = new X509CertificateCollection (); intermediateCerts.AddRange (CurrentUser.IntermediateCA.Certificates); intermediateCerts.AddRange (LocalMachine.IntermediateCA.Certificates); return intermediateCerts; } } static public ArrayList IntermediateCACrls { get { ArrayList intermediateCRLs = new ArrayList (); intermediateCRLs.AddRange (CurrentUser.IntermediateCA.Crls); intermediateCRLs.AddRange (LocalMachine.IntermediateCA.Crls); return intermediateCRLs; } } static public X509CertificateCollection TrustedRootCertificates { get { X509CertificateCollection trustedCerts = new X509CertificateCollection (); trustedCerts.AddRange (CurrentUser.TrustedRoot.Certificates); trustedCerts.AddRange (LocalMachine.TrustedRoot.Certificates); return trustedCerts; } } static public ArrayList TrustedRootCACrls { get { ArrayList trustedCRLs = new ArrayList (); trustedCRLs.AddRange (CurrentUser.TrustedRoot.Crls); trustedCRLs.AddRange (LocalMachine.TrustedRoot.Crls); return trustedCRLs; } } static public X509CertificateCollection UntrustedCertificates { get { X509CertificateCollection untrustedCerts = new X509CertificateCollection (); untrustedCerts.AddRange (CurrentUser.Untrusted.Certificates); untrustedCerts.AddRange (LocalMachine.Untrusted.Certificates); return untrustedCerts; } } } }