You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			166 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			166 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | using System; | ||
|  | using System.Collections.Generic; | ||
|  | using System.IO; | ||
|  | using System.Security; | ||
|  | using System.Security.Cryptography; | ||
|  | 
 | ||
|  | using Mono.Security.Cryptography; | ||
|  | using Mono.Xml; | ||
|  | 
 | ||
|  | namespace Mono.Configuration.Crypto | ||
|  | { | ||
|  | 	public class Key | ||
|  | 	{ | ||
|  | 		static readonly char[] splitChars = {']'}; | ||
|  | 		 | ||
|  | 		string file; | ||
|  | 		KeyPairPersistence keypair; | ||
|  | 		bool machineStore; | ||
|  | 		uint keySize; | ||
|  | 
 | ||
|  | 		public bool IsValid { | ||
|  | 			get; | ||
|  | 			private set; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		public string KeyValue { | ||
|  | 			get; | ||
|  | 			set; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		public bool Local { | ||
|  | 			get { return !machineStore; } | ||
|  | 		} | ||
|  | 		 | ||
|  | 		public string ContainerName { | ||
|  | 			get; | ||
|  | 			set; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		public int ProviderType { | ||
|  | 			get; | ||
|  | 			set; | ||
|  | 		} | ||
|  | 		 | ||
|  | 		public Key (string file, bool machineStore) | ||
|  | 		{ | ||
|  | 			if (String.IsNullOrEmpty (file)) | ||
|  | 				throw new ArgumentNullException ("file"); | ||
|  | 			 | ||
|  | 			this.file = file; | ||
|  | 			this.machineStore = machineStore; | ||
|  | 			this.keySize = 0; | ||
|  | 			ReadFile (); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		public Key (string containerName, string keyValue, bool machineStore) | ||
|  | 		{ | ||
|  | 			if (String.IsNullOrEmpty (containerName)) | ||
|  | 				throw new ArgumentNullException ("containerName"); | ||
|  | 
 | ||
|  | 			if (String.IsNullOrEmpty (keyValue)) | ||
|  | 				throw new ArgumentNullException ("keyValue"); | ||
|  | 
 | ||
|  | 			this.file = null; | ||
|  | 			this.machineStore = machineStore; | ||
|  | 			this.keySize = 0; | ||
|  | 			this.KeyValue = keyValue; | ||
|  | 			this.IsValid = true; | ||
|  | 
 | ||
|  | 			if (keyValue.StartsWith ("RSAKeyValue", StringComparison.Ordinal)) | ||
|  | 				this.ProviderType = 1; | ||
|  | 			else if (keyValue.StartsWith ("DSAKeyValue", StringComparison.Ordinal)) | ||
|  | 				this.ProviderType = 13; | ||
|  | 			else | ||
|  | 				this.ProviderType = -1; | ||
|  | 		} | ||
|  | 		 | ||
|  | 		public Key (string containerName, uint keySize, bool machineStore) | ||
|  | 		{ | ||
|  | 			if (String.IsNullOrEmpty (containerName)) | ||
|  | 				throw new ArgumentNullException ("containerName"); | ||
|  | 
 | ||
|  | 			this.ContainerName = containerName; | ||
|  | 			this.machineStore = machineStore; | ||
|  | 			this.keySize = keySize; | ||
|  | 			this.ProviderType = 1; | ||
|  | 			 | ||
|  | 			GenerateKeyPair (); | ||
|  | 		} | ||
|  | 		 | ||
|  | 		public void Save () | ||
|  | 		{ | ||
|  | 			var csp = new CspParameters (1); | ||
|  | 			if (machineStore) | ||
|  | 				csp.Flags |= CspProviderFlags.UseMachineKeyStore; | ||
|  | 			csp.ProviderName = String.Empty; | ||
|  | 			csp.KeyContainerName = ContainerName; | ||
|  | 			 | ||
|  | 			var kpp = new KeyPairPersistence (csp, KeyValue); | ||
|  | 			kpp.Save (); | ||
|  | 		} | ||
|  | 		 | ||
|  | 		void GenerateKeyPair () | ||
|  | 		{ | ||
|  | 			var rsa = new RSAManaged ((int)keySize); | ||
|  | 			KeyValue = rsa.ToXmlString (true); | ||
|  | 			IsValid = true; | ||
|  | 		} | ||
|  | 		 | ||
|  | 		void ReadFile () | ||
|  | 		{ | ||
|  | 			var sp = new SecurityParser (); | ||
|  | 			sp.LoadXml (File.ReadAllText (file)); | ||
|  | 
 | ||
|  | 			SecurityElement root = sp.ToXml (); | ||
|  | 			if (root.Tag == "KeyPair") { | ||
|  | 				SecurityElement keyvalue = root.SearchForChildByTag ("KeyValue"); | ||
|  | 				if (keyvalue.Children.Count == 0) | ||
|  | 					return; | ||
|  | 				 | ||
|  | 				KeyValue = keyvalue.Children [0].ToString (); | ||
|  | 
 | ||
|  | 				SecurityElement properties = root.SearchForChildByTag ("Properties"); | ||
|  | 				if (properties.Children.Count == 0) | ||
|  | 					return; | ||
|  | 
 | ||
|  | 				SecurityElement property; | ||
|  | 				string containerName = null, attribute; | ||
|  | 				int providerType = -1; | ||
|  | 				 | ||
|  | 				foreach (object o in properties.Children) { | ||
|  | 					property = o as SecurityElement; | ||
|  | 					if (property == null) | ||
|  | 						continue; | ||
|  | 
 | ||
|  | 					switch (property.Tag) { | ||
|  | 						case "Provider": | ||
|  | 							attribute = property.Attribute ("Type"); | ||
|  | 							if (String.IsNullOrEmpty (attribute)) | ||
|  | 								return; | ||
|  | 
 | ||
|  | 							if (!Int32.TryParse (attribute, out providerType)) | ||
|  | 								return; | ||
|  | 							break; | ||
|  | 
 | ||
|  | 						case "Container": | ||
|  | 							attribute = property.Attribute ("Name"); | ||
|  | 							if (String.IsNullOrEmpty (attribute)) | ||
|  | 								return; | ||
|  | 
 | ||
|  | 							containerName = attribute; | ||
|  | 							break; | ||
|  | 					} | ||
|  | 				} | ||
|  | 
 | ||
|  | 				if (String.IsNullOrEmpty (containerName) || providerType == -1) | ||
|  | 					return; | ||
|  | 
 | ||
|  | 				ContainerName = containerName; | ||
|  | 				ProviderType = providerType; | ||
|  | 				IsValid = true; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | } |