Switch from fingerprints to safety numbers

pull/749/head
lilia 9 years ago
parent 7fe708d195
commit f05d693994

@ -468,5 +468,15 @@
"example": "John" "example": "John"
} }
} }
},
"yourSafetyNumberWith": {
"message": "Your safety number with $name$",
"description": "Heading for safety number view",
"placeholders": {
"name": {
"content": "$1",
"example": "John"
}
}
} }
} }

@ -299,26 +299,15 @@
</div> </div>
</script> </script>
<script type='text/x-tmpl-mustache' id='key_verification'> <script type='text/x-tmpl-mustache' id='key_verification'>
<label> {{theirIdentity}} </label> {{ ^has_their_key }}
{{ ^their_key }}
<div class='placeholder'>{{ their_key_unknown }}</div> <div class='placeholder'>{{ their_key_unknown }}</div>
{{ /their_key }} {{ /has_their_key }}
{{ #has_their_key }} {{ #has_their_key }}
<label> {{ yourSafetyNumberWith }} </label>
<div class='key'> <div class='key'>
{{ #their_key }} <span>{{ . }}</span> {{ /their_key }} {{ #chunks }} <span>{{ . }}</span> {{ /chunks }}
</div> </div>
{{ /has_their_key }} {{ /has_their_key }}
<label> {{yourIdentity}} </label>
<div class='key'>
{{ #your_key }} <span>{{ . }}</span> {{ /your_key }}
</div>
<div class='securityNumber'></div>
</script>
<script type='text/x-tmpl-mustache' id='security_number'>
<label> Security number </label>
<div class='key'>
{{ #chunks }} <span>{{ . }}</span> {{ /chunks }}
</div>
</script> </script>
<!-- index --> <!-- index -->
<script type='text/x-tmpl-mustache' id='group_info_input'> <script type='text/x-tmpl-mustache' id='group_info_input'>

@ -259,7 +259,7 @@
} }
if (model) { if (model) {
var view = new Whisper.KeyVerificationPanelView({ var view = new Whisper.KeyVerificationPanelView({
model: { their_number: model.id } model: model
}); });
this.listenBack(view); this.listenBack(view);
} }

@ -14,10 +14,8 @@
this.conversation = options.conversation; this.conversation = options.conversation;
this.render(); this.render();
var view = new Whisper.KeyVerificationView({ var view = new Whisper.KeyVerificationView({
model: { model : this.contact,
their_number: this.model.number, newKey : this.model.identityKey
their_key : this.model.identityKey,
}
}); });
view.$el.appendTo(this.$('.keys')); view.$el.appendTo(this.$('.keys'));
}, },

@ -5,94 +5,64 @@
'use strict'; 'use strict';
window.Whisper = window.Whisper || {}; window.Whisper = window.Whisper || {};
var SecurityNumberView = Whisper.View.extend({
className: 'securityNumber',
templateName: 'security_number',
initialize: function() {
this.generateSecurityNumber();
},
generateSecurityNumber: function() {
new libsignal.FingerprintGenerator(5200).createFor(
this.model.your_number,
this.model.your_key,
this.model.their_number,
this.model.their_key
).then(this.handleSecurityNumber.bind(this));
},
handleSecurityNumber: function(securityNumber) {
this.model.securityNumber = securityNumber;
this.render();
},
render_attributes: function() {
var s = this.model.securityNumber;
var chunks = [];
for (var i = 0; i < s.length; i += 5) {
chunks.push(s.substring(i, i+5));
}
return { chunks: chunks };
}
});
Whisper.KeyVerificationView = Whisper.View.extend({ Whisper.KeyVerificationView = Whisper.View.extend({
className: 'key-verification', className: 'key-verification',
templateName: 'key_verification', templateName: 'key_verification',
initialize: function() { initialize: function(options) {
this.our_number = textsecure.storage.user.getNumber();
if (options.newKey) {
this.their_key = options.newKey;
}
Promise.all([ Promise.all([
this.loadTheirKey(), this.loadTheirKey(),
this.loadOurKey(), this.loadOurKey(),
]).then(function() { ]).then(this.generateSecurityNumber.bind(this))
this.render(); .then(this.render.bind(this));
/*
this.$('.securityNumber').append(
new SecurityNumberView({model: this.model}).el
);
*/
}.bind(this));
},
setOurKey: function(our_key) {
this.model.your_key = our_key;
},
setTheirKey: function(their_key) {
this.model.their_key = their_key;
}, },
loadTheirKey: function() { loadTheirKey: function() {
if (this.model.their_key) { if (this.their_key) {
return Promise.resolve(this.model.their_key); return Promise.resolve(this.their_key);
} else { } else {
return textsecure.storage.protocol.loadIdentityKey( return textsecure.storage.protocol.loadIdentityKey(
this.model.their_number this.model.id
).then(this.setTheirKey.bind(this)); ).then(function(their_key) {
this.their_key = their_key;
}.bind(this));
} }
}, },
loadOurKey: function() { loadOurKey: function() {
if (this.model.your_key) { if (this.our_key) {
return Promise.resolve(this.model.your_key); return Promise.resolve(this.our_key);
} else { } else {
return textsecure.storage.protocol.loadIdentityKey( return textsecure.storage.protocol.loadIdentityKey(
textsecure.storage.user.getNumber() this.our_number
).then(this.setOurKey.bind(this)); ).then(function(our_key) {
this.our_key = our_key;
}.bind(this));
} }
}, },
splitKey: function(key) { generateSecurityNumber: function() {
// key is an array buffer return new libsignal.FingerprintGenerator(5200).createFor(
var bytes = new Uint8Array(key); this.our_number, this.our_key, this.model.id, this.their_key
var octets = []; ).then(function(securityNumber) {
for (var i = 0; i < bytes.byteLength; ++i) { this.securityNumber = securityNumber;
octets.push(('0' + bytes[i].toString(16)).slice(-2)); }.bind(this));
}
return octets;
}, },
render_attributes: function() { render_attributes: function() {
var s = this.securityNumber;
var chunks = [];
for (var i = 0; i < s.length; i += 5) {
chunks.push(s.substring(i, i+5));
}
var yourSafetyNumberWith = i18n(
'yourSafetyNumberWith', this.model.getTitle()
);
return { return {
learnMore : i18n('learnMore'), learnMore : i18n('learnMore'),
verifyIdentity: i18n('verifyIdentity'), their_key_unknown : i18n('theirIdentityUnknown'),
yourIdentity: i18n('yourIdentity'), yourSafetyNumberWith : i18n('yourSafetyNumberWith', this.model.getTitle()),
theirIdentity: i18n('theirIdentity'), has_their_key : this.their_key !== undefined,
their_key_unknown: i18n('theirIdentityUnknown'), chunks : chunks,
your_key: this.splitKey(this.model.your_key),
their_key: this.splitKey(this.model.their_key),
has_their_key: this.model.their_key !== undefined
}; };
} }
}); });

Loading…
Cancel
Save