| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | /* | 
					
						
							|  |  |  |   Copyright (C) 2013 Grégory Soutadé | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   This file is part of gPass. | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   gPass is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |   it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |   the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |   (at your option) any later version. | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   gPass 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 General Public License for more details. | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |   along with gPass.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-05 20:07:11 +01:00
										 |  |  | var hmac = require("hmac").hmac; | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | exports.pkdbf2 = { | 
					
						
							| 
									
										
										
										
											2013-12-07 10:03:53 +01:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  |     pkdbf2 : function(password, salt, iterations, outlen) { | 
					
						
							|  |  |  | 	var result = ""; | 
					
						
							|  |  |  | 	var temp = ""; | 
					
						
							|  |  |  | 	var temp2 = ""; | 
					
						
							|  |  |  | 	var temp_res = ""; | 
					
						
							|  |  |  | 	var temp_res2 = ""; | 
					
						
							| 
									
										
										
										
											2013-12-07 10:03:53 +01:00
										 |  |  | 	     | 
					
						
							| 
									
										
										
										
											2015-01-22 21:50:07 +01:00
										 |  |  | 	hmac.hmac_init(password); | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | 	for (i=1; result.length < outlen; i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-01-22 21:50:07 +01:00
										 |  |  | 	    temp = hmac.hmac_digest(salt +  | 
					
						
							| 
									
										
										
										
											2013-12-07 10:03:53 +01:00
										 |  |  | 	    		       String.fromCharCode((i & 0xff000000) >> 24) + | 
					
						
							|  |  |  | 	    		       String.fromCharCode((i & 0x00ff0000) >> 16) + | 
					
						
							|  |  |  | 	    		       String.fromCharCode((i & 0x0000ff00) >>  8) + | 
					
						
							|  |  |  | 	    		       String.fromCharCode((i & 0x000000ff) >>  0) | 
					
						
							|  |  |  | 			      ); | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | 	    temp_res = temp; | 
					
						
							| 
									
										
										
										
											2013-12-07 10:03:53 +01:00
										 |  |  | 	     | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | 	    for(a=1; a<iterations; a++) | 
					
						
							|  |  |  | 	    { | 
					
						
							| 
									
										
										
										
											2015-01-22 21:50:07 +01:00
										 |  |  | 		temp2 = hmac.hmac_digest(temp); | 
					
						
							| 
									
										
										
										
											2013-10-15 19:29:34 +02:00
										 |  |  | 		temp_res2 = ""; | 
					
						
							|  |  |  | 		for(b = 0; b<temp_res.length; b++) | 
					
						
							|  |  |  | 		    temp_res2 += String.fromCharCode(temp_res.charCodeAt(b) ^ temp2.charCodeAt(b)); | 
					
						
							|  |  |  | 		temp_res = temp_res2; | 
					
						
							|  |  |  | 		temp = temp2; | 
					
						
							|  |  |  | 	    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	    result += temp_res; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return result.substr(0, outlen); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-01-21 18:56:32 +01:00
										 |  |  | }; |