aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib/getObjStructure.js
diff options
context:
space:
mode:
authorFrankie <frankie.diamond@gmail.com>2018-04-06 06:03:53 +0800
committerGitHub <noreply@github.com>2018-04-06 06:03:53 +0800
commit2dfa8a2e5049c21b30f6b70d06d0cfd56097904a (patch)
treeff7f5b0b7e3615193765929527875f1324371baa /app/scripts/lib/getObjStructure.js
parent17931698a8bb2be77ea9671708135bba79ad2296 (diff)
parentffc71ff7d2c27d419bff4ca127ed5219bf9261c3 (diff)
downloadtangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar.gz
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar.bz2
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar.lz
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar.xz
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.tar.zst
tangerine-wallet-browser-2dfa8a2e5049c21b30f6b70d06d0cfd56097904a.zip
Merge pull request #3900 from MetaMask/migration-error-report
migrations - report migrations errors to sentry with vault structure
Diffstat (limited to 'app/scripts/lib/getObjStructure.js')
-rw-r--r--app/scripts/lib/getObjStructure.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/app/scripts/lib/getObjStructure.js b/app/scripts/lib/getObjStructure.js
new file mode 100644
index 000000000..3db389507
--- /dev/null
+++ b/app/scripts/lib/getObjStructure.js
@@ -0,0 +1,33 @@
+const clone = require('clone')
+
+module.exports = getObjStructure
+
+// This will create an object that represents the structure of the given object
+// it replaces all values with the result of their type
+
+// {
+// "data": {
+// "CurrencyController": {
+// "conversionDate": "number",
+// "conversionRate": "number",
+// "currentCurrency": "string"
+// }
+// }
+
+function getObjStructure(obj) {
+ const structure = clone(obj)
+ return deepMap(structure, (value) => {
+ return value === null ? 'null' : typeof value
+ })
+}
+
+function deepMap(target = {}, visit) {
+ Object.entries(target).forEach(([key, value]) => {
+ if (typeof value === 'object' && value !== null) {
+ target[key] = deepMap(value, visit)
+ } else {
+ target[key] = visit(value)
+ }
+ })
+ return target
+}