Skip to content
This repository has been archived by the owner on Mar 7, 2023. It is now read-only.

New mdid #368

Open
wants to merge 48 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
ed6c030
feaat(metadata): compatible with new version of the metadata service
sha49 Nov 22, 2016
0d1118b
feat(shared Metadata): basic functionality
sha49 Nov 22, 2016
8cdc29a
feat(shared Metadata): contacts and sharedMetadata
sha49 Nov 22, 2016
8f9f2c3
test(External): fixed interference with coinify_trade_spec
Sjors Nov 24, 2016
b26107a
feat(shared Metadata): extracted API
sha49 Nov 28, 2016
5ace804
feat(contacts): messaging available
sha49 Nov 30, 2016
ea5d55c
feat(mdid): guid-mdid registration
sha49 Dec 6, 2016
ce70ed2
feat(readInvitation): returns the newly created contact.
sha49 Dec 6, 2016
d9a8640
fix(sharedMetadata): require metadata
kwgithubusername Dec 7, 2016
b87506b
feat(relation): simplified method
sha49 Jan 4, 2017
4be98ef
feat(payment requests)
sha49 Jan 13, 2017
1ade631
feat(PR): payment request address non-reused.
sha49 Jan 16, 2017
6d2736e
fix(digest messages) should wait for all the messages to be digested.
sha49 Jan 26, 2017
02bd491
feat(PR): gap cannot be exceed
sha49 Feb 13, 2017
9fba3b9
feat(Contacts): add last_updated field (#331)
kwgithubusername Feb 15, 2017
7ed7927
typo
sha49 Feb 15, 2017
f814356
fix(): do not mix import styles
sha49 Feb 15, 2017
412ffde
tests(): facilitatedTx and Contact
sha49 Feb 17, 2017
a8ceadd
test()
sha49 Feb 17, 2017
b0e037f
tests(contact class)
sha49 Feb 17, 2017
cf326ee
tests(): contacts_spec
sha49 Feb 17, 2017
32a766e
tests(): contacts_spec
sha49 Feb 17, 2017
bda40ba
fix(lastUpdated): typo
sha49 Feb 20, 2017
7e6fe2d
tests(contacts)
sha49 Feb 20, 2017
8789a3b
more tests
sha49 Feb 21, 2017
273979c
Merge branch 'master' into new-mdid
sha49 Feb 21, 2017
eedab45
feat(digest): returns a promise of all the digested messages
sha49 Feb 21, 2017
cdde251
fix(requests): created and last_updated handling
sha49 Feb 22, 2017
5c3421d
fixed broken tests
sha49 Feb 22, 2017
e8e9002
PRR diesgtion test
sha49 Feb 23, 2017
4ec9f47
feat(requests): cancel and decline support
sha49 Mar 21, 2017
ef36ea7
fix(SharedMetadataAPI): pass JSON container to /share endpoint
kwgithubusername Apr 4, 2017
e29466f
partial contacts-request
sha49 Apr 12, 2017
a96638d
Merge branch 'master' into new-mdid
sha49 Apr 18, 2017
cddad6c
Merge branch 'master' into new-mdid
sha49 Jun 13, 2017
ce0347a
fix partial
sha49 Jun 13, 2017
3cf6642
chore(Build): fix paths to js files
kwgithubusername Jun 13, 2017
07b1ebe
fix(sharedMetadataAPI): update service name
kwgithubusername Jun 13, 2017
5cefda8
fix(Contacts): use label service
kwgithubusername Jun 13, 2017
119d9d8
feat(Contacts): store sender name
kwgithubusername Jun 30, 2017
3e7fe80
feat(Contacts): add initiator source (selected account/imported addre…
kwgithubusername Jul 26, 2017
b16f9d1
feat(Contacts): allow only HD accounts for initiator source
kwgithubusername Jul 26, 2017
2b0be17
fix(Contacts): use decline function in digestDecline
kwgithubusername Jul 28, 2017
ad257f8
Revert "feat(Contacts): store sender name"
kwgithubusername Aug 1, 2017
3402f60
clean(Contacts): remove initiator source except for sending PR from s…
kwgithubusername Aug 1, 2017
8a9a1a9
feat(Contacts): do not change role of PR on digestion if request alre…
kwgithubusername Aug 1, 2017
e0d4ecf
feat(Contacts): expose uuid function for iOS to override
kwgithubusername Aug 2, 2017
836329b
Revert "feat(Contacts): expose uuid function for iOS to override"
kwgithubusername Aug 4, 2017
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions karma.conf.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,9 @@ module.exports = function (config) {
'tests/account_info_spec.js',
'tests/metadata_spec.js',
'tests/exchange_delegate_spec.js',
'tests/contact_spec.js',
'tests/facilitatedTx_spec.js',
'tests/contacts_spec.js',
'tests/labels_spec.js',
'tests/address_hd_spec.js'
]
Expand Down
4 changes: 3 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -48,12 +48,14 @@
"bs58": "2.0.*",
"core-js": "^2.4.1",
"es6-promise": "^3.0.2",
"jwt-decode": "^2.1.0",
"isomorphic-fetch": "^2.2.1",
"pbkdf2": "^3.0.12",
"ramda": "^0.22.1",
"randombytes": "^2.0.1",
"unorm": "^1.4.1",
"ws": "2.0.*"
"ws": "2.0.*",
"uuid": "^3.0.1"
},
"devDependencies": {
"babel-cli": "~6.24.0",
Expand Down
31 changes: 31 additions & 0 deletions src/blockchain-wallet.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ var AccountInfo = require('./account-info');
var Metadata = require('./metadata');
var constants = require('./constants');
var Payment = require('./payment');
var SharedMetadata = require('./sharedMetadata');
var Contacts = require('./contacts');
var Labels = require('./labels');
var Bitcoin = require('bitcoinjs-lib');

Expand Down Expand Up @@ -89,6 +91,7 @@ function Wallet (object) {
this._latestBlock = null;
this._accountInfo = null;
this._external = null;
this._contacts = null;
}

Object.defineProperties(Wallet.prototype, {
Expand Down Expand Up @@ -239,6 +242,10 @@ Object.defineProperties(Wallet.prototype, {
configurable: false,
get: function () { return this._external; }
},
'contacts': {
configurable: false,
get: function () { return this._contacts; }
},
'isEncryptionConsistent': {
configurable: false,
get: function () {
Expand Down Expand Up @@ -828,6 +835,18 @@ Wallet.prototype.fetchAccountInfo = function () {
});
};

Wallet.prototype.loadContacts = function () {
if (this.isDoubleEncrypted === true || !this.isUpgradedToHD) {
return Promise.resolve();
} else {
var masterhdnode = this.hdwallet.getMasterHDNode();
this._contacts = new Contacts(masterhdnode);
const signature = this._contacts._sharedMetadata.signWithMDID(this._guid);
this.MDIDregistration('register-mdid', signature.toString('base64'));
return this._contacts.fetch();
}
};

Wallet.prototype.metadata = function (typeId) {
var masterhdnode = this.hdwallet.getMasterHDNode();
return Metadata.fromMasterHDNode(masterhdnode, typeId);
Expand Down Expand Up @@ -909,6 +928,18 @@ Wallet.prototype.createPayment = function (initialState) {
return new Payment(this, initialState);
};

Wallet.prototype.MDIDregistration = function (method, signedMDID) {
// method: register-mdid / unregister-mdid
var data = {
guid: this._guid,
sharedKey: this._sharedKey,
method: method,
payload: signedMDID,
length: signedMDID.length
};
return API.request('POST', 'wallet', data);
};

Wallet.prototype.cacheMetadataKey = function (secondPassword) {
if (!secondPassword) { return Promise.reject('second password needed'); }
if (!this.validateSecondPassword(secondPassword)) { return Promise.reject('wrong second password'); }
Expand Down
90 changes: 90 additions & 0 deletions src/contact.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
'use strict';

const Bitcoin = require('bitcoinjs-lib');
const Metadata = require('./metadata');
// individual imports to reduce bundle size
const assoc = require('ramda/src/assoc');
const prop = require('ramda/src/prop');
const map = require('ramda/src/map');
const uuid = require('uuid');
const FacilitatedTx = require('./facilitatedTx');

class Contact {
constructor (o) {
this.id = o.id;
this.mdid = o.mdid;
this.name = o.name;
this.xpub = o.xpub;
this.trusted = o.trusted;
this.invitationSent = o.invitationSent; // I invited somebody
this.invitationReceived = o.invitationReceived; // Somebody invited me
this.facilitatedTxList = o.facilitatedTxList ? map(FacilitatedTx.factory, o.facilitatedTxList) : {};
}
get pubKey () {
return this.xpub ? Bitcoin.HDNode.fromBase58(this.xpub).keyPair : null;
}
}

Contact.factory = function (o) {
return new Contact(o);
};

Contact.new = function (o) {
const id = uuid();
const namedContact = assoc('id', id, o);
return new Contact(namedContact);
};

Contact.prototype.fetchXPUB = function () {
return this.mdid
? Metadata.read(this.mdid).then((r) => { this.xpub = r.xpub; return r.xpub; })
: Promise.reject('UNKNOWN_MDID');
};

// create and add a request payment request to that contact facilitated tx list
Contact.prototype.RPR = function (intendedAmount, id, role, note) {
const rpr = FacilitatedTx.RPR(intendedAmount, id, role, note);
this.facilitatedTxList = assoc(id, rpr, this.facilitatedTxList);
return rpr;
};

// create and/or add a payment request to that contact facilitated tx list
Contact.prototype.PR = function (intendedAmount, id, role, address, note) {
var existingTx = prop(id, this.facilitatedTxList);
if (existingTx) {
existingTx.address = address;
existingTx.state = FacilitatedTx.WAITING_PAYMENT;
existingTx.last_updated = Date.now();
return existingTx;
} else {
const pr = FacilitatedTx.PR(intendedAmount, id, role, address, note);
this.facilitatedTxList = assoc(id, pr, this.facilitatedTxList);
return pr;
}
};

// modify the state of facilitated tx to broadcasted
Contact.prototype.PRR = function (txHash, id) {
var existingTx = prop(id, this.facilitatedTxList);
existingTx.tx_hash = txHash;
existingTx.state = FacilitatedTx.PAYMENT_BROADCASTED;
existingTx.last_updated = Date.now();
return existingTx;
};

// modify the state of facilitated tx to declined
Contact.prototype.Decline = function (id) {
var existingTx = prop(id, this.facilitatedTxList);
existingTx.state = FacilitatedTx.DECLINED;
existingTx.last_updated = Date.now();
return existingTx;
};

// modify the state of facilitated tx to Cancelled
Contact.prototype.Cancel = function (id) {
var existingTx = prop(id, this.facilitatedTxList);
existingTx.state = FacilitatedTx.CANCELLED;
existingTx.last_updated = Date.now();
return existingTx;
};
module.exports = Contact;
Loading