summary refs log tree commit diff
path: root/synapse/storage
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2014-08-14 14:30:25 +0100
committerErik Johnston <erik@matrix.org>2014-08-14 14:30:25 +0100
commit6d6a1c3454ae787e3878202a8e41341ddcf7bee0 (patch)
tree1376ad1825e21a4a60b190141e862800111bc808 /synapse/storage
parentChange relative db paths to absolute paths in case we daemonize. (diff)
downloadsynapse-6d6a1c3454ae787e3878202a8e41341ddcf7bee0.tar.xz
Actually encode dicts as json in the DB
Diffstat (limited to 'synapse/storage')
-rw-r--r--synapse/storage/__init__.py4
-rw-r--r--synapse/storage/_base.py3
2 files changed, 4 insertions, 3 deletions
diff --git a/synapse/storage/__init__.py b/synapse/storage/__init__.py
index d38d613450..cd9acdc447 100644
--- a/synapse/storage/__init__.py
+++ b/synapse/storage/__init__.py
@@ -81,11 +81,11 @@ class DataStore(RoomDataStore, RoomMemberStore, MessageStore, RoomStore,
             "event_type", event.type,
             "sender": event.user_id,
             "room_id": event.room_id,
-            "content": event.content,
+            "content": json.dumps(event.content),
         }
 
         unrec = {k: v for k, v in event.get_full_dict() if k not in vals.keys()}
-        val["unrecognized_keys"] = unrec
+        val["unrecognized_keys"] = json.dumps(unrec)
 
         yield self._simple_insert("events", vals)
 
diff --git a/synapse/storage/_base.py b/synapse/storage/_base.py
index 489b6bd171..5cb26ad6db 100644
--- a/synapse/storage/_base.py
+++ b/synapse/storage/_base.py
@@ -288,7 +288,8 @@ class SQLBaseStore(object):
 
     def _parse_event_from_row(self, row_dict):
         d = copy.deepcopy({k: v for k, v in row.items() if v})
-        d.update(json.loads(row["unrecognized_keys"]))
+        d.update(json.loads(json.loads(row["unrecognized_keys"])))
+        d["content"] = json.loads(d["content"})
         del d["unrecognized_keys"]
 
         return self.event_factory.create_event(