]> nmode's Git Repositories - signal-cli/blobdiff - src/main/java/org/asamk/textsecure/JsonSignedPreKeyStore.java
Rename to signal-cli
[signal-cli] / src / main / java / org / asamk / textsecure / JsonSignedPreKeyStore.java
diff --git a/src/main/java/org/asamk/textsecure/JsonSignedPreKeyStore.java b/src/main/java/org/asamk/textsecure/JsonSignedPreKeyStore.java
deleted file mode 100644 (file)
index f890fe8..0000000
+++ /dev/null
@@ -1,114 +0,0 @@
-package org.asamk.textsecure;
-
-import com.fasterxml.jackson.core.JsonGenerator;
-import com.fasterxml.jackson.core.JsonParser;
-import com.fasterxml.jackson.core.JsonProcessingException;
-import com.fasterxml.jackson.databind.*;
-import org.whispersystems.libsignal.InvalidKeyIdException;
-import org.whispersystems.libsignal.state.SignedPreKeyRecord;
-import org.whispersystems.libsignal.state.SignedPreKeyStore;
-
-import java.io.IOException;
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-
-class JsonSignedPreKeyStore implements SignedPreKeyStore {
-
-    private final Map<Integer, byte[]> store = new HashMap<>();
-
-    public JsonSignedPreKeyStore() {
-
-    }
-
-
-    public void addSignedPreKeys(Map<Integer, byte[]> preKeys) {
-        store.putAll(preKeys);
-    }
-
-    @Override
-    public SignedPreKeyRecord loadSignedPreKey(int signedPreKeyId) throws InvalidKeyIdException {
-        try {
-            if (!store.containsKey(signedPreKeyId)) {
-                throw new InvalidKeyIdException("No such signedprekeyrecord! " + signedPreKeyId);
-            }
-
-            return new SignedPreKeyRecord(store.get(signedPreKeyId));
-        } catch (IOException e) {
-            throw new AssertionError(e);
-        }
-    }
-
-    @Override
-    public List<SignedPreKeyRecord> loadSignedPreKeys() {
-        try {
-            List<SignedPreKeyRecord> results = new LinkedList<>();
-
-            for (byte[] serialized : store.values()) {
-                results.add(new SignedPreKeyRecord(serialized));
-            }
-
-            return results;
-        } catch (IOException e) {
-            throw new AssertionError(e);
-        }
-    }
-
-    @Override
-    public void storeSignedPreKey(int signedPreKeyId, SignedPreKeyRecord record) {
-        store.put(signedPreKeyId, record.serialize());
-    }
-
-    @Override
-    public boolean containsSignedPreKey(int signedPreKeyId) {
-        return store.containsKey(signedPreKeyId);
-    }
-
-    @Override
-    public void removeSignedPreKey(int signedPreKeyId) {
-        store.remove(signedPreKeyId);
-    }
-
-    public static class JsonSignedPreKeyStoreDeserializer extends JsonDeserializer<JsonSignedPreKeyStore> {
-
-        @Override
-        public JsonSignedPreKeyStore deserialize(JsonParser jsonParser, DeserializationContext deserializationContext) throws IOException, JsonProcessingException {
-            JsonNode node = jsonParser.getCodec().readTree(jsonParser);
-
-
-            Map<Integer, byte[]> preKeyMap = new HashMap<>();
-            if (node.isArray()) {
-                for (JsonNode preKey : node) {
-                    Integer preKeyId = preKey.get("id").asInt();
-                    try {
-                        preKeyMap.put(preKeyId, Base64.decode(preKey.get("record").asText()));
-                    } catch (IOException e) {
-                        System.out.println(String.format("Error while decoding prekey for: %s", preKeyId));
-                    }
-                }
-            }
-
-            JsonSignedPreKeyStore keyStore = new JsonSignedPreKeyStore();
-            keyStore.addSignedPreKeys(preKeyMap);
-
-            return keyStore;
-
-        }
-    }
-
-    public static class JsonSignedPreKeyStoreSerializer extends JsonSerializer<JsonSignedPreKeyStore> {
-
-        @Override
-        public void serialize(JsonSignedPreKeyStore jsonPreKeyStore, JsonGenerator json, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {
-            json.writeStartArray();
-            for (Map.Entry<Integer, byte[]> signedPreKey : jsonPreKeyStore.store.entrySet()) {
-                json.writeStartObject();
-                json.writeNumberField("id", signedPreKey.getKey());
-                json.writeStringField("record", Base64.encodeBytes(signedPreKey.getValue()));
-                json.writeEndObject();
-            }
-            json.writeEndArray();
-        }
-    }
-}