diff --git a/karma.conf.js b/karma.conf.js index 8b1c405fa..d9b224d28 100644 --- a/karma.conf.js +++ b/karma.conf.js @@ -88,6 +88,7 @@ module.exports = function(karma) { 'tests/blockchain_wallet_spec.js.coffee', 'tests/rng_spec.js.coffee', 'tests/transaction_list_spec.js.coffee', + 'tests/wallet_crypto_spec.js.coffee', ] }; diff --git a/tests/data/aes-256-vectors.json b/tests/data/aes-256-vectors.json new file mode 100644 index 000000000..ff0dd2afd --- /dev/null +++ b/tests/data/aes-256-vectors.json @@ -0,0 +1,77 @@ +{ + "cbc": { + "key": "603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4", + "tests": [ + { + "iv": "000102030405060708090A0B0C0D0E0F", + "testvector": "6bc1bee22e409f96e93d7e117393172a", + "ciphertext": "f58c4c04d6e5f1ba779eabfb5f7bfbd6" + }, + { + "iv": "F58C4C04D6E5F1BA779EABFB5F7BFBD6", + "testvector": "ae2d8a571e03ac9c9eb76fac45af8e51", + "ciphertext": "9cfc4e967edb808d679f777bc6702c7d" + }, + { + "iv": "9CFC4E967EDB808D679F777BC6702C7D", + "testvector": "30c81c46a35ce411e5fbc1191a0a52ef", + "ciphertext": "39f23369a9d9bacfa530e26304231461" + }, + { + "iv": "39F23369A9D9BACFA530E26304231461", + "testvector": "f69f2445df4f9b17ad2b417be66c3710", + "ciphertext": "b2eb05e2c39be9fcda6c19078c6a9d1b" + } + ] + }, + "ofb": { + "key": "603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4", + "tests": [ + { + "iv": "000102030405060708090A0B0C0D0E0F", + "testvector": "6bc1bee22e409f96e93d7e117393172a", + "ciphertext": "dc7e84bfda79164b7ecd8486985d3860" + }, + { + "iv": "B7BF3A5DF43989DD97F0FA97EBCE2F4A", + "testvector": "ae2d8a571e03ac9c9eb76fac45af8e51", + "ciphertext": "4febdc6740d20b3ac88f6ad82a4fb08d" + }, + { + "iv": "E1C656305ED1A7A6563805746FE03EDC", + "testvector": "30c81c46a35ce411e5fbc1191a0a52ef", + "ciphertext": "71ab47a086e86eedf39d1c5bba97c408" + }, + { + "iv": "41635BE625B48AFC1666DD42A09D96E7", + "testvector": "f69f2445df4f9b17ad2b417be66c3710", + "ciphertext": "0126141d67f37be8538f5a8be740e484" + } + ] + }, + "ecb": { + "key": "603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4", + "tests": [ + { + "iv": "", + "testvector": "6bc1bee22e409f96e93d7e117393172a", + "ciphertext": "f3eed1bdb5d2a03c064b5a7e3db181f8" + }, + { + "iv": "", + "testvector": "ae2d8a571e03ac9c9eb76fac45af8e51", + "ciphertext": "591ccb10d410ed26dc5ba74a31362870" + }, + { + "iv": "", + "testvector": "30c81c46a35ce411e5fbc1191a0a52ef", + "ciphertext": "b6ed21b99ca6f4f9f153e7b1beafed1d" + }, + { + "iv": "", + "testvector": "f69f2445df4f9b17ad2b417be66c3710", + "ciphertext": "23304b7a39f9f3ff067d8d8f9e24ecc7" + } + ] + } +} diff --git a/tests/data/wallet-data.json b/tests/data/wallet-data.json new file mode 100644 index 000000000..baa540942 --- /dev/null +++ b/tests/data/wallet-data.json @@ -0,0 +1,82 @@ +{ + "v3": [ + { + "guid": "15506a26-fa63-4158-a898-63e6f81aaf9f", + "password": "testpassword", + "iterations": 5000, + "data": { + "guid": "15506a26-fa63-4158-a898-63e6f81aaf9f", + "sharedKey": "5ee0973f-44c3-4317-9edb-dea9cf25bcdc", + "double_encryption": false, + "options": { + "pbkdf2_iterations": 5000, + "fee_per_kb": 10000, + "html5_notifications": false, + "logout_time": 600000 + }, + "address_book": [], + "tx_notes": {}, + "tx_names": [], + "keys": [], + "paidTo": {}, + "hd_wallets": [ + { + "seed_hex": "5f99079b5162acb585a9b0d719c05de3", + "passphrase": "", + "mnemonic_verified": false, + "default_account_idx": 0, + "accounts": [ + { + "label": "My Bitcoin Wallet", + "archived": false, + "xpriv": "xprv9yBZ9TrUgcmm8HSeW53rkmDi3AkQfxYhBq6hitM5WyVt7iPuikhfo5GpVgRkZncKMVNHzEH5eraZUfKnDXDHjFhXyuuc9iyEPXQSD7H6FF4", + "xpub": "xpub6CAuYyPNWzL4LmX7c6as7uASbCau5RGYZ42JXGkh5K2rzWj4GJ1vLsbJLzjksGursEwwXmyyg47sRkwN2YQBA7kiCTdqSETpd64LBqL84t1", + "address_labels": [], + "cache": { + "receiveAccount": "xpub6EiGuhE74faCYPBMFX8YbmWh8TzxKA4wupxhsyfNZhA4TCyEdJGjeYYQXLWoBERW36gNeawowC48TvVMzdjbxeVRWS1wjCAjoeP5aHUewyq", + "changeAccount": "xpub6EiGuhE74faCaYuTxzXjWiKvx3JSgqpurM7RF8GLXanHeQ5f5kZiLoRiqdgTYZkFiBEiXQ4L1sQfKQCbjNqkAGSvwkGxku7JgQDLzQNEF8u" + } + } + ] + } + ] + }, + "iv": "6d0de58acba8a1f2badef0de907c0b1d", + "pad": "514ec8", + "enc": "{\"pbkdf2_iterations\":5000,\"version\":3,\"payload\":\"bQ3lisuoofK63vDekHwLHY0DPWsP9wULcj/B5VlkGmsPQsDp7eQ66rMV+eRKu/dir3dprqprTudHoyx9DVfs0uNvuMdjYFY6uAN+1OL0TVkFdbueyviHShRwIfI+Sv1H57AmGrBVAkjyWgNpl9+idBUDiL4goyOCpwRE36Xttk8yLxNQKuGY/Sa487eyU+iC4LVS90DXPl8PCQmaZhAnfN6Cn4h7g0Z9z6PZz8ZIzvUT8kfMPa6wewp8452SUoPhVT9acoCM8XNlj/ErfC718PyidExZsX05rtkq/3Q/5/eEOb8e2n6YFtDVpWWvXkGw47K1WKAHSB2U0vuDGpsmG4FBwub0F2cFb6FYh7HkMeRYf4/z6UqVnlD1jRDLzFhVwGPHZiTni80zl6GqtnEfcvUubsp8i5ygWkhtLbaP+IChr3JzUgl9Y1QHozPzxFuTwNRmjjgft6bN/43WRuD3sjTPJz6HOn9Hti9zqYm546+mU+UBEhzmKy6MeSV27oHhHTLrBddcCU80AAxopJsC76hxWh0SzjuTWEhmAczZfdllkawQs/sSIOR9YLb25+jusoPmylQyBfLL3bt+g6ek7xcg9kBxeqhuSQj6C+OGolHtBJzhOKKqs/fgPy+0Vjzd8jHo6QM0yauuzUR1oQOfV9iIWORVhYGqcNrXAccRnQCXTlxGVi4v5Zk9CGmhpCjenccTtT+bZVzrqAHvmopZ4GgbYak9lTy8OtddYM741TmhhqExztnNP+gUZcxVNe0/yO7K2qXveLqO7sO3WB1fV2bgI8y1JwEyNKq+cPoMxdueMsna/H0UvgXPC/b0On/e3YctFeUHDYfGZSBKq/pHefp+MoSxUszuS19ALh3paKeK0QhrEgFPUvT7ScUNMzhKc4LiViviSgrgfyojrqpOkhAokrrBpq8XDSgNJxxGRfVDH75kUFJEBHBSCE32If8V1M4H+R9ypqhQ8R6/V8dCffCO/GI4UdFaeLVy/2DniPvR4zoPQN0ilwT8ypE6Y+QWnZJc6VYidVtipwKmD5cZMcaZeRNv3hJ0WBSj6v/Nr0LUxG1lNbFWMzMEARG3dhkZNAhCY+vAFkArUIDpawskQ8A9jQ2ZpGN89A6UrVGzTVPbyKisPJ+9YCuKF+v3tM3WpRaK7WQGpvPmsnl6AAT7W/utiVdSDtpPQ+G6D7pLEcZuJBAkwX+gcf3f8AsyCy8v1xYv15kL2xFXybjnA3lgGqJaqFxWOQwXhXXkovjiX0IJzJ/QH9aL32moB5OsRNvcCRMBiQoDus+fKJ1epo356R8xsvwjE2FF2NuPQS8CtZRmTKpCO3mGe3Aoi3QKpaPeg0ZWUUqmvfTr3suDTtWPJg9dX4J5FDAjLxeof4RNZR0=\"}" + } + ], + "v2": [ + { + "guid": "cc90a34d-9eeb-49e7-95ef-9741b77de443", + "password": "testtest12", + "enc": "{\"version\":2,\"pbkdf2_iterations\":5000,\"payload\":\"b+OfaGwd/zcOsSy3BUXD6w6u18rVOiFFeSHLNCZYhgfoPGj3csxlYL4gAGYYBqQDT6BzWdfT3/7rq0Oe44mMdFfKP8TWyt41aPOXKZo5MgfBOtamvNMD7PtW5Qxap9VUemKCdWMe5IS7R80/md2E3WPxUlWIqW2mooOFFpfoicVMGnJormlUaiUIsG9hv43MtP3g18eYv3P3OE+2LGyjavmSTbmgLznUA8TcAJNNLwD8br9kBp/TTd1wTFNMwyjILlD20HgoX4S/922qhReR4dxTjJUjplE5LJVBkemwNDNqCXZVo94r3RizD7SBwXneawVGIQZYOZ0aBvXdEe2ooIoZ2fIGMsdJCMvzXBXZ85jdfRg0LFtB9+YaOwZsM3TlY6wr7hk3sSpTVtHf22+egIWQEa1rylt3ywK/ArdAq4ydpGOtjfjfZfiKazc0CYiqVxJ5HBD4NBfh1moLZnOcHnzM5EnW6jO9dVek579C4sh7s9kAztwCVX5r4GfSTovPvuwzcEVxUL4uEHd+zaczQHU8zWIGrXupWKHfkjeoWxDM0iW6edBWtv13/TJnjTkeJzraQS1iU4iQGkPplITqctHIgschR8Cj2HurUcW9Y/2C5nEdhfMjnTfCxzspLWObOCGWnLEMWOJhC4MPsUJy3p+R1JD7p1QlyRQ0I8vtn+FEuEUL4ui9Fe9zfRvd1xfiJ+0CBCAtRwzEaBqCnI9GciErdTysUw0lvcBKbPU05ajsSfbYIzow2O6SG/PCqIcUbePChuqVJBRPmK1erzC1XNt2HFRYKTqIWy/jtx4cKgXBtK750LX+67Wcvw/OjX3rthvfE4ZZYYl/smJUB32b2tfSF72+aSzmC9nz/fJTztNahQIPbU/vGE2R/R5CQZCjvQxvgsfXKVk9N0Av9gpH1w+i0BgAIwi5mBA+zZlgUteNcuEWkPgE4NpN+uue9mlq/t1rpySjOgt0D50gUmJMfQGgYUoN3OtyjGUt437Auk6Y37aHYXZekjDPCdgr7yYDvkmUVeB1f31swzh/nwz4lbw9ezSTHIYBMN4XW4xuG3vtefu6fIK0BDncXEE7d3BM9OnWzTBtJQVvWZW2+lslb/PjmEFTY/UoELKjpG4wTvm+LfI+Q2jlLT7VblZeUVdEeONhElkadl/SQQq2sRVbEHzyZhlEc3cbznT5BPeGEoIG70NOckCxl57F84VO17d9xvtMs5joaYB0nr2yRuBFU9/T1FOLiQKjOv/GCOLLL5IdOUlVHNlj17EQ7KtaghNTA7ndPoVp7pgc+Gu2zKn0yBVKzLTD8t7L429pCs9N0QsO00w+tVLZwH9l37rNkqFaW1BhOD+T4VnGdy1fYIeqKfyWpf9UExPaZniki7+syIPoQ7bc0ZDWzr7FcIuRsPzOu3koW7fOPxYYaIWHLGSvtnfsRVb029CoKsr/RQNA8zKN6SuYjguEdA63/GEUIIDX9QpAlyGAGFN2Dfm4DgKipDHgqiIykf/PldocnF2iS96l+JFHFwtnXBjNOVjhbmQDJOCK1IhZfjimqfRBmFATmPerpMqDllACinmu7WcEufEn/NdKRVagki0GEWhWbcg+LApuwTSG8K/6JR7dHjh1McuZ60PObVV6qSjvpvIW+THuQ52C5DUQz7ReLuc/BMe1zd/xFB982AikeTIDFQl03QJ7w5inVBrDUcJEbNt8Adg+byPozUDnw06+i705h5gZXuWioklrHbt7OlSHcWfWnZa7HqZHJ128mi80OzpK2qePp6/mYv/zbcjKPh47H9m2LoV2zeAzlwMsgQtp0wu8bXbietEB0KtvVTarU14iFOftwZnhgVv3oIUVZQ7zkua4J+eiMy6gDQNNUB+0t11F8w5c8Ivnp+rg1nD4RJaOHnIZ2IU9ie2PpaiuIiyyaX1drAzNOM5MU0dOrDBTIkreM8bZH8LllYnkwa62nlY4EjWtVivhDk9rB7bOUZMhQmHB9Y539EmHJxvqIborRDGDC/3AvuFSRZN1jug6KZhYjr8aG98HhN3cFw6M6DwDS8llhkfMdM1l/fFS3LjjuVz1yAOdI4GWVDKdjKKjW2rbwjnpgoK+plxN8KqM8JEt6z3gPJwvIhImysXjXNKxbjHWVKGAYD28iK6f4csk1NrgCHM12r8Lkwf0gXW1AVvxufYKzpa/9MrA6V7B+Y3fJ9ooDAlikVCFzVEFD1894hgWhOXPeZS5qOqnW4bvViGsi0dhQvWnztBu+PUN531oL/Ecx4q/U0gz6oxVJ2YtoHG3G/H8ZFdq4bMwXM1A3b7rd2sIdO6EY87g2PgpoPF7idnfQdxxu3lC6HjaMwbn8mxwwJSSoGO3QYmZWRhRf8wJteGm3ha5rDXS952WGBc1o7K2zx7kbjURR92pkdyPqSyUfwYovZXpzCawGlAqbIbRtcxxQdod4OBXCdqmCBklxjUb529/arFJYZXJJuxIY6bM630mriMvyYAuHkgIbsiTwyTcwJ15OsQxy95aNYiHU1HotJKJhNRdpzBvAKxSoGhD40vkM72EdpB6ymeAUeABRb3wvD1KY+a2GcPVSE7ZVqaNJ+hGOdDLq41+Kwh9/mR0zlmmIKKxwBX3IL9EX7eesKVOKH7JFMggLNi2fxuc46OCQVIws6p54jUj1ksce45EYE6syEZkB8Ekhk3V4s5DwBDXBuaHJa70AKRZPlG9QGXLeVmF/JS9PhcEA+3QpOb79+OZF9BBnz6hPPrttAPXGMqoNQvDySEV4l4tijrZJHe0YMOw9zoVQYA5hJW1+kS4lUq7SIC7gSN+vWAMBh6LFAity5JikUlXoYievM8zqySbr4xP9HI/zph3tHmONkfTBKCo/dkD1QaQfD37Qgqo40q4WDgbS78MMq0AeHU9WTVoa1IBkn5aSAelq3rTMVaKTzBOxKdc7EI+Pl1MNf8+0/ggNPC6InCpvOcNdbPuQxM3NLqMrZYNb5x+xoxOXrAvDH4wnF59JkvGhr6OOU4RNfv5YJZ/U3r9NyhvQtJExHKWKE6fxjDa3bruZ4UqQZXxwW5XgMS6+5QN4j1dOJhiL9CnWsNEQvSTa0rfZv3AcZs41hPrY8NXAueYZfjccec30lH7iGDgP2NOvd8tRbSO+X/I9OFxc6m2CoEoT4sniy6rBUCh19hJOt2P08x8U371wZkEG1yQzOF1mrmvlAT+aZP0WUS55JM1sqGdEHHTjJuv4h9NSCP8nURwj6y5hfqnUQPnofUTGvwV24E6+HvQTXoaLxks5k1Rw8moKfhsVEmdj2Arh9O21vwhEYc1+uWFNqT8s5f0OzQ9n0glGdg4SWFsZ+ttEyHaE5HTkuNm/dXtQi6GOcjZzR41+8gMh8O3KFhkZqxLfpdWSNeZ8GpY/LBvt1ZIXIIXjjybYDOz2Sx5ANssXt8nyk4nyjl2Ggv5BNzhbcQfstC6Pg0JVFhXtYizCqyZsjWhwaKynnP3UCqf5xJteuFwOyZyXpeEw/tdtQqtpw81T2iba3+69q7tkpv7FJtMraGfbD/BBWRAQ/W23AwREkru3Pm2sbfRSqnc84b3ZARUKpV6k8MEALWOcNFrP95uBQPHaBGZSQR4KZdlHvEjRN8WqZNgfH78lnUvWbKkdXGSrMeMrZVZwXI4fUlfexnqa/YeVmNewRDajuRTWnYMlyQgQae54FF+iz1NSGSNt6eruL4vgVFT3R09hxCDsqf5tNCDR88XC/DtDZvyPVs+e9Va/DA2x5lir6p/U9BKo5mNBG9UKvrOvep7Yu7Lfn2dN7cutDAY2hZRrKeVJxwXg1IlVJnsCDHockVfe4JSsAiUPZQQpPx7id5GbUOcXT9dtHgFxt5BpqzTldrbXYqvsit0kusUhkdJc5Q/+g9gIYqRNLLouNum0heZZ82dKfmhYwoED+hupYW1WidTIEkVcv3cDeYPPBdxcU7Zli1M2n7M+AbulhmZXxe+RDkbFvK7m8rzAJdOjI7Vxn3+8/8X3sQl1tpTWd9XLz+O/l+y58IZI6jpCSZGRLfJpjNJ4wlJs3Vr3aTmP0m4ayyz28lIItH46URrSVc/TUQehaVw09ouMlMN/HOXc7nvPL+2Ll161h6reVLuo6FOfrIWHGYNtklB3gKbEYeLEUFaIgW5am/A+mhJKiaC8LsdeOhX6f980YDN4cXkn/NvOXKfJ1D4X6MptfQy4dBj/jE4rMIcUmPXZi9tZKXJvk5IchO1RLnS6bh9ys+oWz0w0OaofE5NbvoFj26uLNhD3TPesmrt+0JW1okiqQe9Jr0HLlhlQQp0zwoLH3aHWbY6h+Y4zVn0sEYZ3qKaoLT6MzMZtdYRX6YbLyQF5i2dAQRto9LE18Y9GX/kKHER61Is5xAkCRIbgl4v7Dq2rxPQoKD97/qqXN6OVLKasg3mUyqPjL5+clTb0Iqlfjx7+/ftXpjaHTM0YQWMa1TZlB2D4dXVWb4/R+HlqTiX7owY58+Kih14Rt9dtiIndjvcil3N2CdUz9bW6ur8MhtW5qWrTz1tXXpsWgcZrVCzECuFJZfltXRvbgz1Z3j9CUXJwtzYWKekxEvGP9tHnccvGyI3hC6llqHs5mkaNJRGkdeuwNgNdbJS+8ZU8YyRj/s5SCh9A9ncOoI6kZh27GcqckLBq8au+zFwr6zPusdTWUH18G9cEPeL0tsfeDJKz3jI9pl8l6emTEQ3ROveqSZC/D28pmK1z3IcGDP60bwbOTGHLnjd+S6PjuoVi1l7v4bTpNwnvslK7mQ9cuG8xzPppfMlyOtdKFvMBEFYUh0vjBLNrQT3M9DaCvLDvQNIA13whWYzyNbirSahYlSrw5Er4edXzIkjw2M8vmiCS0HG/s10I3KKj0Ck6RiT9dxg7Rez3wl+nvlobMZiihBfO4FZVEP2wbgHmI9vkDKBSiTXVkCA3cXPxa5qJNrKRcOCtZXhQ7SsQViClH490T+lqMjICwSn4EOV7sO9VaKv4neywsedm+aX6uwQM/Xhwji8Z6SFesW+fWCWsZoQ1IshxXYtra9diD2CUk1Z1Sb7oExROd93sSPdFP99LArUPatN9zSUlXIEEekV3NycBa/2kyEm7nlYkZb51b0YQClYivGKD1wPa5rvYBv2IUAqsiV0Sh8RDqQKqucZfZvdl7IMrxmcs9T4p07tEsk8RbqWJBEtc0aSMFrIIkNLzazzAPMfaOi+OhDVj4nPrIeIpDoPjqppTfVZw2ZZu+kBov2hgamYakhx7z3ZbOfAqA696RqvIyx0MYZJ65Rt2ObaM1EwZfyyTsBztvwf23KqUSuOr9qsVhlfmTjSDoT0mUGT7uR3mCAVhsVMAfp3LmzNTmzWAOgBYKvBv45czqGCBkwFA4Gs8Ed/IxvUbErm3tGiGjHzrO7JrDDoZ5dGbzsfg1WPl3EyUyipn9C5md1wGDXH4eFG8SbXajk+v/G6uqK5EVgghWKBSfuYMvRy8ujghet0BInXddyZwhCOT1GNSSR5HiUPmkYR2trSs06fDBtut5j70YnEY7qEmvaV84WTz2rybAVWSWeJd8SDZcrvJyZyFCU49PRxGMnGZDpLvXel/W2EfbqIn0/f9lwCrEtpiUUzPSMlu1Sp956CdvHRLtv2pLqryp6Tw1aBGFHFll6eEgnKnu93IPLojXUTfhWHU4stAWtjM+lfSAMapZWjEyS3cI5rekBxJ6qH9zjSTMcHzhDzfTomIjKZJwRCzU2KjSxZbVOMtNoNbBAD6HW8/KXwtvVETlQZwSLUpUeCWdGLNyT4s/HN+vaG7j/BQjTIj3YM1gfHhpzHvvrPzTq/2/myJS1mq+Iu+lF8bHQQ/g81gDv17xoMZUIOjNSmYLs8PkAFDNWpmmc1Tz3In7MxQMj+xZWgW4l4+7HTfTDtBBW+KmG5haiwqwGfCPBX13kYWzqu5CLne141BYZEqcsVF0Qwmp14+QfjLcKuHjXz0G8NKUqzC2xgP80Pljc79MxjBCthVplUKoAVU84krApYRR/LGI7AbrS8V6La8hBMt6XCPX4xF2EkuoQ2D5O6U5afAhcSIyPtZDPHz91e+yH87Al7rmUZPaslux/yhuCjmdzARr8g+e4JHlBgD2udSdIaKuodT7mWST6f3WLE7jKxSOn0IssYSi2mkV9nNHQY1QIdf87Y8R9dJfodAT/5lxJdi7X+yDpp9WGwXrUqvfohAG2H37fZis2H4y/2Rf5vRJgw0Lvs3haeFkzgkvuKxy6sjRX96p6sIpoEfpiuP4bV6Z94VpMsbcrNCA2Pkh4Mew5xNwf3UVPen/6LqjCUMdWoPn8Fz0sGRGISrBCrvVo3yJrG+tifxrny5LEjCH3tkVa+6K6s1qud/x43oAkusBI4Myb17OvE+WVeslWenvkpQ/yotXU0wY9LIJjp8/oIXh1T/p+ZKRuB1q6Y7JmLf5zbl3JNVnAG/PgNsr5JXp7lhrIR19gfUIajml99M9gB+Ly0luHd18jTCHWkbEqXxSekXf8eeOoKouSaTUDcJtxlupmNG7H5uU1KM+TQLaz+I+hgAyO5PLjW4VWkjJXImiWYtzya20oFe2gsg5ZyFJPuNyCtFopkHmRti0gL726fF4FfinhKyuPKa/Jf7O+g/DM87ycRPts4C11B8OqcSa0OxomaiD2yms0viTme66fDi0/Y6O/glCaOj1msrwB2OXC3Q6nyIrHhdfcxL8CwAyJUWr6VdHYEZ8GisK+hYh3hCNk/AJpcsS7KboCP1emlVxnEKT/iBWpUpXDp/i3Rlu7np/y1FeoER57zzvbniYaRRuHMHByGzQ/VH5Pex6zswB+xXLut5zu4/cQN4I4XNBaH2ftBGFo6ZLL12NCSMWDApVvVaaMy+EETlFJW1eZ7PkjS93iyh6rDP7GrUtPbOjVPlCpZYgWHMWpXurUcT6ztmTE+kW3MgtTn6fixGSoo7yukQIs8fscKsexKnSXXHPxQT58r8mHMgvvYIL3iOfQccVlMEhOvLiRE9gjEA7gm7A7d0kqMLtHbrQoevygbb5uMaLWvSYstyKvnvbW3vh1FHzK6oBWfihyTxDJ5v2R12on9RIbGAzcDsFI8BrvFw9vck9UMcPxFkZDMD0vucvWYNwTb6qRpbc8UBh4U6sNgcf4MgcDit3e0zlL49gqZwximmwkfb0MqxM2cLBTfPMuVaPGV91tYh+jzNke/etB6pGRtrqS8qXM68beOUy2qe7cMV8BcUwk2fF7LMlKN9QPXIjXpmnfHv8ILZobBN4yH07oatUopPsdrtx3b3iQ4Ii98Ku8Qay9KSQznXZfRmwztmqXedBq94abr8yVlUbOoQUuq63OS10g4c9G+ktIKbN+SSahU49HIg0vPUsAaEu3hVH6bfxo2yp/wfVPBCmXd16NMs0ii30/8WvU2NVApSUpahIUzIKESuTS3gnquuxsl3d7EUTZOBwYAUjVmPjIm94d43tuTwr3WTkgM6Rmtj9D97LHewkjlmmqjDeG0l0OCObqecyMnOSzjCzUtILkgUcubMNUzpxRv8VHODMJ7buTtEAwuqFPSZapWUkGNZSP0jORzJaa2yOhXDJ6vn2k7g0hi3JnDJfMqMHo5suI9UErsevrVv87GDDtnKMelqvAVoZs+oTj3xum3JDPE7pmYjA7VfxsGMm9IyTOIjw6xrTt44Z45zi9a+TLxykiPVMMuUcCuPre8qi/9jyEtM4MBttYVI/5kAWYFwM/a5nKv+I4zSP4gc7TMk3cwfqG+GNMVgcDEXuTRBjHjT36w+7S6L+fJiIF592kVx5xYAhk6hAozv1tevbvsHV0BpVNE6rwjzyqAZE+GzG/WYk0fpygJhTGZjn0sUZvQtu5dy41+Ylkih+AZFoAnrIZwXygJb5EVRvIbU1q0EXdyXK3RowqSjuZchFpVhfI0qqFbUCYWJCaB+4ydOpJN99fJvxeVfYj4OgvmYrNHt0ofSGA2m64vcw6wufBZhlBa9geP5A1BeXyhu9BWJaaG5xnTgJ06KbJrp4ienwKWGHbPuci4V/ldK8PN9tpT53Ea+NiiPQrHr+hC0/Ss3YU0jnKZGB7KNZtT19B56KvBhpWSCWvt9kxXsbu+Jz2sl6LoqeMzuX5g1zg1iXwRbFLP2LwQTOaadQuMPegiQ4xLYhCyJkgZwFps9ebmNA0KPRojMJJaYdNr9i1l6gLCaYVhhryi3qOvf+SJuQhm6Pz9p31zbbE5k8S7kOXDg6hTWToSW8Zv3/l0WkH1xaKRFYnfn9EP4oRw7jlo1SHLiGMV7LuYrliekZCfwD4nNqhg7yF4s6kHTcChxaifDxD3tFumMxBaI6N0Kx0m+rJV3pEMrHUVNestWpVsbHxWjUgMJnJy2J4leN7+1X7Wn6a3lNYWFtfpOcs96lwyJn6zj05OCuLF/03PFz4aPfbnJXx1wW0Z349QGd0FOV150lgrq82/za5Y6OaW93+bGdnx4W9sZOdiJyKmmbIT3vnh3lBaQ/8dr7sQkRERb1uiEmgMGd7fmWAFEcDsFpD1S57W7a/LiQbPYACcp2OunWPkU0w1QseFpVgZsmeKFxaZPeW0N+3rVzj4azgDzwtvq/0pwMsULZ3QLANqda8kjPHaCDdAjkzgV0kXOZ02djIfxfvNp6ayND2bjVWgTPSmHQ+go4JkuDv297rymxyVeSoE1VmXuxIUMy9QS9k9Hj0YGC9WSnRmUu5ujbd+FPMDA9XBcSRfef1LNrr2kdCh1FYfrBrtVE+WZD0IgST3nNFLsDD4coaBU4A4Y03kggIqWzp5F4ao7F8aOFBYTcIbiYEyqvNsV79yjQaCPMtY3khDTWPQbeLf7Ji9FVtA9KReyIXRXfBWhZ9P/SpI74m8zfV8LRKc7dH1poyfOHDVlzLWzQbU09ecMDJgIyW6ZaLIVmlsPDrHFoiQ0eSTU4ZNh5lwfbsmw0o4CL1GZlqN/N+2YQCOHq/rjFgnhZ6vKsg2+E1r4SyOrWSyvA1kKOMimi/RH5JIGJeUHOmG6K6Q1mYQGnqJ3ZNDni0yItaqeANRpoHOZ6r+JiDuOJCcySjWaHaEb/j8yOCcN9jxr/jj1I6K8OY8hpubD1EGlwB4XYolVRZ804rnBRqsmurz4CcmZWma+0aL+cTcjuSynFo5cJbgKdlNl93QxtP7lOHWUA9YUcmExYrfZFatF+x15WoZoUuCbdzPVL4PAidQgeuSkQGJ/5oB7+xXuxNPPuEp321jY7JeuNpJoptVp2zfO8F3GeMkFZRagPS7iZovFvV5lCL87rwfB+7wlBRYV6T6lMg8dWQgz4cLK0UTPTFDl1vGzLiS9SFiwRLQajWYdo0VUaSTJ1b1Mfm1AH+91FLKxECMtf5yvPWGp3NeYf3NPv5rfSFtm0ncZhOpTY4AftfYCtXyhbq/kZ+05gLk3DcR82Xgy34sgO5WLtONX9HHSuITJQKCCdKmNmaz3/ow53UoErKpLIgetL0bRMs4TDpYMc5ERYO4nPvo9G9o9QHxK+H2JTEQb/EXioiSAkj7cUcxhBAvoZAJnzFLLL9L5C6beSR8sHIzMDxM/DYGdv0FPqxwbCfM0f2RXemwfmvpnCAid5Rqsa3tZ/h2iQtlvhST7gdrXR9T/TzM9DhcFywHLoday8K/FA4jd99TWp0PY5w9aD5HlfIjyJuXP6AD3dv0yVkoBDEUYU7ur3Y1OZAdrGEu9GVk2ORq72fap34EiIZGJ1yInONdKCdV/2FtyJHQJNNV+buEqQuvdHyOM16MFXSTXo8Mrd0hTDgJ9/ZEpULmUZ0MVGv/K3N3Lwcy22exFLWbNkE9icZ2ELnm0mD+VVwpACq/zgNXehul8WPuYqhA8t+zOhjNbvHIXWx7z9BZweJONdsmG1MVlk8JsRGHtapfQItxYsVDtcVSYnVfup3b4BoXNB4vcUK6h/sm3EEeF4JnTGrRZbQFWwLYOD8OC1WjQ6iu3QKeNcQ5yCcaeLtqbzlmm5xA6QyQjOGuu9rEMqo+QCnp6D5KAtaHc9ARLj+5L3wN8OziqaATPI6aY9mLssLPw025FkX6IXDXbG9YB9zg0ciOnVibBODVpkuuVFQBmsd0l1wjRFOUpvmD7qY+lN9VOjCVclH988COsn12sflQhAnst+7UXMXwtFIHxSboGp7dgoagW6jg0hbcrfmCr3FshtqKRGFVl38/6HGN+PrQ/HtTk/DOtJEM6SrMgbVgU8swY7iox31m0ODKRBHuZP8tArTA6zx3MkPwu6+WcQeOFU4oOtaD/Yrmda/h9Ysn/g6CasLvjvmCEBU00cbS3TXMOzWAvo45H8Q84+J+EFt/y9kRjhnxnUqPGy4XQlUliteJmnXi4wLhCx17GMO605UWr64EmmOPrjQaoPOLr9H6Isefv0gPL7oF6wJPKoZfFitcw64Id26X0GfFv5rXQveQcIsM6/DKtepaysQidqUPHspWCrAMCeZQpTOTZ3NRFCE6eAs0yadySI8YJuifmggyYSwPX9NsPYVo3nmc4jLxm4WvRLa3OiXzowAJC8ftU6rOCEReD7YMKteOmXw/hZymLTMxwPTDDBMFKZZdPozbNq2I3rTNOLzOf1hCk7Y6v8zTpJdczUyNtAaWexD+I/nTW4JMZ9FNiGkVJN4zhtsA6ftRC5HJYOQUp2788B9dgmMJ0FIwipxoXd90CtCjgtIfUMK992eRMPWNNBqqLX5cITyGDEJqySLPIviWlIKSLIlqtO7iAd8EyBe7OH0f3O4gmu9lyBxgf6/1U7BhH5myfocmdlSrGe6cLDX7iKXlzN3vVk1PljoqMNOYv/1y0NXawTY5qhu9INM8RR1YPHZm/OAou+z8fI81LmjpD4QDdY8Cjav5TXc2+IbplK8jHpiHwPtltpnwwtYXcvIt8RXc0usBaFIBdR2PCrw/m3D8llFyT77J5MhjeU2wgZRcCEO0ZtW1O1v1b1NpUPwl3JXoxoiDtZhGtSzkMJbtZup9iSoOr8855/Ag+Gbp+FumyQdxhICXLBdvtxq9hZMrvcoBoUo17+22FSkEfZRO3SyUt33wO9STAYms64SRXH5sIDy45Msgxskxv3d2EhFBPkjelBB/J98UrlfPbdk9drRdG6+McNmwDX9ho/1qgvaBNn5tHJyLJXOoIeR/eIaVwrbSfyErvOyPEPGvdHpJ6zDu/ziPORChCHd/KQVCDo3Q4iFpKnZULFhLFm8H4sMZPIvTGNn1akMWsYzhg1NRPRpyB8OU4Ulq5uQKgrE/vvMFUXgsg8KV0W+53ZmCdTwopRFEvHH0vOHoGXr1RsD/WgXTZcAIpAzS4gNwm7e807vWEw+4BX3gtHSs6fFYd6tkiMM591Ak/hCMpjcSNjWoNyIssToZMrawHxemZ0i6MRUshU65gwz6rwLsc1oUNZCI50FrRBt6qea4FqzrVT7RAXqorwrkoKgKN8EiQlkdddLggl9j5ixOjqwRtNNRsZ/J4TuR5nmCQ/+047LbmqSeCoSl4EqVM3lBm9OzMOLIkDCfv61mQiaVhRv/8D5tNJjFmQzDC2O0EgMbpmqJ8hfLhDCCw7U+OhtOa8PfSiRClVQHRLilXKxZEkYq6rF18/lxcvbu7jVa3Z/TArr9wTn0uO/SLozueUlP707UiHB/7BlYjookSXzivwFTiXg0GEFYLPpLf2sWHHPFnrC7i5MWoiAZRxymtOTkm5VxqeylKGk1YkttypCpCZGRDH3ZylI1HkDE5GqMeG5hyBJdOIxd0nZXm/PUbjVLZf7TUnEwo2UcHgLjBUVZEy8gDpLVvIHwhXTcJV6BmM5iubsfkKqUt7TB/X14/i20bulM9nnpFyHnoRNvgywiekBMDqPNSoaGKQJP1cEvcumP5fJCxkKeI4DWUgCabNbJfW4CaFri4YL9d8/t+0DwAZ7XTLzKb8lCi2Ydg+dnlNkqzYONjUUzZYlBGsW2b02vsCxgbVZBXuqmIoo5VieBI1H5B6GR3RG1zAYPzhrtATKQ2qi+GA6YkSM0CMHiQKrwr6w0cKWDOy+0U6U2PpQQeZw1Q4eMn8/WS4WLhMlYzo7XZ0uyUJHHM9qC1lshFxF6KEBKxR7hlwzc/5sU6svgOuZaxHtVwijxi9Bc5bTHN0VCPokWYsCRU/JJV+PhQbD+sbap5msAr/33tzjrWZ4z4z2NKxazEMlGFF9oZQNfT92dxchrjkP5uQxFCvc2RiCVLOZPUAbRygO7hsHEkAKuOsZJ2Zf/2CNXlGgQq58axqT0i3HbunKR3BYouAXk4jbKbuxctr46TFE9WqhUtJV2b8WhysjQRtndCWBUOW+aFqaLNgOUDPbURatni+hfk42tzMbFh7MJAK2QRzooGUqeFJLDnPsLoXc1X7bejsmjjzwlN+GCsVjdF86JBkGvIpaBLTiTO+ipT+s/FDNoHd+PO1rzAgY6JnUEeBJTz/1Mi+J0ie8WtkWJ5PVkuGwqnIiac4yr1HedVgCZ03fuc2F026CNiJtCroyQTzq9UaqSvR/1qShTOGCBi7Jqu0YKhU6X2oaa1kWqvKKSITwRs3s7OJlXv5eF+R359f4CK3H3h3A7Ncx61XoImKro/aH9sbIOsLFSoWWn883vC2Zpn/vTVstqSSc/qSrDmn6E6x5rnyNOKnFcjTRMvQZpFOmOZY1Wwp6vPjtM+keoKp/+EmDbzlmK5VX7x61M5+wMWrIAKr/+M0uY6FENLqZ2MWFamrYw1uYq6q1cb173jadQOiJ676MXuAlHb1SlF9+RQ7HCyOj+z2jqlaxp3IHrjYEOPqqH8DunUDdkPTTEMD1jBeJiaE+2lq0EosNWuVizZ6U/fpS6nf6rn339J4SaFg==\"}" + } + ], + "v1": [ + { + "mode": "CBC", + "padding": "Iso10126", + "iterations": 10, + "guid": "6253e902-ce79-4027-bdc4-af51ed970eb5", + "password": "testpassword", + "enc": "OPWBr1rsrvGsbNpIidlztqc0YsPwS0gg51rz6gWlrsJzY+VidziSekuiy7AcxVF42sMcJp9XD41xPsmq0m9yEWrFw6QufwLjSWNE4IK8mD6jIYH35a7fWKbK0LXGq4UIHCfM2W8WVoz/l0QO+JrGrqC3gg8qGyHP3NsVZKVAqG6cGmBi9WEs688U5B0NNGPXPLKE1ZXzHbSd6Pdub1xWv/BEo4RsAu1NySQJpcq3hqo9nLMsza9aiwKH5rG1aMUDu50LNtGs3vCx8ZAkcZpYVp1ZLeoD3pnZVc7siq3kiqJ7zDQoE3FORgD6PuAc6YB2PXW6I3ubw4hkvFMnkIK4/Cc/AEB8RYar6rjmgPVYXSm+ok39sPi9ppIE23k4LkFzz3dUbTM2ub1kKPCUoJLp2E4tUg4hqRidaC7rNxkPyI3lyBWrS8JD457pFYlTWYsUtU1P2sHhxKZuKdeDPQ/Jvo0y+xO5rK9OgmKCg0qxuwaXf4NYu6laqaGEQywRmRyhT1f3E0pQZ371dObo4FOdiVEODhvadPf0FCHjOtuaxWwEkFwyFHVtc0lVNhcy0rg65j2efHpDUXqQnqFBgc2PG23BVI1gY0JIDT5zp33wdFX3r6MjYxSUV7KbRBDwCD0Q3a9NepX9bqv3wpi1qYJ6kcht0iMAE+5WmHHeHWza2HFMXcUApSAU6cu2fzOfK+4gRMJPjNAdk/nVQT1UnWy9k+s6jvwaXBPI10ewaTz5ayRTXyku36N1xLsM6DnBPoJCunuDEXMI5dILgr3BVSCqvzboWsRW04bAfFbpYANioQgdDD5zerygHa61V7ICyD/x5G4li6VLIefsCGGBo+7fU149zYkHv7ruH8F/J26b11UH+gpThimLgenJectT3MnksMFaz8LiSRn6jnz7CMeXssxBoYRT0gvq4MN6JxFGD01HfcqfVuBkWXk8Mo1OE75v3HWovrJOrTXhYbr+JaPppA==" + }, + { + "mode": "OFB", + "padding": "NoPadding", + "iterations": 1, + "guid": "6253e902-ce79-4027-bdc4-af51ed970eb5", + "password": "testpassword", + "enc": "1LbdcPCYTFMr3Yv27kaJ/kqKflbhLMsQJXAL4EyWOzTKiDHmVrO6JTInh0GzXwTcDSJJQw4G614LT7YyfaZLd3+shhFDQycvSLKrnC4wM40CcIE1Ow335YlolV6+WAJAAQ951ipS2cUERXSpxbbDy41AbUG+wIX/R2wCbiosT6OLHjnMSuQWx5CyEB1ZqRUXfc3TYwbh1iCJdBDaPFnmTPN/LpRegC99DFEJ0E94dPim42Q/8KV4mDNvCOUGjLfqsi/3I+M6kGJtzC5CUo0dVZ0bzzTTXEXm7Ga0eo3arCdMQUDPVGcbJbGK8qTcWcHXHw90EJEGBUi6i4p1XXw+26T5k+Qs6Fl7GD3PHl5Urusk4twB5DM/Hwp5vFWnsCsbM78CRhJl3rbheBMx6t1RJKvxpOUrh/OyvOwhWtU6hRXmS/zrwwDqbWiVG9/LzZP19hnAvlTJ0o1jF/Dmz+EoTaotkVHFZDUuYDKfWPY/+K7sQGkagfdv5W1X9rfary22prDUo8kFiRvNHvGMie3TiM1ucSdpBj1DpgfwCxnWzLIeoRl8ZJFUN/V8CkGjpPoyBYZFfjCeGq9+ET0wXL4s9qfNXaHfx2oEuiwcLcDDf71us655hIW6t/OPaPZ3WPhnW4KqrTtL4xduYrisYbhoZkmqJe5Jl110jhiKdNYdvmOcFo764RDPcu2Oa1bszYhGTbRPc45kLauJUAW3e/UUbA87RpAqFnOLH/0vcNMJvcKbvID9A1RSZNjmlerSOptab+yYI97D6EitvFDx9tFMmUrfWFRGs5bOrjiAHobcCqpJ60AivYHPkkkaz8gROz30aqa9Dpz15wplbOVIpKVqf8hly8Bghj5QK4+m2Nf2qALDdBfX+1ZIUh23kiy0s3duWoJQttIyK0AeEU8oHa0MRP5T/ikMatVvw7GVmcDzO8pFBdBxssxReEhnXCpd4nmjcuWbroa+5oaCMWtzXH4I" + }, + { + "mode": "CBC", + "padding": "Iso10126", + "iterations": 1, + "guid": "6253e902-ce79-4027-bdc4-af51ed970eb5", + "password": "testpassword", + "enc": "BuAqphHuJDoKyTIHRXlzlm1ZMVo1NKM9l6fDFldPGOPTobqEG+9RjO9UHLcUO04HAbqogDZdoOxU2cyNM7bi7JYEZDTlfiIYldFkJUP+zGA4Wg+twCS+oOJrv4D8VoKaFl8oAnIns2n8o8MEQscxxkBzjNWoZ3yE6jG1AjtoYt8owrz97S8XFmnSaK3/Q3doTMKFPaRZ7NAR7z0gWI4KaHtfmHMYEsiGy33M4riq3DCyiGGezg+f2IlUUsRj/+VmxZd5KlCpA4ZIG3fPpp19BPj2S3yFdDqZtMjfggo570iHi7eMogFrZAo+yiLJlYSaoWT8fs8vTmnm8pxxRYb1601AmrBnNlPPpvGRNSBiV/rfKdaVqPYygonTBca5fLBA+QQQ8k5HJdiKRjgfJkZWpjexxdXTuLi/bRKYfKOp5GT+fDrgNAv/E56U4rpwpolAQYzJI8XGDF6CZCVJHWAIPqq8XO7sBBofRuGpUoJMZChDoSbVJV12ZYKSo52j/oo+G/e/Rylrydb2u2qte4RdvYQE+Fr9FIX8nR3JUJwXpXx3/rUImPJa+9P9+ySOjRo4zvmh04Zj+C6eGfsLO4GvpKe748d6WrQzTZwzcVmzCeFA0spcDmJaeQ6iB9HKh8yYo5YDWiEiuHw1CIxDb83wnlLepxmk0isEMCIXETNJ+8ns1263kBbYKbt9FyfB8gNrSHEM7tyVc5v03Z++c11+9dSONnLyQArQSLCvnktPQlKm2cb/rRfmbk8ASlCfZkkhn6TR7Ugcvgoj+Sh7fm9LWYISdPx3vmPriplQjvnYnrvBcXoNmJuFmNG6tBgCK8wdbtOCtFw4KS0e8nAOjZ4o0xfNuLv+TmMyyA9xAXRGDEPV+5Z//MAQJc69usAazTaojxicUh0RghUlQOpiqHW5Mbg0tUlkAkCJJYJKfu6elNDslw8l6NwjIvaR7rgdF6JGXbRrX9zl81dAYfyWxJg9Nw==" + } + ] +} diff --git a/tests/wallet_crypto_spec.js.coffee b/tests/wallet_crypto_spec.js.coffee new file mode 100644 index 000000000..d18b0b855 --- /dev/null +++ b/tests/wallet_crypto_spec.js.coffee @@ -0,0 +1,128 @@ + +describe 'WalletCrypto', -> + + WalletCrypto = require('../src/wallet-crypto') + crypto = require('crypto') + walletData = require('./data/wallet-data') + + describe 'decryptWalletSync()', -> + + describe 'wallet v3', -> + walletData.v3.forEach (wallet) -> + it "should decrypt #{wallet.guid}", -> + dec = WalletCrypto.decryptWalletSync(wallet.enc, wallet.password) + expect(dec.guid).toEqual(wallet.guid) + + describe 'legacy wallet v2', -> + walletData.v2.forEach (wallet) -> + it "should decrypt #{wallet.guid}", -> + dec = WalletCrypto.decryptWalletSync(wallet.enc, wallet.password) + expect(dec.guid).toEqual(wallet.guid) + + describe 'legacy wallet v1', -> + walletData.v1.forEach (wallet) -> + it "should decrypt #{wallet.mode}, #{wallet.padding}, #{wallet.iterations} iterations", -> + dec = WalletCrypto.decryptWalletSync(wallet.enc, wallet.password) + expect(dec.guid).toEqual(wallet.guid) + + describe 'encryptWallet()', -> + v3 = walletData.v3[0] + + it 'should encrypt a v3 wallet', -> + spyOn(crypto, 'randomBytes').and.callFake((bytes) -> + salt = new Buffer(v3.iv, 'hex') + padding = new Buffer(v3.pad, 'hex') + return if bytes == 16 then salt else padding + ) + enc = WalletCrypto.encryptWallet(JSON.stringify(v3.data), v3.password, v3.iterations, 3) + expect(enc).toEqual(v3.enc) + + describe 'aes-256', -> + vectors = require('./data/aes-256-vectors') + + ['cbc', 'ofb', 'ecb'].forEach (mode) -> + + describe "#{mode}", -> + key = new Buffer(vectors[mode].key, 'hex') + + opts = + mode: WalletCrypto.AES[mode.toUpperCase()] + padding: WalletCrypto.pad.NoPadding + + vectors[mode].tests.forEach (caseData) -> + enc = undefined + + iv = if caseData.iv then new Buffer(caseData.iv, 'hex') else null + testvector = new Buffer(caseData.testvector, 'hex') + ciphertext = new Buffer(caseData.ciphertext, 'hex') + + it "should encrypt #{caseData.testvector}", -> + enc = WalletCrypto.AES.encrypt(testvector, key, iv, opts) + expect(enc.compare(ciphertext)).toEqual(0) + + it "should decrypt #{caseData.testvector}", -> + dec = WalletCrypto.AES.decrypt(enc, key, iv, opts) + expect(dec.compare(testvector)).toEqual(0) + + describe 'padding', -> + + BLOCK_SIZE_BYTES = 16 + pad = WalletCrypto.pad + input = new Buffer(10).fill(0xff) + + describe 'NoPadding', -> + it 'should not add bytes when padding', -> + output = pad.NoPadding.pad(input, BLOCK_SIZE_BYTES) + expect(output.compare(input)).toEqual(0) + + it 'should not remove bytes when unpadding', -> + output = pad.NoPadding.unpad(input) + expect(output.compare(input)).toEqual(0) + + describe 'ZeroPadding', -> + it 'should fill the remaining block space with 0x00 bytes', -> + output = pad.ZeroPadding.pad(input, BLOCK_SIZE_BYTES) + expect(output.length).toEqual(BLOCK_SIZE_BYTES) + expect(output.toString('hex').match(/(00)+$/)[0].length/2).toEqual(6) + + it 'should remove all trailing 0x00 bytes when unpadding', -> + padded = Buffer.concat([ input, new Buffer(6).fill(0x00) ]) + output = pad.ZeroPadding.unpad(padded) + expect(output.length).toEqual(10) + + it 'should unpad a ZeroPadding padded buffer', -> + output = pad.ZeroPadding.unpad(pad.ZeroPadding.pad(input, BLOCK_SIZE_BYTES)) + expect(output.compare(input)).toEqual(0) + + describe 'Iso10126', -> + it 'should set the last byte to the padding length', -> + output = pad.Iso10126.pad(input, BLOCK_SIZE_BYTES) + expect(output[output.length - 1]).toEqual(0x06) + + it 'should pad using random bytes', -> + spyOn(crypto, 'randomBytes').and.callThrough() + pad.Iso10126.pad(input, BLOCK_SIZE_BYTES) + expect(crypto.randomBytes).toHaveBeenCalledWith(5) + + it 'should unpad based on the last byte', -> + padded = new Buffer(BLOCK_SIZE_BYTES) + padded[padded.length - 1] = 0x07 + output = pad.Iso10126.unpad(padded) + expect(output.length).toEqual(9) + + it 'should unpad an Iso10126 padded buffer', -> + output = pad.Iso97971.unpad(pad.Iso97971.pad(input, BLOCK_SIZE_BYTES)) + expect(output.compare(input)).toEqual(0) + + describe 'Iso97971', -> + it 'should set the first padding byte to 0x80', -> + output = pad.Iso97971.pad(input, BLOCK_SIZE_BYTES) + expect(output[input.length]).toEqual(0x80) + + it 'should pad the rest with 0x00 bytes', -> + output = pad.Iso97971.pad(input, BLOCK_SIZE_BYTES) + expect(output.toString('hex').match(/(00)+$/)[0].length/2).toEqual(5) + + it 'should unpad an Iso97971 padded buffer', -> + output = pad.Iso97971.unpad(pad.Iso97971.pad(input, BLOCK_SIZE_BYTES)) + expect(output.compare(input)).toEqual(0)