js

时间:2017-05-24 13:51:51

标签: javascript encryption

您好我尝试使用信号协议进行客户端消息交换(仅用于测试)。但我对proccessPreKey有困难。

这是测试代码

<script src="javascripts/libsignal-protocol.js"></script>
<script src="javascripts/InMemorySignalProtocolStore.js"></script>
<script>
            var KeyHelperUser1 = libsignal.KeyHelper;
            var KeyHelperUser2 = libsignal.KeyHelper;

            var registrationId_User1 = KeyHelperUser1.generateRegistrationId();
            var registrationId_User2 = KeyHelperUser2.generateRegistrationId();
            // Store registrationId somewhere durable and safe.

            var identityKeyPair_User1, identityKeyPair_User2;
            var SignedPreKey_User1, SignedPreKey_User2;

            // Test Store
            var store_User1   = new SignalProtocolStore();
            var store_User2   = new SignalProtocolStore();

            var PreKey_User1, PreKey_User2;

            // Build the session
            var address_User1 = new libsignal.SignalProtocolAddress(1002, 0);
            var address_User2 = new libsignal.SignalProtocolAddress(1001, 0);

            var sessionBuilder_User1 = new libsignal.SessionBuilder(store_User1, address_User1);
            var sessionBuilder_User2 = new libsignal.SessionBuilder(store_User2, address_User2);

            KeyHelperUser1.generateIdentityKeyPair().then(function(identityKeyPair) {
                // keyPair -> { pubKey: ArrayBuffer, privKey: ArrayBuffer }
                // Store identityKeyPair somewhere durable and safe.
                identityKeyPair_User1 = identityKeyPair;

                KeyHelperUser1.generatePreKey(1001).then(function(preKey) {
                    //store.storePreKey(preKey.keyId, preKey.keyPair);
                    PreKey_User1 = preKey;
                    KeyHelperUser2.generatePreKey(1002).then(function(preKey) {
                        //store.storePreKey(preKey.keyId, preKey.keyPair);
                        PreKey_User2 = preKey;
                        KeyHelperUser1.generateSignedPreKey(identityKeyPair_User1, 1001).then(function(signedPreKey) {
                            store_User1.storeSignedPreKey(signedPreKey.keyId, signedPreKey.keyPair);
                            SignedPreKey_User1 = signedPreKey;


                            KeyHelperUser2.generateIdentityKeyPair().then(function(identityKeyPair) {
                                // keyPair -> { pubKey: ArrayBuffer, privKey: ArrayBuffer }
                                // Store identityKeyPair somewhere durable and safe.
                                identityKeyPair_User2 = identityKeyPair;

                                KeyHelperUser2.generateSignedPreKey(identityKeyPair_User2, 1002).then(function(signedPreKey) {
                                    store_User2.storeSignedPreKey(signedPreKey.keyId, signedPreKey.keyPair);
                                    SignedPreKey_User2 = signedPreKey;

                                    var promise_User1 = sessionBuilder_User1.processPreKey({
                                        registrationId: registrationId_User2,
                                        identityKey: identityKeyPair_User2.pubKey,
                                        signedPreKey: {
                                            keyId     : 1002,
                                            publicKey : SignedPreKey_User2.pubKey,
                                            signature : SignedPreKey_User2.signature
                                        },
                                        preKey: {
                                            keyId     : 1002,
                                            publicKey : PreKey_User1.pubKey
                                        }
                                    });

                                    promise_User1.catch(function onerror(error) {
                                        // handle identity key conflict
                                        //console.log(error);
                                    });

                                });
                            });
                        });
                    });
                });


            });
        </script>

我真的不知道processPreKey想要哪些参数。有人可以帮忙吗?

2 个答案:

答案 0 :(得分:5)

嘿所以这是我放在一起的东西,希望它有所帮助。

var KeyHelper = libsignal.KeyHelper;

function generateIdentity(store) {
    return Promise.all([
        KeyHelper.generateIdentityKeyPair(),
        KeyHelper.generateRegistrationId(),
    ]).then(function(result) {
        store.put('identityKey', result[0]);
        store.put('registrationId', result[1]);
    });
}

