aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts
diff options
context:
space:
mode:
authorDan Finlay <dan@danfinlay.com>2016-10-13 11:03:14 +0800
committerDan Finlay <dan@danfinlay.com>2016-10-13 11:07:46 +0800
commitcce8d9e3600e8ba0ced12013b0b208fff9f9c8a8 (patch)
treeb045e8c58f074ced7b4208bc093de35b1addabb3 /app/scripts
parentcd2c00a31873490c9129023abb35dd7983604b60 (diff)
downloadtangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar.gz
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar.bz2
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar.lz
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar.xz
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.tar.zst
tangerine-wallet-browser-cce8d9e3600e8ba0ced12013b0b208fff9f9c8a8.zip
Began adding browser-native encryptor module
Added new Qunit build process that will browserify the contents of `test/integration/lib` into the QUnit browser, allowing much more modular testing, including unit testing of our modules in our target browsers. Made a basic unit test file of this form for the new encryptor module, which fails miserably because I've only just begun to work with it. I've started with this blog post as a starting point, and will be adjusting it to our needs from there: http://qnimate.com/passphrase-based-encryption-using-web-cryptography-api/
Diffstat (limited to 'app/scripts')
-rw-r--r--app/scripts/lib/encryptor.js51
1 files changed, 51 insertions, 0 deletions
diff --git a/app/scripts/lib/encryptor.js b/app/scripts/lib/encryptor.js
new file mode 100644
index 000000000..607825764
--- /dev/null
+++ b/app/scripts/lib/encryptor.js
@@ -0,0 +1,51 @@
+var vector = global.crypto.getRandomValues(new Uint8Array(16))
+var key = null
+
+module.exports = {
+ encrypt,
+ decrypt,
+ convertArrayBufferViewtoString,
+ keyFromPassword,
+}
+
+// Takes a Pojo, returns encrypted text.
+function encrypt (password, dataObj) {
+ var data = JSON.stringify(dataObj)
+ global.crypto.subtle.encrypt({name: 'AES-CBC', iv: vector}, key, convertStringToArrayBufferView(data)).then(function(result){
+ const encryptedData = new Uint8Array(result)
+ return encryptedData
+ },
+ function(e){
+ console.log(e.message)
+ })
+}
+
+// Takes encrypted text, returns the restored Pojo.
+function decrypt (password, text) {
+
+}
+
+function convertStringToArrayBufferView (str) {
+ var bytes = new Uint8Array(str.length)
+ for (var i = 0; i < str.length; i++) {
+ bytes[i] = str.charCodeAt(i)
+ }
+
+ return bytes
+}
+
+function convertArrayBufferViewtoString (buffer) {
+ var str = ''
+ for (var i = 0; i < buffer.byteLength; i++) {
+ str += String.fromCharCode(buffer[i])
+ }
+
+ return str
+}
+
+function keyFromPassword (password) {
+ global.crypto.subtle.digest({name: 'SHA-256'}, convertStringToArrayBufferView(password)).then(function(result){
+ return global.crypto.subtle.importKey('raw', result, {name: 'AES-CBC'}, false, ['encrypt', 'decrypt'])
+ })
+}
+