Skip to content

Commit

Permalink
B64IoDupSuber class and tests
Browse files Browse the repository at this point in the history
  • Loading branch information
SmithSamuelM committed Dec 7, 2024
1 parent e8dc2b4 commit 550b478
Show file tree
Hide file tree
Showing 4 changed files with 341 additions and 7 deletions.
2 changes: 1 addition & 1 deletion src/keri/db/basing.py
Original file line number Diff line number Diff line change
Expand Up @@ -2380,7 +2380,7 @@ def getUreLast(self, key):

def getUreItemIter(self, key=b''):
"""
Use sgKey()
Use snKey()
Return iterator of partial signed escrowed event triple items at next
key after key.
Items is (key, val) where proem has already been stripped from val
Expand Down
81 changes: 76 additions & 5 deletions src/keri/db/subing.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,8 @@
OnIoDupSuber provides set of insertion ordered values where the where trailing
part of key is serialized ordinal number so that the ordering within each
key prefix is monotonically increasing numeric.
key prefix is monotonically increasing numeric. Useful to provide omndices
for sn ordering of superseding KEL events.
Each of these base types for managing the key space may be mixed with other
Classes that provide different types of values these include.
Expand Down Expand Up @@ -638,6 +639,10 @@ class B64SuberBase(SuberBase):
db (dbing.LMDBer): base LMDB db
sdb (lmdb._Database): instance of lmdb named sub db for this Suber
sep (str): separator for combining keys tuple of strs into key bytes
for db key and also used to convert val iterator to val bytes
Must not be Base64 character.
default is self.Sep == '.'
"""

def __init__(self, *pa, **kwa):
Expand Down Expand Up @@ -759,8 +764,6 @@ class B64Suber(B64SuberBase, Suber):
.sep must not be Base64 character.
Each key consistes of pre joined with .sep to ordinal suffix
Assumes dupsort==False
"""
Expand All @@ -775,6 +778,7 @@ def __init__(self, *pa, **kwa):
each key. Set to False
sep (str): separator to convert keys iterator to key bytes for db key
default is self.Sep == '.'
also used to convert val iterator to val bytes
Must not be Base64 character.
verify (bool): True means reverify when ._des from db when applicable
False means do not reverify. Default False
Expand Down Expand Up @@ -2158,13 +2162,44 @@ def getItemIter(self, keys: str | bytes | memoryview | Iterable = "",
yield (self._tokeys(key), self._des(val))


class B64IoDupSuber(B64SuberBase, IoDupSuber):
"""
Subclass of B64SuberBase and IoDupSuber that serializes and deserializes
values as .sep joined strings of Base64 components in insertion ordered
duplicates with leading value proem. Proem + .sep joined value and must fit
in 511 bytes of keyspace as duplicate
Assumes dupsort==True
"""

def __init__(self, *pa, **kwa):
"""
Inherited Parameters:
db (dbing.LMDBer): base db
subkey (str): LMDB sub database key
dupsort (bool): True means enable duplicates at each key
False (default) means do not enable duplicates at
each key. Set to False
sep (str): separator for combining keys tuple of strs into key bytes
for db key and also used to convert val iterator to val bytes
Must not be Base64 character.
default is self.Sep == '.'
verify (bool): True means reverify when ._des from db when applicable
False means do not reverify. Default False
"""
super(B64IoDupSuber, self).__init__(*pa, **kwa)



class OnIoDupSuber(OnSuberBase, IoDupSuber):
"""
Sub class of IoDupSuber and OnSuberBase that supports Insertion Ordering
(IoDup) of duplicates but where the trailing part of the key space is
a serialized monotonically increasing ordinal number. This is useful for
escrows of key events etc where duplicates of likely events are maintained
in insertion order.
escrows of key events which are ordinally numbered such as sn but where
duplicates of likely events are also maintained in insertion order.
Insertion order is maintained by automagically prepending and stripping an
ordinal ordering proem to/from each duplicate value at a given key.
Expand Down Expand Up @@ -2412,3 +2447,39 @@ def getOnItemBackIter(self, keys: str|bytes|memoryview|Iterable = "", on: int=0)
for keys, on, val in (self.db.getOnIoDupItemBackIter(db=self.sdb,
key=self._tokey(keys), on=on, sep=self.sep.encode())):
yield (self._tokeys(keys), on, self._des(val))


class B64OnIoDupSuber(B64SuberBase, OnIoDupSuber):
"""
Subclass of B64SuberBase and OnIoDupSuber that serializes and deserializes
values as .sep joined strings of Base64 components in insertion ordered
duplicates with leading value proem but where the trailing part of the
key space is a serialized monotonically increasing ordinal number.
Proem + .sep joined value and must fit n 511 bytes of keyspace as duplicate.
Insertion order is maintained by automagically prepending and stripping an
ordinal ordering proem to/from each duplicate value at a given key.
OnIoDupSuber adds the convenience methods from OnSuberBase to OnIoDupSuber
for those cases where the keyspace has a trailing ordinal part.
Assumes dupsort==True
"""

def __init__(self, *pa, **kwa):
"""
Inherited Parameters:
db (dbing.LMDBer): base db
subkey (str): LMDB sub database key
dupsort (bool): True means enable duplicates at each key
False (default) means do not enable duplicates at
each key. Set to False
sep (str): separator for combining keys tuple of strs into key bytes
for db key and also used to convert val iterator to val bytes
Must not be Base64 character.
default is self.Sep == '.'
verify (bool): True means reverify when ._des from db when applicable
False means do not reverify. Default False
"""
super(B64OnIoDupSuber, self).__init__(*pa, **kwa)
2 changes: 1 addition & 1 deletion src/keri/help/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,4 @@
ogler = ogling.initOgler(prefix='keri', syslogged=False) # inits once only on first import

from .helping import (nowIso8601, toIso8601, fromIso8601,
nonStringSequence, nonStringIterable)
nonStringSequence, nonStringIterable, Reb64)
Loading

0 comments on commit 550b478

Please sign in to comment.