mirror of
				https://github.com/openpgpjs/openpgpjs.git
				synced 2025-10-14 00:59:29 +00:00 
			
		
		
		
	Update README.md
This commit is contained in:
		
							parent
							
								
									d11d138313
								
							
						
					
					
						commit
						262ae2b092
					
				
							
								
								
									
										36
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								README.md
									
									
									
									
									
								
							| @ -9,7 +9,7 @@ OpenPGP.js | |||||||
| 
 | 
 | ||||||
| For server side use, install via npm: | For server side use, install via npm: | ||||||
| 
 | 
 | ||||||
|     npm install openpgp |     npm install --save openpgp | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Browser support | ### Browser support | ||||||
| @ -20,7 +20,7 @@ For use in browser, install via bower: | |||||||
| 
 | 
 | ||||||
| Or Fetch a minified build under [dist](https://github.com/openpgpjs/openpgpjs/tree/master/dist). | Or Fetch a minified build under [dist](https://github.com/openpgpjs/openpgpjs/tree/master/dist). | ||||||
| 
 | 
 | ||||||
| The library can be loaded via  AMD/require.js or accessed globally via `window.openpgp`. | The library can be loaded as a common.js module, a AMD/require.js module or accessed globally via `window.openpgp`. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### Dependencies | ### Dependencies | ||||||
| @ -32,11 +32,32 @@ OpenPGP.js uses ES6 promises which are available in [most modern browsers](http: | |||||||
| 
 | 
 | ||||||
| ### Examples | ### Examples | ||||||
| 
 | 
 | ||||||
|  | #### Generate new keypair | ||||||
|  | ```js | ||||||
|  | var openpgp = require('openpgp'); | ||||||
|  | 
 | ||||||
|  | var options = { | ||||||
|  |     numBits: 2048, | ||||||
|  |     userId: 'Jon Smith <jon.smith@example.org>', | ||||||
|  |     passphrase: 'super long and hard to guess secret' | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | openpgp.generateKeyPair(options).then(function(keypair) { | ||||||
|  |     // success | ||||||
|  |     var privkey = keypair.privateKeyArmored; | ||||||
|  |     var pubkey = keypair.publicKeyArmored; | ||||||
|  | }).catch(function(error) { | ||||||
|  |     // failure | ||||||
|  | }); | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
| #### Encryption | #### Encryption | ||||||
| ```js | ```js | ||||||
| var openpgp = require('openpgp'); | var openpgp = require('openpgp'); | ||||||
|  | 
 | ||||||
| var key = '-----BEGIN PGP PUBLIC KEY BLOCK ... END PGP PUBLIC KEY BLOCK-----'; | var key = '-----BEGIN PGP PUBLIC KEY BLOCK ... END PGP PUBLIC KEY BLOCK-----'; | ||||||
| var publicKey = openpgp.key.readArmored(key); | var publicKey = openpgp.key.readArmored(key); | ||||||
|  | 
 | ||||||
| openpgp.encryptMessage(publicKey.keys, 'Hello, World!').then(function(pgpMessage) { | openpgp.encryptMessage(publicKey.keys, 'Hello, World!').then(function(pgpMessage) { | ||||||
|     // success |     // success | ||||||
| }).catch(function(error) { | }).catch(function(error) { | ||||||
| @ -47,11 +68,14 @@ openpgp.encryptMessage(publicKey.keys, 'Hello, World!').then(function(pgpMessage | |||||||
| #### Decryption | #### Decryption | ||||||
| ```js | ```js | ||||||
| var openpgp = require('openpgp'); | var openpgp = require('openpgp'); | ||||||
|  | 
 | ||||||
| var key = '-----BEGIN PGP PRIVATE KEY BLOCK ... END PGP PRIVATE KEY BLOCK-----'; | var key = '-----BEGIN PGP PRIVATE KEY BLOCK ... END PGP PRIVATE KEY BLOCK-----'; | ||||||
| var privateKey = openpgp.key.readArmored(key).keys[0]; | var privateKey = openpgp.key.readArmored(key).keys[0]; | ||||||
| privateKey.decrypt('passphrase'); | privateKey.decrypt('passphrase'); | ||||||
|  | 
 | ||||||
| var pgpMessage = '-----BEGIN PGP MESSAGE ... END PGP MESSAGE-----'; | var pgpMessage = '-----BEGIN PGP MESSAGE ... END PGP MESSAGE-----'; | ||||||
| pgpMessage = openpgp.message.readArmored(pgpMessage); | pgpMessage = openpgp.message.readArmored(pgpMessage); | ||||||
|  | 
 | ||||||
| openpgp.decryptMessage(privateKey, pgpMessage).then(function(plaintext) { | openpgp.decryptMessage(privateKey, pgpMessage).then(function(plaintext) { | ||||||
|     // success |     // success | ||||||
| }).catch(function(error) { | }).catch(function(error) { | ||||||
| @ -59,6 +83,10 @@ openpgp.decryptMessage(privateKey, pgpMessage).then(function(plaintext) { | |||||||
| }); | }); | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | ### Documentation | ||||||
|  | 
 | ||||||
|  | A jsdoc build of our code comments is available at [doc/index.html](http://openpgpjs.org/openpgpjs/doc/index.html). Public calls should generally be made through the OpenPGP object [doc/openpgp.html](http://openpgpjs.org/openpgpjs/doc/module-openpgp.html). | ||||||
|  | 
 | ||||||
| ### Security recommendations | ### Security recommendations | ||||||
| 
 | 
 | ||||||
| It should be noted that js crypto apps deployed via regular web hosting (a.k.a. [**host-based security**](https://www.schneier.com/blog/archives/2012/08/cryptocat.html)) provide users with less security than installable apps with auditable static versions. Installable apps can be deployed as a [Firefox](https://developer.mozilla.org/en-US/Marketplace/Publishing/Packaged_apps) or [Chrome](http://developer.chrome.com/apps/about_apps.html) packaged app. These apps are basically signed zip files and their runtimes typically enforce a strict [Content Security Policy (CSP)](http://www.html5rocks.com/en/tutorials/security/content-security-policy/) to protect users against [XSS](http://en.wikipedia.org/wiki/Cross-site_scripting). This [blogpost](http://tonyarcieri.com/whats-wrong-with-webcrypto) explains the trust model of the web quite well. | It should be noted that js crypto apps deployed via regular web hosting (a.k.a. [**host-based security**](https://www.schneier.com/blog/archives/2012/08/cryptocat.html)) provide users with less security than installable apps with auditable static versions. Installable apps can be deployed as a [Firefox](https://developer.mozilla.org/en-US/Marketplace/Publishing/Packaged_apps) or [Chrome](http://developer.chrome.com/apps/about_apps.html) packaged app. These apps are basically signed zip files and their runtimes typically enforce a strict [Content Security Policy (CSP)](http://www.html5rocks.com/en/tutorials/security/content-security-policy/) to protect users against [XSS](http://en.wikipedia.org/wiki/Cross-site_scripting). This [blogpost](http://tonyarcieri.com/whats-wrong-with-webcrypto) explains the trust model of the web quite well. | ||||||
| @ -71,10 +99,6 @@ To create your own build of the library, just run the following command after cl | |||||||
| 
 | 
 | ||||||
|     npm install && npm test |     npm install && npm test | ||||||
| 
 | 
 | ||||||
| ### Documentation |  | ||||||
| 
 |  | ||||||
| A jsdoc build of our code comments is available at [doc/index.html](http://openpgpjs.org/openpgpjs/doc/index.html). Public calls should generally be made through the OpenPGP object [doc/openpgp.html](http://openpgpjs.org/openpgpjs/doc/module-openpgp.html). |  | ||||||
| 
 |  | ||||||
| ### Mailing List | ### Mailing List | ||||||
| 
 | 
 | ||||||
| You can [sign up](http://list.openpgpjs.org/) for our mailing list and ask for help there.  We've recently worked on getting our [archive up and running](http://www.mail-archive.com/list@openpgpjs.org/). | You can [sign up](http://list.openpgpjs.org/) for our mailing list and ask for help there.  We've recently worked on getting our [archive up and running](http://www.mail-archive.com/list@openpgpjs.org/). | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Tankred Hase
						Tankred Hase