�PNG  IHDR��;���IDATx��ܻn�0���K�� �)(�pA��� ���7�LeG{�� �§㻢|��ذaÆ 6lذaÆ 6lذaÆ 6lom��$^�y���ذag�5bÆ 6lذaÆ 6lذa{���� 6lذaÆ �`����}H�Fkm�,�m����Ӫ���ô�ô!� �x�|'ܢ˟;�E:���9�&ᶒ�}�{�v]�n&�6� �h��_��t�ڠ͵-ҫ���Z;��Z$�.�P���k�ž)�!��o���>}l�eQfJ�T��u і���چ��\��X=8��Rن4`Vw�l�>����n�G�^��i�s��"ms�$�u��i��?w�bs[m�6�K4���O���.�4��%����/����b�C%��t ��M�ז� �-l�G6�mrz2���s�%�9��s@���-�k�9�=���)������k�B5����\��+͂�Zsٲ ��Rn��~G���R���C����� �wIcI��n7jJ���hۛNCS|���j0��8y�iHKֶۛ�k�Ɉ+;Sz������L/��F�*\��Ԕ�#"5��m�2��[S��������=�g��n�a�P�e�ғ�L�� lذaÆ 6l�^k��̱aÆ 6lذaÆ 6lذa;���� �_��ذaÆ 6lذaÆ 6lذaÆ ���R���IEND�B` var crypto = require('../browser') var test = require('tape') var fs = require('fs') var Buffer = require('safe-buffer').Buffer var path = require('path') // Test RSA encryption/decryption test('node tests', function (t) { var keyPem = fs.readFileSync(path.join(__dirname, 'test_key.pem'), 'ascii') var rsaPubPem = fs.readFileSync(path.join(__dirname, 'test_rsa_pubkey.pem'), 'ascii') var rsaKeyPem = fs.readFileSync(path.join(__dirname, 'test_rsa_privkey.pem'), 'ascii') var rsaKeyPemEncrypted = fs.readFileSync(path.join( __dirname, 'test_rsa_privkey_encrypted.pem'), 'ascii') var input = 'I AM THE WALRUS' var bufferToEncrypt = Buffer.from(input) var encryptedBuffer = crypto.publicEncrypt(rsaPubPem, bufferToEncrypt) var decryptedBuffer = crypto.privateDecrypt(rsaKeyPem, encryptedBuffer) t.equal(input, decryptedBuffer.toString()) var decryptedBufferWithPassword = crypto.privateDecrypt({ key: rsaKeyPemEncrypted, passphrase: 'password' }, encryptedBuffer) t.equal(input, decryptedBufferWithPassword.toString()) // encryptedBuffer = crypto.publicEncrypt(certPem, bufferToEncrypt); // decryptedBuffer = crypto.privateDecrypt(keyPem, encryptedBuffer); // t.equal(input, decryptedBuffer.toString()); encryptedBuffer = crypto.publicEncrypt(keyPem, bufferToEncrypt) decryptedBuffer = crypto.privateDecrypt(keyPem, encryptedBuffer) t.equal(input, decryptedBuffer.toString()) encryptedBuffer = crypto.privateEncrypt(keyPem, bufferToEncrypt) decryptedBuffer = crypto.publicDecrypt(keyPem, encryptedBuffer) t.equal(input, decryptedBuffer.toString()) t.throws(function () { crypto.privateDecrypt({ key: rsaKeyPemEncrypted, passphrase: 'wrong' }, encryptedBuffer) }) t.end() })