diff options
author | Magnus Ahltorp <map@kth.se> | 2015-09-29 10:30:28 +0200 |
---|---|---|
committer | Linus Nordberg <linus@nordu.net> | 2015-11-11 13:32:37 +0100 |
commit | de81352a53bc78b3c84143d77615662717b9d157 (patch) | |
tree | 04b599a1ca9e5fb2cda7eb0ab20a8cb054db77cb /src/db.erl | |
parent | c7094dd2108a9583f7704c156ae34264edf26090 (diff) |
Make it possible to send several entries at once with merge/sendentry
Diffstat (limited to 'src/db.erl')
-rw-r--r-- | src/db.erl | 19 |
1 files changed, 16 insertions, 3 deletions
@@ -7,7 +7,7 @@ %% API. -export([start_link/0, stop/0]). -export([create_size_table/0]). --export([add/2, add_entryhash/2, set_treesize/1, size/0]). +-export([add_entry_sync/2, add_entry_nosync/2, sync_entry_db/0, add_entryhash/2, set_treesize/1, size/0]). -export([add_index_nosync_noreverse/2]). -export([verifiedsize/0, set_verifiedsize/1]). -export([sendsth_verified/0, set_sendsth_verified/2]). @@ -75,14 +75,27 @@ stop() -> %%%%%%%%%%%%%%%%%%%% %% Public API. --spec add(binary(), binary()) -> ok. -add(LeafHash, Data) -> +-spec add_entry_sync(binary(), binary()) -> ok. +add_entry_sync(LeafHash, Data) -> lager:debug("add leafhash ~s", [mochihex:to_hex(LeafHash)]), ok = perm:addvalue(entry_db, LeafHash, Data), perm:commit(entry_db), lager:debug("leafhash ~s added", [mochihex:to_hex(LeafHash)]), ok. +-spec add_entry_nosync(binary(), binary()) -> ok. +add_entry_nosync(LeafHash, Data) -> + lager:debug("add leafhash ~s", [mochihex:to_hex(LeafHash)]), + ok = perm:addvalue(entry_db, LeafHash, Data), + lager:debug("leafhash ~s added", [mochihex:to_hex(LeafHash)]), + ok. + +sync_entry_db() -> + lager:debug("committing entry db"), + perm:commit(entry_db), + lager:debug("committed entry db"), + ok. + -spec add_entryhash(binary(), binary()) -> ok | differ. add_entryhash(LeafHash, EntryHash) -> perm:addvalue(entryhash_db, EntryHash, LeafHash). |