From 45752625134cb388650c770c156c825c80ff4550 Mon Sep 17 00:00:00 2001 From: Ivan Socolsky Date: Fri, 11 Sep 2015 11:15:46 -0300 Subject: [PATCH] implement check --- lib/storage.js | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/lib/storage.js b/lib/storage.js index 836af12..61dd719 100644 --- a/lib/storage.js +++ b/lib/storage.js @@ -385,13 +385,32 @@ Storage.prototype.fetchAddresses = function(walletId, cb) { Storage.prototype.storeAddressAndWallet = function(wallet, addresses, cb) { var self = this; + var addresses = [].concat(addresses); if (addresses.length == 0) return cb(); - this.db.collection(collections.ADDRESSES).insert(addresses, { - w: 1 - }, function(err) { - if (err) return cb(err); - self.storeWallet(wallet, cb); + + async.filter(addresses, function(address, next) { + self.db.collection(collections.ADDRESSES).findOne({ + address: address.address, + }, { + walletId: true, + }, function(err, result) { + if (err || !result) return next(true); + if (result.walletId != wallet.id) { + log.warn('Address ' + address.address + ' exists in more than one wallet.'); + return next(true); + } + // Ignore if address was already in wallet + return next(false); + }); + }, function(newAddresses) { + if (newAddresses.length == 0) return cb(); + self.db.collection(collections.ADDRESSES).insert(newAddresses, { + w: 1 + }, function(err) { + if (err) return cb(err); + self.storeWallet(wallet, cb); + }); }); };