mirror of
				https://github.com/openpgpjs/openpgpjs.git
				synced 2025-10-14 00:59:29 +00:00 
			
		
		
		
	 23295342fc
			
		
	
	
		23295342fc
		
	
	
	
	
		
			
			work correctly with utf8 strings. Fixeda visibility issue with the testing suite and added relevant unit tests.
		
			
				
	
	
		
			511 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			511 lines
		
	
	
		
			26 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="en">
 | |
| <head>
 | |
|     <meta charset="utf-8">
 | |
|     <title>JSDoc: Source: openpgp.js</title>
 | |
|     
 | |
|     <script src="scripts/prettify/prettify.js"> </script>
 | |
|     <script src="scripts/prettify/lang-css.js"> </script>
 | |
|     <!--[if lt IE 9]>
 | |
|       <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
 | |
|     <![endif]-->
 | |
|     <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
 | |
|     <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
 | |
| </head>
 | |
| 
 | |
| <body>
 | |
| 
 | |
| <div id="main">
 | |
|     
 | |
|     <h1 class="page-title">Source: openpgp.js</h1>
 | |
|     
 | |
|     
 | |
| 
 | |
| 
 | |
|     
 | |
|     <section>
 | |
|         <article>
 | |
|             <pre class="prettyprint source"><code>// GPG4Browsers - An OpenPGP implementation in javascript
 | |
| // Copyright (C) 2011 Recurity Labs GmbH
 | |
| // 
 | |
| // This library is free software; you can redistribute it and/or
 | |
| // modify it under the terms of the GNU Lesser General Public
 | |
| // License as published by the Free Software Foundation; either
 | |
| // version 2.1 of the License, or (at your option) any later version.
 | |
| // 
 | |
| // This library is distributed in the hope that it will be useful,
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| // Lesser General Public License for more details.
 | |
| // 
 | |
| // You should have received a copy of the GNU Lesser General Public
 | |
| // License along with this library; if not, write to the Free Software
 | |
| // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | |
| 
 | |
| /**
 | |
|  * @fileoverview The openpgp base class should provide all of the functionality 
 | |
|  * to consume the openpgp.js library. All additional classes are documented 
 | |
|  * for extending and developing on top of the base library.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * GPG4Browsers Core interface. A single instance is hold
 | |
|  * from the beginning. To use this library call "openpgp.init()"
 | |
|  * @alias openpgp
 | |
|  * @class
 | |
|  * @classdesc Main Openpgp.js class. Use this to initiate and make all calls to this library.
 | |
|  */
 | |