function generatePreKeyBundle(store, preKeyId, signedPreKeyId) {
    return Promise.all([
        store.getIdentityKeyPair(),
        store.getLocalRegistrationId()
    ]).then(function(result) {
        var identity = result[0];
        var registrationId = result[1];

        return Promise.all([
            KeyHelper.generatePreKey(preKeyId),
            KeyHelper.generateSignedPreKey(identity, signedPreKeyId),
        ]).then(function(keys) {
            var preKey = keys[0]
            var signedPreKey = keys[1];

            store.storePreKey(preKeyId, preKey.keyPair);
            store.storeSignedPreKey(signedPreKeyId, signedPreKey.keyPair);

            return {
                identityKey: identity.pubKey,
                registrationId : registrationId,
                preKey:  {
                    keyId     : preKeyId,
                    publicKey : preKey.keyPair.pubKey
                },
                signedPreKey: {
                    keyId     : signedPreKeyId,
                    publicKey : signedPreKey.keyPair.pubKey,
                    signature : signedPreKey.signature
                }
            };
        });
    });
}

var ALICE_ADDRESS = new libsignal.SignalProtocolAddress("xxxxxxxxx", 1);
var BOB_ADDRESS   = new libsignal.SignalProtocolAddress("yyyyyyyyyyyyy", 1);

    var aliceStore = new libsignal.SignalProtocolStore();

    var bobStore = new libsignal.SignalProtocolStore();
    var bobPreKeyId = 1337;
    var bobSignedKeyId = 1;

    var Curve = libsignal.Curve;

        Promise.all([
            generateIdentity(aliceStore),
            generateIdentity(bobStore),
        ]).then(function() {
            return generatePreKeyBundle(bobStore, bobPreKeyId, bobSignedKeyId);
        }).then(function(preKeyBundle) {
            var builder = new libsignal.SessionBuilder(aliceStore, BOB_ADDRESS);
            return builder.processPreKey(preKeyBundle).then(function() {

              var originalMessage = util.toArrayBuffer("my message ......");
              var aliceSessionCipher = new libsignal.SessionCipher(aliceStore, BOB_ADDRESS);
              var bobSessionCipher = new libsignal.SessionCipher(bobStore, ALICE_ADDRESS);

              aliceSessionCipher.encrypt(originalMessage).then(function(ciphertext) {

                  // check for ciphertext.type to be 3 which includes the PREKEY_BUNDLE
                  return bobSessionCipher.decryptPreKeyWhisperMessage(ciphertext.body, 'binary');

              }).then(function(plaintext) {

                  alert(plaintext);

              });

              bobSessionCipher.encrypt(originalMessage).then(function(ciphertext) {

                  return aliceSessionCipher.decryptWhisperMessage(ciphertext.body, 'binary');

              }).then(function(plaintext) {

                  assertEqualArrayBuffers(plaintext, originalMessage);

              });

            });
        });

答案 1 :(得分:0)

没有足够的代表发表评论;只是解决答案下面的评论。

@Niczem Olaske,可以删除util.toArrayBuffer([message])。返回的密文已经是一个arrayBuffer,并且在加密之前将消息转换为arrayBuffer仍然需要在末尾将其转换回字符串。但是,必须声明一个全局“ util”对象,以使libsignal起作用(至少在JavaScript中)。因此,您只需输入:const util = {};在函数体外部的某个位置,或者:Object.assign(window,{util:{}});在使用libsignal之前。

@Hasib Mahmud,此错误是由于Bob尚未建立会话而试图加密发给Alice的消息所致。如果使用async / await而不是.then(()=> etc ...),则可以避免此问题。鲍勃必须先解密爱丽丝的消息才能与她建立会话,然后再加密发给她的消息。 请注意,他需要使用'decryptPreKeyWhisperMessage'方法,以便在调用该方法时使用其preKey来建立会话。在双方建立会话之后,他可以使用'decryptWhisperMessage'方法。