Skip to content

Commit

Permalink
adds escrow clearing (WebOfTrust#864)
Browse files Browse the repository at this point in the history
* adds escrow clearing, moves original escrow command to 'escrow list'

Signed-off-by: Kevin Griffin <[email protected]>

* fix: add qnfs database to clear escrow

---------

Signed-off-by: Kevin Griffin <[email protected]>
Co-authored-by: Kent Bull <[email protected]>
  • Loading branch information
m00sey and kentbull authored Oct 4, 2024
1 parent e7bcfee commit d41831f
Show file tree
Hide file tree
Showing 7 changed files with 187 additions and 19 deletions.
8 changes: 6 additions & 2 deletions src/keri/app/cli/commands/clean.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,9 +47,13 @@ def __init__(self, args):
super(CleanDoer, self).__init__()

def recur(self, tyme):

hby = existing.setupHby(name=self.args.name, base=self.args.base,
bran=self.args.bran, temp=self.args.temp)

print("Clearing escrows...")
hby.db.clearEscrows()
print("Finished")

print("Migrating...")
hby.db.migrate()
print("Finished")
Expand All @@ -59,6 +63,6 @@ def recur(self, tyme):

print("Database open, performing clean...")
hby.db.clean()
print("Finished.")
print("Finished")

return True
3 changes: 3 additions & 0 deletions src/keri/app/cli/commands/escrow/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import argparse

parser = argparse.ArgumentParser(description="A collection of escrow operations")
52 changes: 52 additions & 0 deletions src/keri/app/cli/commands/escrow/clear.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# -*- encoding: utf-8 -*-
"""
KERI
keri.kli.commands.escrow module
"""
import argparse

from hio import help
from hio.base import doing
from keri.app.cli.common import existing

logger = help.ogler.getLogger()

parser = argparse.ArgumentParser(description='Clear escrows')
parser.set_defaults(handler=lambda args: handler(args),
transferable=True)
parser.add_argument('--name', '-n', help='keystore name and file location of KERI keystore', required=True)
parser.add_argument('--base', '-b', help='additional optional prefix to file location of KERI keystore',
required=False, default="")
parser.add_argument('--passcode', '-p', help='21 character encryption passcode for keystore (is not saved)',
dest="bran", default=None) # passcode => bran
parser.add_argument('--force', action="store_true", required=False,
help='True means perform clear without prompting the user')


def handler(args):
if not args.force:
print()
print("This command will clear all escrows and is not reversible.")
print()
yn = input("Are you sure you want to continue? [y|N]: ")

if yn not in ("y", "Y"):
print("...exiting")
return []

kwa = dict(args=args)
return [doing.doify(clear, **kwa)]


def clear(tymth, tock=0.0, **opts):
""" Command line clear handler
"""
_ = (yield tock)
args = opts["args"]
name = args.name
base = args.base
bran = args.bran

with existing.existingHby(name=name, base=base, bran=bran) as hby:
hby.db.clearEscrows()
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# -*- encoding: utf-8 -*-
"""
KERI
keri.kli.commands module
keri.kli.commands.escrow module
"""
import argparse
Expand Down
26 changes: 26 additions & 0 deletions src/keri/db/basing.py
Original file line number Diff line number Diff line change
Expand Up @@ -1367,6 +1367,32 @@ def migrate(self):

self.version = keri.__version__

def clearEscrows(self):
"""
Clear all escrows
"""
for (k, _) in self.getUreItemIter():
self.delUres(key=k)
for (k, _) in self.getVreItemIter():
self.delVres(key=k)
for (k, _) in self.getPseItemIter():
self.delPses(key=k)
for (k, _) in self.getPweItemIter():
self.delPwes(key=k)
for (k, _) in self.getUweItemIter():
self.delUwes(key=k)
for (k, _) in self.getOoeItemIter():
self.delOoes(key=k)
for (k, _) in self.getLdeItemIter():
self.delLdes(key=k)
for (pre, said), edig in self.qnfs.getItemIter():
self.qnfs.rem(keys=(pre, said))


for escrow in [self.qnfs, self.misfits, self.delegables, self.pdes, self.udes, self.rpes, self.epsd, self.eoobi,
self.dpub, self.gpwe, self.gdee, self.dpwe, self.gpse, self.epse, self.dune]:
escrow.trim()

@property
def current(self):
""" Current property determines if we are at the current database migration state.
Expand Down
2 changes: 1 addition & 1 deletion tests/app/cli/test_kli_commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -239,7 +239,7 @@ def test_standalone_kli_commands(helpers, capsys):
'\t3. DEMwUl3u8mJ-cWxSnReA0rQesIgZ8SFoHp0U2WyiZjRt\n'
'\n')

args = parser.parse_args(["escrow", "--name", "test"])
args = parser.parse_args(["escrow", "list", "--name", "test"])
assert args.handler is not None
doers = args.handler(args)
directing.runController(doers=doers)
Expand Down
113 changes: 98 additions & 15 deletions tests/db/test_basing.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,28 +7,23 @@
import os
from dataclasses import dataclass, asdict

import lmdb
import pytest
from hio.base import doing

from keri.help.helping import datify, dictify

import lmdb
from hio.base import doing
from keri import core
from keri.app import habbing
from keri.core import coring, eventing, serdering

from keri.core.coring import Kinds, versify

from keri.core.coring import Kinds, versify, Seqner
from keri.core.eventing import incept, rotate, interact, Kever

from keri.app import habbing

from keri.core.serdering import Serder
from keri.db import basing
from keri.db import dbing
from keri.db import subing
from keri.db.basing import openDB, Baser, KeyStateRecord
from keri.db.basing import openDB, Baser, KeyStateRecord, OobiRecord
from keri.db.dbing import (dgKey, onKey, snKey)
from keri.db.dbing import openLMDB

from keri.help.helping import datify, dictify
# this breaks when running as __main__ better to do a custom import call to
# walk the directory tree and import explicity rather than depend on it
# being a known package. Works with pytest because pytest contructs a path
Expand Down Expand Up @@ -185,9 +180,6 @@ def test_baser():
assert actual.local == record.local
assert db.esrs.get(key) == record




# test first seen event log .fels sub db
preA = b'BAKY1sKmgyjAiUDdUBPNPyrSz_ad_Qf9yzhDNZlEKiMc'
preB = b'EH7Oq9oxCgYa-nnNLvwhp9sFZpALILlRYyB-6n4WDi7w'
Expand Down Expand Up @@ -1824,6 +1816,97 @@ def test_KERI_BASER_MAP_SIZE_handles_bad_values(caplog):
os.environ.pop("KERI_BASER_MAP_SIZE")


def test_clear_escrows():
with openDB() as db:
key = b'A'
vals = [b"z", b"m", b"x", b"a"]

db.putUres(key, vals)
db.putVres(key, vals)
db.putPses(key, vals)
db.putPwes(key, vals)
db.putUwes(key, vals)
db.putOoes(key, vals)
db.putLdes(key, vals)

pre = b'k'
snh = b'snh'
saidb = b'saidb'
db.qnfs.add(keys=(pre, saidb), val=b"z")
assert db.qnfs.cnt(keys=(pre, saidb)) == 1

db.misfits.add(keys=(pre, snh), val=saidb)
assert db.misfits.cnt(keys=(pre, snh)) == 1

db.delegables.add(snKey(pre, 0), saidb)
assert db.delegables.cnt(keys=snKey(pre, 0)) == 1

db.pdes.addOn(keys=pre, on=0, val=saidb)
assert db.pdes.cnt(keys=snKey(pre, 0)) == 1

udesKey = dgKey('DAzwEHHzq7K0gzQPYGGwTmuupUhPx5_yZ-Wk1x4ejhcc'.encode("utf-8"),
'EGAPkzNZMtX-QiVgbRbyAIZGoXvbGv9IPb0foWTZvI_4'.encode("utf-8"))
db.udes.put(keys=udesKey, val=(coring.Seqner(qb64b=b'0AAAAAAAAAAAAAAAAAAAAAAB'),
coring.Saider(qb64b=b'EALkveIFUPvt38xhtgYYJRCCpAGO7WjjHVR37Pawv67E')))
assert db.udes.get(keys=udesKey) is not None

saider = coring.Saider(qb64b='EGAPkzNZMtX-QiVgbRbyAIZGoXvbGv9IPb0foWTZvI_4')
db.rpes.put(keys=('route',), vals=[saider])
assert db.rpes.cnt(keys=('route',)) == 1

db.epsd.put(keys=('DAzwEHHzq7K0gzQPYGGwTmuupUhPx5_yZ-Wk1x4ejhcc',), val=coring.Dater())
assert db.epsd.get(keys=('DAzwEHHzq7K0gzQPYGGwTmuupUhPx5_yZ-Wk1x4ejhcc',)) is not None

db.eoobi.pin(keys=('url',), val=OobiRecord())
assert db.eoobi.cntAll() == 1

serder = Serder(raw=b'{"v":"KERI10JSON0000cb_","t":"ixn","d":"EG8WAmM29ZBdoXbnb87yiPxQw4Y7gcQjqZS74vBAKsRm","i":"DApYGFaqnrALTyejaJaGAVhNpSCtqyerPqWVK9ZBNZk0","s":"4","p":"EAskHI462CuIMS_gNkcl_QewzrRSKH2p9zHQIO132Z30","a":[]}')
db.dpub.put(keys=(pre, 'said'), val=serder)
assert db.dpub.get(keys=(pre, 'said')) is not None

db.gpwe.add(keys=(pre,), val=(coring.Seqner(qb64b=b'0AAAAAAAAAAAAAAAAAAAAAAB'), saider))
assert db.gpwe.cnt(keys=(pre,)) == 1

db.gdee.add(keys=(pre,), val=(coring.Seqner(qb64b=b'0AAAAAAAAAAAAAAAAAAAAAAB'), saider))
assert db.gdee.cnt(keys=(pre,)) == 1

db.dpwe.pin(keys=(pre, 'said'), val=serder)
assert db.dpwe.get(keys=(pre, 'said')) is not None

db.gpse.add(keys=('qb64',), val=(coring.Seqner(qb64b=b'0AAAAAAAAAAAAAAAAAAAAAAB'), saider))
assert db.gpse.cnt(keys=('qb64',)) == 1

db.epse.put(keys=('dig',), val=serder)
assert db.epse.get(keys=('dig',)) is not None

db.dune.pin(keys=(pre, 'said'), val=serder)
assert db.dune.get(keys=(pre, 'said')) is not None

db.clearEscrows()

assert db.getUres(key) == []
assert db.getVres(key) == []
assert db.getPses(key) == []
assert db.getPwes(key) == []
assert db.getUwes(key) == []
assert db.getOoes(key) == []
assert db.getLdes(key) == []
assert db.qnfs.cnt(keys=(pre, saidb)) == 0
assert db.misfits.cnt(keys=(pre, snh)) == 0
assert db.delegables.cnt(keys=snKey(pre, 0)) == 0
assert db.pdes.cnt(keys=snKey(pre, 0)) == 0
assert db.udes.get(keys=udesKey) is None
assert db.rpes.cnt(keys=('route',)) == 0
assert db.epsd.get(keys=('DAzwEHHzq7K0gzQPYGGwTmuupUhPx5_yZ-Wk1x4ejhcc',)) is None
assert db.eoobi.cntAll() == 0
assert db.dpub.get(keys=(pre, 'said')) is None
assert db.gpwe.cnt(keys=(pre,)) == 0
assert db.gdee.cnt(keys=(pre,)) == 0
assert db.dpwe.get(keys=(pre, 'said')) is None
assert db.gpse.cnt(keys=('qb64',)) == 0
assert db.epse.get(keys=('dig',)) is None
assert db.dune.get(keys=(pre, 'said')) is None

if __name__ == "__main__":
test_baser()
test_clean_baser()
Expand Down

0 comments on commit d41831f

Please sign in to comment.