| function _openpgp () {
 | |
| 	this.tostring = "";
 | |
| 	
 | |
| 	/**
 | |
| 	 * initializes the library:
 | |
| 	 * - reading the keyring from local storage
 | |
| 	 * - reading the config from local storage
 | |
| 	 */
 | |
| 	function init() {
 | |
| 		this.config = new openpgp_config();
 | |
| 		this.config.read();
 | |
| 		this.keyring = new openpgp_keyring();
 | |
| 		this.keyring.init();
 | |
| 	}
 | |
| 	
 | |
| 	/**
 | |
| 	 * reads several publicKey objects from a ascii armored
 | |
| 	 * representation an returns openpgp_msg_publickey packets
 | |
| 	 * @param {String} armoredText OpenPGP armored text containing
 | |
| 	 * the public key(s)
 | |
| 	 * @return {openpgp_msg_publickey[]} on error the function
 | |
| 	 * returns null
 | |
| 	 */
 | |
| 	function read_publicKey(armoredText) {
 | |
| 		var mypos = 0;
 | |
| 		var publicKeys = new Array();
 | |
| 		var publicKeyCount = 0;
 | |
| 		var input = openpgp_encoding_deArmor(armoredText.replace(/\r/g,'')).openpgp;
 | |
| 		var l = input.length;
 | |
| 		while (mypos != input.length) {
 | |
| 			var first_packet = openpgp_packet.read_packet(input, mypos, l);
 | |
| 			// public key parser
 | |
| 			if (input[mypos].charCodeAt() == 0x99 || first_packet.tagType == 6) {
 | |
| 				publicKeys[publicKeyCount] = new openpgp_msg_publickey();				
 | |
| 				publicKeys[publicKeyCount].header = input.substring(mypos,mypos+3);
 | |
| 				if (input[mypos].charCodeAt() == 0x99) {
 | |
| 					// parse the length and read a tag6 packet
 | |
| 					mypos++;
 | |
| 					var l = (input[mypos++].charCodeAt() << 8)
 | |
| 							| input[mypos++].charCodeAt();
 | |
| 					publicKeys[publicKeyCount].publicKeyPacket = new openpgp_packet_keymaterial();
 | |
| 					publicKeys[publicKeyCount].publicKeyPacket.header = publicKeys[publicKeyCount].header;
 | |
| 					publicKeys[publicKeyCount].publicKeyPacket.read_tag6(input, mypos, l);
 | |
| 					mypos += publicKeys[publicKeyCount].publicKeyPacket.packetLength;
 | |
| 					mypos += publicKeys[publicKeyCount].read_nodes(publicKeys[publicKeyCount].publicKeyPacket, input, mypos, (input.length - mypos));
 | |
| 				} else {
 | |
| 					publicKeys[publicKeyCount] = new openpgp_msg_publickey();
 | |
| 					publicKeys[publicKeyCount].publicKeyPacket = first_packet;
 | |
| 					mypos += first_packet.headerLength+first_packet.packetLength;
 | |
| 					mypos += publicKeys[publicKeyCount].read_nodes(first_packet, input, mypos, input.length -mypos);
 | |
| 				}
 | |
| 			} else {
 | |
| 				util.print_error("no public key found!");
 | |
| 				return null;
 | |
| 			}
 | |
| 			publicKeys[publicKeyCount].data = input.substring(0,mypos);
 | |
| 			publicKeyCount++;
 | |
| 		}
 | |
| 		return publicKeys;
 | |
| 	}
 | |
| 	
 | |
| 	/**
 | |
| 	 * reads several privateKey objects from a ascii armored
 | |
| 	 * representation an returns openpgp_msg_privatekey objects
 | |
| 	 * @param {String} armoredText OpenPGP armored text containing
 | |
| 	 * the private key(s)
 | |
| 	 * @return {openpgp_msg_privatekey[]} on error the function
 | |
| 	 * returns null
 | |
| 	 */
 | |
| 	function read_privateKey(armoredText) {
 | |
| 		var privateKeys = new Array();
 | |
| 		var privateKeyCount = 0;
 | |
| 		var mypos = 0;
 | |
| 		var input = openpgp_encoding_deArmor(armoredText.replace(/\r/g,'')).openpgp;
 | |
| 		var l = input.length;
 | |
| 		while (mypos != input.length) {
 | |
| 			var first_packet = openpgp_packet.read_packet(input, mypos, l);
 | |
| 			if (first_packet.tagType == 5) {
 | |
| 				privateKeys[privateKeys.length] = new openpgp_msg_privatekey();
 | |
| 				mypos += first_packet.headerLength+first_packet.packetLength;
 | |
| 				mypos += privateKeys[privateKeyCount].read_nodes(first_packet, input, mypos, l);
 | |
| 			// other blocks	            
 | |
| 			} else {
 | |
| 				util.print_error('no block packet found!');
 | |
| 				return null;
 | |
| 			}
 | |
| 			privateKeys[privateKeyCount].data = input.substring(0,mypos);
 | |
| 			privateKeyCount++;
 | |
| 		}
 | |
| 		return privateKeys;		
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * reads message packets out of an OpenPGP armored text and
 | |
| 	 * returns an array of message objects
 | |
| 	 * @param {String} armoredText text to be parsed
 | |
| 	 * @return {openpgp_msg_message[]} on error the function
 | |
| 	 * returns null
 | |
| 	 */
 | |
| 	function read_message(armoredText) {
 | |
| 		var dearmored;
 | |
| 		try{
 | |
|     		dearmored = openpgp_encoding_deArmor(armoredText.replace(/\r/g,''));
 | |
| 		}
 | |
| 		catch(e){
 | |
|     		util.print_error('no message found!');
 | |
|     		return null;
 | |
| 		}
 | |
| 		return read_messages_dearmored(dearmored);
 | |
| 		}
 | |
| 		
 | |
| 	/**
 | |
| 	 * reads message packets out of an OpenPGP armored text and
 | |
| 	 * returns an array of message objects. Can be called externally or internally.
 | |
| 	 * External call will parse a de-armored messaged and return messages found.
 | |
| 	 * Internal will be called to read packets wrapped in other packets (i.e. compressed)
 | |
| 	 * @param {String} input dearmored text of OpenPGP packets, to be parsed
 | |
| 	 * @return {openpgp_msg_message[]} on error the function
 | |
| 	 * returns null
 | |
| 	 */
 | |
| 	function read_messages_dearmored(input){
 | |
| 		var messageString = input.openpgp;
 | |
| 		var signatureText = input.text; //text to verify signatures against. Modified by Tag11.
 | |
| 		var messages = new Array();
 | |
| 		var messageCount = 0;
 | |
| 		var mypos = 0;
 | |
| 		var l = messageString.length;
 | |
| 		while (mypos < messageString.length) {
 | |
| 			var first_packet = openpgp_packet.read_packet(messageString, mypos, l);
 | |
| 			if (!first_packet) {
 | |
| 				break;
 | |
| 			}
 | |
| 			// public key parser (definition from the standard:)
 | |
| 			// OpenPGP Message      :- Encrypted Message | Signed Message |
 | |
| 			//                         Compressed Message | Literal Message.
 | |
| 			// Compressed Message   :- Compressed Data Packet.
 | |
| 			// 
 | |
| 			// Literal Message      :- Literal Data Packet.
 | |
| 			// 
 | |
| 			// ESK                  :- Public-Key Encrypted Session Key Packet |
 | |
| 			//                         Symmetric-Key Encrypted Session Key Packet.
 | |
| 			// 
 | |
| 			// ESK Sequence         :- ESK | ESK Sequence, ESK.
 | |
| 			// 
 | |
| 			// Encrypted Data       :- Symmetrically Encrypted Data Packet |
 | |
| 			//                         Symmetrically Encrypted Integrity Protected Data Packet
 | |
| 			// 
 | |
| 			// Encrypted Message    :- Encrypted Data | ESK Sequence, Encrypted Data.
 | |
| 			// 
 | |
| 			// One-Pass Signed Message :- One-Pass Signature Packet,
 | |
| 			//                         OpenPGP Message, Corresponding Signature Packet.
 | |
| 
 | |
| 			// Signed Message       :- Signature Packet, OpenPGP Message |
 | |
| 			//                         One-Pass Signed Message.
 | |
| 			if (first_packet.tagType ==  1 ||
 | |
| 			    (first_packet.tagType == 2 && first_packet.signatureType < 16) ||
 | |
| 			     first_packet.tagType ==  3 ||
 | |
| 			     first_packet.tagType ==  4 ||
 | |
| 				 first_packet.tagType ==  8 ||
 | |
| 				 first_packet.tagType ==  9 ||
 | |
| 				 first_packet.tagType == 10 ||
 | |
| 				 first_packet.tagType == 11 ||
 | |
| 				 first_packet.tagType == 18 ||
 | |
| 				 first_packet.tagType == 19) {
 | |
| 				messages[messages.length] = new openpgp_msg_message();
 | |
| 				messages[messageCount].messagePacket = first_packet;
 | |
| 				messages[messageCount].type = input.type;
 | |
| 				// Encrypted Message
 | |
| 				if (first_packet.tagType == 9 ||
 | |
| 				    first_packet.tagType == 1 ||
 | |
| 				    first_packet.tagType == 3 ||
 | |
| 				    first_packet.tagType == 18) {
 | |
| 					if (first_packet.tagType == 9) {
 | |
| 						util.print_error("unexpected openpgp packet");
 | |
| 						break;
 | |
| 					} else if (first_packet.tagType == 1) {
 | |
| 						util.print_debug("session key found:\n "+first_packet.toString());
 | |
| 						var issessionkey = true;
 | |
| 						messages[messageCount].sessionKeys = new Array();
 | |
| 						var sessionKeyCount = 0;
 | |
| 						while (issessionkey) {
 | |
| 							messages[messageCount].sessionKeys[sessionKeyCount] = first_packet;
 | |
| 							mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 							l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 							first_packet = openpgp_packet.read_packet(messageString, mypos, l);
 | |
| 							
 | |
| 							if (first_packet.tagType != 1 && first_packet.tagType != 3)
 | |
| 								issessionkey = false;
 | |
| 							sessionKeyCount++;
 | |
| 						}
 | |
| 						if (first_packet.tagType == 18 || first_packet.tagType == 9) {
 | |
| 							util.print_debug("encrypted data found:\n "+first_packet.toString());
 | |
| 							messages[messageCount].encryptedData = first_packet;
 | |
| 							mypos += first_packet.packetLength+first_packet.headerLength;
 | |
| 							l -= (first_packet.packetLength+first_packet.headerLength);
 | |
| 							messageCount++;
 | |
| 							
 | |
| 						} else {
 | |
| 							util.print_debug("something is wrong: "+first_packet.tagType);
 | |
| 						}
 | |
| 						
 | |
| 					} else if (first_packet.tagType == 18) {
 | |
| 						util.print_debug("symmetric encrypted data");
 | |
| 						break;
 | |
| 					}
 | |
| 				} else 
 | |
| 					if (first_packet.tagType == 2 && first_packet.signatureType < 3) {
 | |
| 					// Signed Message
 | |
| 						mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 						l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 						messages[messageCount].text = signatureText;
 | |
| 						messages[messageCount].signature = first_packet;
 | |
| 				        messageCount++;
 | |
| 				} else 
 | |
| 					// Signed Message
 | |
| 					if (first_packet.tagType == 4) {
 | |
| 						//TODO: Implement check
 | |
| 						mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 						l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 				} else 
 | |
| 					if (first_packet.tagType == 8) {
 | |
| 					// Compressed Message
 | |
| 						mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 						l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 				        var decompressedText = first_packet.decompress();
 | |
| 				        messages = messages.concat(openpgp.read_messages_dearmored({text: decompressedText, openpgp: decompressedText}));
 | |
| 				} else
 | |
| 					// Marker Packet (Obsolete Literal Packet) (Tag 10)
 | |
| 					// "Such a packet MUST be ignored when received." see http://tools.ietf.org/html/rfc4880#section-5.8
 | |
| 					if (first_packet.tagType == 10) {
 | |
| 						// reset messages
 | |
| 						messages.length = 0;
 | |
| 						// continue with next packet
 | |
| 						mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 						l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 				} else 
 | |
| 					if (first_packet.tagType == 11) {
 | |
| 					// Literal Message -- work is already done in read_packet
 | |
| 					mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 					l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 					signatureText = first_packet.data;
 | |
| 					messages[messageCount].data = first_packet.data;
 | |
| 					messageCount++;
 | |
| 				} else 
 | |
| 					if (first_packet.tagType == 19) {
 | |
| 					// Modification Detect Code
 | |
| 						mypos += first_packet.packetLength + first_packet.headerLength;
 | |
| 						l -= (first_packet.packetLength + first_packet.headerLength);
 | |
| 				}
 | |
| 			} else {
 | |
| 				util.print_error('no message found!');
 | |
| 				return null;
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		return messages;
 | |
| 	}
 | |
| 	
 | |
| 	/**
 | |
| 	 * creates a binary string representation of an encrypted and signed message.
 | |
| 	 * The message will be encrypted with the public keys specified and signed
 | |
| 	 * with the specified private key.
 | |
| 	 * @param {Object} privatekey {obj: [openpgp_msg_privatekey]} Private key 
 | |
| 	 * to be used to sign the message
 | |
| 	 * @param {Object[]} publickeys An arraf of {obj: [openpgp_msg_publickey]}
 | |
| 	 * - public keys to be used to encrypt the message 
 | |
| 	 * @param {String} messagetext message text to encrypt and sign
 | |
| 	 * @return {String} a binary string representation of the message which 
 | |
| 	 * can be OpenPGP armored
 | |
| 	 */
 | |
| 	function write_signed_and_encrypted_message(privatekey, publickeys, messagetext) {
 | |
| 		var result = "";
 | |
| 		var literal = new openpgp_packet_literaldata().write_packet(messagetext.replace(/\r\n/g,"\n").replace(/\n/g,"\r\n"));
 | |
| 		util.print_debug_hexstr_dump("literal_packet: |"+literal+"|\n",literal);
 | |
| 		for (var i = 0; i < publickeys.length; i++) {
 | |
| 			var onepasssignature = new openpgp_packet_onepasssignature();
 | |
| 			var onepasssigstr = "";
 | |
| 			if (i == 0)
 | |
| 				onepasssigstr = onepasssignature.write_packet(1, openpgp.config.config.prefer_hash_algorithm,  privatekey, false);
 | |
| 			else
 | |
| 				onepasssigstr = onepasssignature.write_packet(1, openpgp.config.config.prefer_hash_algorithm,  privatekey, false);
 | |
| 			util.print_debug_hexstr_dump("onepasssigstr: |"+onepasssigstr+"|\n",onepasssigstr);
 | |
| 			var datasignature = new openpgp_packet_signature().write_message_signature(1, messagetext.replace(/\r\n/g,"\n").replace(/\n/g,"\r\n"), privatekey);
 | |
| 			util.print_debug_hexstr_dump("datasignature: |"+datasignature.openpgp+"|\n",datasignature.openpgp);
 | |
| 			if (i == 0) {
 | |
| 				result = onepasssigstr+literal+datasignature.openpgp;
 | |
| 			} else {
 | |
| 				result = onepasssigstr+result+datasignature.openpgp;
 | |
| 			}
 | |
| 		}
 | |
| 		
 | |
| 		util.print_debug_hexstr_dump("signed packet: |"+result+"|\n",result);
 | |
| 		// signatures done.. now encryption
 | |
| 		var sessionkey = openpgp_crypto_generateSessionKey(openpgp.config.config.encryption_cipher); 
 | |
| 		var result2 = "";
 | |
| 		
 | |
| 		// creating session keys for each recipient
 | |
| 		for (var i = 0; i < publickeys.length; i++) {
 | |
| 			var pkey = publickeys[i].getEncryptionKey();
 | |
| 			if (pkey == null) {
 | |
| 				util.print_error("no encryption key found! Key is for signing only.");
 | |
| 				return null;
 | |
| 			}
 | |
| 			result2 += new openpgp_packet_encryptedsessionkey().
 | |
| 					write_pub_key_packet(
 | |
| 						pkey.getKeyId(),
 | |
| 						pkey.MPIs,
 | |
| 						pkey.publicKeyAlgorithm,
 | |
| 						openpgp.config.config.encryption_cipher,
 | |
| 						sessionkey);
 | |
| 		}
 | |
| 		if (openpgp.config.config.integrity_protect) {
 | |
| 			result2 += new openpgp_packet_encryptedintegrityprotecteddata().write_packet(openpgp.config.config.encryption_cipher, sessionkey, result);
 | |
| 		} else {
 | |
| 			result2 += new openpgp_packet_encrypteddata().write_packet(openpgp.config.config.encryption_cipher, sessionkey, result);
 | |
| 		}
 | |
| 		return openpgp_encoding_armor(3,result2,null,null);
 | |
| 	}
 | |
| 	/**
 | |
| 	 * creates a binary string representation of an encrypted message.
 | |
| 	 * The message will be encrypted with the public keys specified 
 | |
| 	 * @param {Object[]} publickeys An array of {obj: [openpgp_msg_publickey]}
 | |
| 	 * -public keys to be used to encrypt the message 
 | |
| 	 * @param {String} messagetext message text to encrypt
 | |
| 	 * @return {String} a binary string representation of the message
 | |
| 	 * which can be OpenPGP armored
 | |
| 	 */
 | |
| 	function write_encrypted_message(publickeys, messagetext) {
 | |
| 		var result = "";
 | |
| 		var literal = new openpgp_packet_literaldata().write_packet(messagetext.replace(/\r\n/g,"\n").replace(/\n/g,"\r\n"));
 | |
| 		util.print_debug_hexstr_dump("literal_packet: |"+literal+"|\n",literal);
 | |
| 		result = literal;
 | |
| 		
 | |
| 		// signatures done.. now encryption
 | |
| 		var sessionkey = openpgp_crypto_generateSessionKey(openpgp.config.config.encryption_cipher); 
 | |
| 		var result2 = "";
 | |
| 		
 | |
| 		// creating session keys for each recipient
 | |
| 		for (var i = 0; i < publickeys.length; i++) {
 | |
| 			var pkey = publickeys[i].getEncryptionKey();
 | |
| 			if (pkey == null) {
 | |
| 				util.print_error("no encryption key found! Key is for signing only.");
 | |
| 				return null;
 | |
| 			}
 | |
| 			result2 += new openpgp_packet_encryptedsessionkey().
 | |
| 					write_pub_key_packet(
 | |
| 						pkey.getKeyId(),
 | |
| 						pkey.MPIs,
 | |
| 						pkey.publicKeyAlgorithm,
 | |
| 						openpgp.config.config.encryption_cipher,
 | |
| 						sessionkey);
 | |
| 		}
 | |
| 		if (openpgp.config.config.integrity_protect) {
 | |
| 			result2 += new openpgp_packet_encryptedintegrityprotecteddata().write_packet(openpgp.config.config.encryption_cipher, sessionkey, result);
 | |
| 		} else {
 | |
| 			result2 += new openpgp_packet_encrypteddata().write_packet(openpgp.config.config.encryption_cipher, sessionkey, result);
 | |
| 		}
 | |
| 		return openpgp_encoding_armor(3,result2,null,null);
 | |
| 	}
 | |
| 	
 | |
| 	/**
 | |
| 	 * creates a binary string representation a signed message.
 | |
| 	 * The message will be signed with the specified private key.
 | |
| 	 * @param {Object} privatekey {obj: [openpgp_msg_privatekey]}
 | |
| 	 * - the private key to be used to sign the message 
 | |
| 	 * @param {String} messagetext message text to sign
 | |
| 	 * @return {Object} {Object: text [String]}, openpgp: {String} a binary
 | |
| 	 *  string representation of the message which can be OpenPGP
 | |
| 	 *   armored(openpgp) and a text representation of the message (text). 
 | |
| 	 * This can be directly used to OpenPGP armor the message
 | |
| 	 */
 | |
| 	function write_signed_message(privatekey, messagetext) {
 | |
| 		var sig = new openpgp_packet_signature().write_message_signature(1, messagetext.replace(/\r\n/g,"\n").replace(/\n/,"\r\n"), privatekey);
 | |
| 		var result = {text: messagetext.replace(/\r\n/g,"\n").replace(/\n/,"\r\n"), openpgp: sig.openpgp, hash: sig.hash};
 | |
| 		return openpgp_encoding_armor(2,result, null, null)
 | |
| 	}
 | |
| 	
 | |
| 	/**
 | |
| 	 * generates a new key pair for openpgp. Beta stage. Currently only 
 | |
| 	 * supports RSA keys, and no subkeys.
 | |
| 	 * @param {Integer} keyType to indicate what type of key to make. 
 | |
| 	 * RSA is 1. Follows algorithms outlined in OpenPGP.
 | |
| 	 * @param {Integer} numBits number of bits for the key creation. (should 
 | |
| 	 * be 1024+, generally)
 | |
| 	 * @param {String} userId assumes already in form of "User Name 
 | |
| 	 * <username@email.com>"
 | |
| 	 * @param {String} passphrase The passphrase used to encrypt the resulting private key
 | |
| 	 * @return {Object} {privateKey: [openpgp_msg_privatekey], 
 | |
| 	 * privateKeyArmored: [string], publicKeyArmored: [string]}
 | |
| 	 */
 | |
| 	function generate_key_pair(keyType, numBits, userId, passphrase){
 | |
| 		var userIdPacket = new openpgp_packet_userid();
 | |
| 		var userIdString = userIdPacket.write_packet(userId);
 | |
| 		
 | |
| 		var keyPair = openpgp_crypto_generateKeyPair(keyType,numBits, passphrase, openpgp.config.config.prefer_hash_algorithm, 3);
 | |
| 		var privKeyString = keyPair.privateKey;
 | |
| 		var privKeyPacket = new openpgp_packet_keymaterial().read_priv_key(privKeyString.string,3,privKeyString.string.length);
 | |
| 		if(!privKeyPacket.decryptSecretMPIs(passphrase))
 | |
| 		    util.print_error('Issue creating key. Unable to read resulting private key');
 | |
| 		var privKey = new openpgp_msg_privatekey();
 | |
| 		privKey.privateKeyPacket = privKeyPacket;
 | |
| 		privKey.getPreferredSignatureHashAlgorithm = function(){return openpgp.config.config.prefer_hash_algorithm};//need to override this to solve catch 22 to generate signature. 8 is value for SHA256
 | |
| 		
 | |
| 		var publicKeyString = privKey.privateKeyPacket.publicKey.data;
 | |
| 		var hashData = String.fromCharCode(0x99)+ String.fromCharCode(((publicKeyString.length) >> 8) & 0xFF) 
 | |
| 			+ String.fromCharCode((publicKeyString.length) & 0xFF) +publicKeyString+String.fromCharCode(0xB4) +
 | |
| 			String.fromCharCode((userId.length) >> 24) +String.fromCharCode(((userId.length) >> 16) & 0xFF) 
 | |
| 			+ String.fromCharCode(((userId.length) >> 8) & 0xFF) + String.fromCharCode((userId.length) & 0xFF) + userId
 | |
| 		var signature = new openpgp_packet_signature();
 | |
| 		signature = signature.write_message_signature(16,hashData, privKey);
 | |
| 		var publicArmored = openpgp_encoding_armor(4, keyPair.publicKey.string + userIdString + signature.openpgp );
 | |
| 
 | |
| 		var privArmored = openpgp_encoding_armor(5,privKeyString.string+userIdString+signature.openpgp);
 | |
| 		
 | |
| 		return {privateKey : privKey, privateKeyArmored: privArmored, publicKeyArmored: publicArmored}
 | |
| 	}
 | |
| 	
 | |
| 	this.generate_key_pair = generate_key_pair;
 | |
| 	this.write_signed_message = write_signed_message; 
 | |
| 	this.write_signed_and_encrypted_message = write_signed_and_encrypted_message;
 | |
| 	this.write_encrypted_message = write_encrypted_message;
 | |
| 	this.read_message = read_message;
 | |
| 	this.read_messages_dearmored = read_messages_dearmored;
 | |
| 	this.read_publicKey = read_publicKey;
 | |
| 	this.read_privateKey = read_privateKey;
 | |
| 	this.init = init;
 | |
| }
 | |
| 
 | |
| var openpgp = new _openpgp();
 | |
| 
 | |
| 
 | |
| </code></pre>
 | |
|         </article>
 | |
|     </section>
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| </div>
 | |
| 
 | |
| <nav>
 | |
|     <h2><a href="index.html">Index</a></h2><h3>Classes</h3><ul><li><a href="_openpgp_packet.html">_openpgp_packet</a></li><li><a href="JXG.Util.html">Util</a></li><li><a href="openpgp.html">openpgp</a></li><li><a href="openpgp_config.html">openpgp_config</a></li><li><a href="openpgp_keyring.html">openpgp_keyring</a></li><li><a href="openpgp_msg_message.html">openpgp_msg_message</a></li><li><a href="openpgp_msg_privatekey.html">openpgp_msg_privatekey</a></li><li><a href="openpgp_msg_publickey.html">openpgp_msg_publickey</a></li><li><a href="openpgp_packet_compressed.html">openpgp_packet_compressed</a></li><li><a href="openpgp_packet_encrypteddata.html">openpgp_packet_encrypteddata</a></li><li><a href="openpgp_packet_encryptedintegrityprotecteddata.html">openpgp_packet_encryptedintegrityprotecteddata</a></li><li><a href="openpgp_packet_encryptedsessionkey.html">openpgp_packet_encryptedsessionkey</a></li><li><a href="openpgp_packet_keymaterial.html">openpgp_packet_keymaterial</a></li><li><a href="openpgp_packet_literaldata.html">openpgp_packet_literaldata</a></li><li><a href="openpgp_packet_marker.html">openpgp_packet_marker</a></li><li><a href="openpgp_packet_modificationdetectioncode.html">openpgp_packet_modificationdetectioncode</a></li><li><a href="openpgp_packet_onepasssignature.html">openpgp_packet_onepasssignature</a></li><li><a href="openpgp_packet_signature.html">openpgp_packet_signature</a></li><li><a href="openpgp_packet_userattribute.html">openpgp_packet_userattribute</a></li><li><a href="openpgp_packet_userid.html">openpgp_packet_userid</a></li><li><a href="openpgp_type_keyid.html">openpgp_type_keyid</a></li><li><a href="openpgp_type_mpi.html">openpgp_type_mpi</a></li><li><a href="openpgp_type_s2k.html">openpgp_type_s2k</a></li></ul><h3>Global</h3><ul><li><a href="global.html#bin2str">bin2str</a></li><li><a href="global.html#calc_checksum">calc_checksum</a></li><li><a href="global.html#crc_table">crc_table</a></li><li><a href="global.html#decode_utf8">decode_utf8</a></li><li><a href="global.html#encode_utf8">encode_utf8</a></li><li><a href="global.html#get_hashAlgorithmString">get_hashAlgorithmString</a></li><li><a href="global.html#getCheckSum">getCheckSum</a></li><li><a href="global.html#getPGPMessageType">getPGPMessageType</a></li><li><a href="global.html#hash_headers">hash_headers</a></li><li><a href="global.html#hex2bin">hex2bin</a></li><li><a href="global.html#hexidump">hexidump</a></li><li><a href="global.html#hexstrdump">hexstrdump</a></li><li><a href="global.html#MD5">MD5</a></li><li><a href="global.html#openpgp_cfb_decrypt">openpgp_cfb_decrypt</a></li><li><a href="global.html#openpgp_cfb_encrypt">openpgp_cfb_encrypt</a></li><li><a href="global.html#openpgp_cfb_mdc">openpgp_cfb_mdc</a></li><li><a href="global.html#openpgp_crypto_asymetricDecrypt">openpgp_crypto_asymetricDecrypt</a></li><li><a href="global.html#openpgp_crypto_asymetricEncrypt">openpgp_crypto_asymetricEncrypt</a></li><li><a href="global.html#openpgp_crypto_generateKeyPair">openpgp_crypto_generateKeyPair</a></li><li><a href="global.html#openpgp_crypto_generateSessionKey">openpgp_crypto_generateSessionKey</a></li><li><a href="global.html#openpgp_crypto_getHashByteLength">openpgp_crypto_getHashByteLength</a></li><li><a href="global.html#openpgp_crypto_getPrefixRandom">openpgp_crypto_getPrefixRandom</a></li><li><a href="global.html#openpgp_crypto_getPseudoRandom">openpgp_crypto_getPseudoRandom</a></li><li><a href="global.html#openpgp_crypto_getRandomBigInteger">openpgp_crypto_getRandomBigInteger</a></li><li><a href="global.html#openpgp_crypto_getRandomBytes">openpgp_crypto_getRandomBytes</a></li><li><a href="global.html#openpgp_crypto_getSecureRandom">openpgp_crypto_getSecureRandom</a></li><li><a href="global.html#openpgp_crypto_hashData">openpgp_crypto_hashData</a></li><li><a href="global.html#openpgp_crypto_MDCSystemBytes">openpgp_crypto_MDCSystemBytes</a></li><li><a href="global.html#openpgp_crypto_signData">openpgp_crypto_signData</a></li><li><a href="global.html#openpgp_crypto_symmetricDecrypt">openpgp_crypto_symmetricDecrypt</a></li><li><a href="global.html#openpgp_crypto_symmetricEncrypt">openpgp_crypto_symmetricEncrypt</a></li><li><a href="global.html#openpgp_crypto_verifySignature">openpgp_crypto_verifySignature</a></li><li><a href="global.html#openpgp_encoding_armor">openpgp_encoding_armor</a></li><li><a href="global.html#openpgp_encoding_armor_addheader">openpgp_encoding_armor_addheader</a></li><li><a href="global.html#openpgp_encoding_base64_decode">openpgp_encoding_base64_decode</a></li><li><a href="global.html#openpgp_encoding_base64_encode">openpgp_encoding_base64_encode</a></li><li><a href="global.html#openpgp_encoding_deArmor">openpgp_encoding_deArmor</a></li><li><a href="global.html#openpgp_encoding_eme_pkcs1_decode">openpgp_encoding_eme_pkcs1_decode</a></li><li><a href="global.html#openpgp_encoding_eme_pkcs1_encode">openpgp_encoding_eme_pkcs1_encode</a></li><li><a href="global.html#openpgp_encoding_emsa_pkcs1_decode">openpgp_encoding_emsa_pkcs1_decode</a></li><li><a href="global.html#openpgp_encoding_emsa_pkcs1_encode">openpgp_encoding_emsa_pkcs1_encode</a></li><li><a href="global.html#openpgp_encoding_html_encode">openpgp_encoding_html_encode</a></li><li><a href="global.html#print_debug">print_debug</a></li><li><a href="global.html#print_debug_hexstr_dump">print_debug_hexstr_dump</a></li><li><a href="global.html#print_error">print_error</a></li><li><a href="global.html#print_info">print_info</a></li><li><a href="global.html#shiftRight">shiftRight</a></li><li><a href="global.html#str2bin">str2bin</a></li><li><a href="global.html#str2Uint8Array">str2Uint8Array</a></li><li><a href="global.html#Uint8Array2str">Uint8Array2str</a></li><li><a href="global.html#util">util</a></li><li><a href="global.html#verifyCheckSum">verifyCheckSum</a></li></ul>
 | |
| </nav>
 | |
| 
 | |
| <br clear="both">
 | |
| 
 | |
| <footer>
 | |
|     Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.2.0-dev</a> on Tue Apr 16 2013 10:42:39 GMT+0200 (CEST)
 | |
| </footer>
 | |
| 
 | |
| <script> prettyPrint(); </script>
 | |
| </body>
 | |
| </html>
 |