From: AsamK Date: Tue, 7 Jul 2015 09:04:59 +0000 (+0200) Subject: Actually store preKeys X-Git-Tag: v0.0.2~10 X-Git-Url: https://git.nmode.ca/signal-cli/commitdiff_plain/dbebd38391596cab7581841a8a3eeb34c511c9da Actually store preKeys --- diff --git a/src/main/java/cli/JsonSignedPreKeyStore.java b/src/main/java/cli/JsonSignedPreKeyStore.java index 000a0aa4..5b24c8dc 100644 --- a/src/main/java/cli/JsonSignedPreKeyStore.java +++ b/src/main/java/cli/JsonSignedPreKeyStore.java @@ -34,7 +34,7 @@ public class JsonSignedPreKeyStore implements SignedPreKeyStore { public JSONArray getJson() { JSONArray result = new JSONArray(); for (Integer id : store.keySet()) { - result.put(new JSONObject().put("id", id.toString()).put("record", store.get(id))); + result.put(new JSONObject().put("id", id.toString()).put("record", Base64.encodeBytes(store.get(id)))); } return result; } diff --git a/src/main/java/cli/Manager.java b/src/main/java/cli/Manager.java index 433c43dc..b745988b 100644 --- a/src/main/java/cli/Manager.java +++ b/src/main/java/cli/Manager.java @@ -24,6 +24,7 @@ import org.whispersystems.libaxolotl.InvalidVersionException; import org.whispersystems.libaxolotl.state.PreKeyRecord; import org.whispersystems.libaxolotl.state.SignedPreKeyRecord; import org.whispersystems.libaxolotl.util.KeyHelper; +import org.whispersystems.libaxolotl.util.Medium; import org.whispersystems.libaxolotl.util.guava.Optional; import org.whispersystems.textsecure.api.TextSecureAccountManager; import org.whispersystems.textsecure.api.TextSecureMessagePipe; @@ -137,13 +138,21 @@ public class Manager { //accountManager.setGcmId(Optional.of(GoogleCloudMessaging.getInstance(this).register(REGISTRATION_ID))); registered = true; + int start = 0; List oneTimePreKeys = KeyHelper.generatePreKeys(start, 100); + for (int i = start; i < oneTimePreKeys.size(); i++) { + axolotlStore.storePreKey(i, oneTimePreKeys.get(i)); + } + PreKeyRecord lastResortKey = KeyHelper.generateLastResortPreKey(); + axolotlStore.storePreKey(Medium.MAX_VALUE, lastResortKey); + int signedPreKeyId = 0; SignedPreKeyRecord signedPreKeyRecord; try { signedPreKeyRecord = KeyHelper.generateSignedPreKey(axolotlStore.getIdentityKeyPair(), signedPreKeyId); + axolotlStore.storeSignedPreKey(signedPreKeyId, signedPreKeyRecord); } catch (InvalidKeyException e) { // Should really not happen System.out.println("invalid key");