Changed repositories to work with SQLDroid, which seems to have very limited support for blobs, at least it didn't work when I used stream.
This commit is contained in:
		| @@ -96,16 +96,17 @@ public class JdbcAddressRepository extends JdbcHelper implements AddressReposito | ||||
|             ResultSet rs = stmt.executeQuery("SELECT address, alias, public_key, private_key, subscribed FROM Address WHERE " + where); | ||||
|             while (rs.next()) { | ||||
|                 BitmessageAddress address; | ||||
|                 Blob privateKeyBlob = rs.getBlob("private_key"); | ||||
|                 if (privateKeyBlob != null) { | ||||
|                     PrivateKey privateKey = PrivateKey.read(privateKeyBlob.getBinaryStream()); | ||||
|  | ||||
|                 byte[] privateKeyBytes = rs.getBytes("private_key"); | ||||
|                 if (privateKeyBytes != null) { | ||||
|                     PrivateKey privateKey = PrivateKey.read(new ByteArrayInputStream(privateKeyBytes)); | ||||
|                     address = new BitmessageAddress(privateKey); | ||||
|                 } else { | ||||
|                     address = new BitmessageAddress(rs.getString("address")); | ||||
|                     Blob publicKeyBlob = rs.getBlob("public_key"); | ||||
|                     if (publicKeyBlob != null) { | ||||
|                     byte[] publicKeyBytes = rs.getBytes("public_key"); | ||||
|                     if (publicKeyBytes != null) { | ||||
|                         Pubkey pubkey = Factory.readPubkey(address.getVersion(), address.getStream(), | ||||
|                                 publicKeyBlob.getBinaryStream(), (int) publicKeyBlob.length(), false); | ||||
|                                 new ByteArrayInputStream(publicKeyBytes), publicKeyBytes.length, false); | ||||
|                         if (address.getVersion() == 4 && pubkey instanceof V3Pubkey) { | ||||
|                             pubkey = new V4Pubkey((V3Pubkey) pubkey); | ||||
|                         } | ||||
| @@ -179,8 +180,7 @@ public class JdbcAddressRepository extends JdbcHelper implements AddressReposito | ||||
|         if (data != null) { | ||||
|             ByteArrayOutputStream out = new ByteArrayOutputStream(); | ||||
|             data.writeUnencrypted(out); | ||||
|             ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray()); | ||||
|             ps.setBlob(parameterIndex, in); | ||||
|             ps.setBytes(parameterIndex, out.toByteArray()); | ||||
|         } else { | ||||
|             ps.setBlob(parameterIndex, (Blob) null); | ||||
|         } | ||||
|   | ||||
| @@ -82,8 +82,7 @@ abstract class JdbcHelper { | ||||
|         if (data != null) { | ||||
|             ByteArrayOutputStream os = new ByteArrayOutputStream(); | ||||
|             data.write(os); | ||||
|             byte[] bytes = os.toByteArray(); | ||||
|             ps.setBinaryStream(parameterIndex, new ByteArrayInputStream(bytes), bytes.length); | ||||
|             ps.setBytes(parameterIndex, os.toByteArray()); | ||||
|         } else { | ||||
|             ps.setBlob(parameterIndex, (Blob) null); | ||||
|         } | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import ch.dissem.bitmessage.ports.Inventory; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| import java.io.ByteArrayInputStream; | ||||
| import java.sql.*; | ||||
| import java.util.LinkedList; | ||||
| import java.util.List; | ||||
| @@ -78,8 +79,8 @@ public class JdbcInventory extends JdbcHelper implements Inventory { | ||||
|             Statement stmt = connection.createStatement(); | ||||
|             ResultSet rs = stmt.executeQuery("SELECT data, version FROM Inventory WHERE hash = X'" + vector + "'"); | ||||
|             if (rs.next()) { | ||||
|                 Blob data = rs.getBlob("data"); | ||||
|                 return Factory.getObjectMessage(rs.getInt("version"), data.getBinaryStream(), (int) data.length()); | ||||
|                 byte[] data = rs.getBytes("data"); | ||||
|                 return Factory.getObjectMessage(rs.getInt("version"), new ByteArrayInputStream(data), data.length); | ||||
|             } else { | ||||
|                 LOG.info("Object requested that we don't have. IV: " + vector); | ||||
|                 return null; | ||||
| @@ -107,8 +108,8 @@ public class JdbcInventory extends JdbcHelper implements Inventory { | ||||
|             ResultSet rs = stmt.executeQuery(query.toString()); | ||||
|             List<ObjectMessage> result = new LinkedList<>(); | ||||
|             while (rs.next()) { | ||||
|                 Blob data = rs.getBlob("data"); | ||||
|                 result.add(Factory.getObjectMessage(rs.getInt("version"), data.getBinaryStream(), (int) data.length())); | ||||
|                 byte[] data = rs.getBytes("data"); | ||||
|                 result.add(Factory.getObjectMessage(rs.getInt("version"), new ByteArrayInputStream(data), data.length)); | ||||
|             } | ||||
|             return result; | ||||
|         } catch (Exception e) { | ||||
|   | ||||
| @@ -25,6 +25,7 @@ import ch.dissem.bitmessage.ports.MessageRepository; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| import java.io.ByteArrayInputStream; | ||||
| import java.io.IOException; | ||||
| import java.sql.*; | ||||
| import java.util.ArrayList; | ||||
| @@ -106,9 +107,9 @@ public class JdbcMessageRepository extends JdbcHelper implements MessageReposito | ||||
|             ResultSet rs = stmt.executeQuery("SELECT id, iv, type, sender, recipient, data, sent, received, status FROM Message WHERE " + where); | ||||
|             while (rs.next()) { | ||||
|                 byte[] iv = rs.getBytes("iv"); | ||||
|                 Blob data = rs.getBlob("data"); | ||||
|                 byte[] data = rs.getBytes("data"); | ||||
|                 Plaintext.Type type = Plaintext.Type.valueOf(rs.getString("type")); | ||||
|                 Plaintext.Builder builder = Plaintext.readWithoutSignature(type, data.getBinaryStream()); | ||||
|                 Plaintext.Builder builder = Plaintext.readWithoutSignature(type, new ByteArrayInputStream(data)); | ||||
|                 long id = rs.getLong("id"); | ||||
|                 builder.id(id); | ||||
|                 builder.IV(new InventoryVector(iv)); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user