Commit e029a0cd authored by Jim Fulton's avatar Jim Fulton

This is superceded by the storage interfaces in ZODB.interfaces.

parent 7bedfa43
This diff is collapsed.
...@@ -322,10 +322,14 @@ class IStorageDB(Interface): ...@@ -322,10 +322,14 @@ class IStorageDB(Interface):
there would be so many that it would be inefficient to do so. there would be so many that it would be inefficient to do so.
""" """
def invalidate(transaction_id, oids): def invalidate(transaction_id, oids, version=''):
"""Invalidate object ids committed by the given transaction """Invalidate object ids committed by the given transaction
The oids argument is an iterable of object identifiers. The oids argument is an iterable of object identifiers.
The version argument is provided for backward
compatibility. If passed, it must be an empty string.
""" """
def references(record, oids=None): def references(record, oids=None):
...@@ -339,10 +343,11 @@ class IStorageDB(Interface): ...@@ -339,10 +343,11 @@ class IStorageDB(Interface):
class IDatabase(IStorageDB): class IDatabase(IStorageDB):
"""ZODB DB. """ZODB DB.
TODO: This interface is incomplete.
""" """
# TODO: This interface is incomplete.
# XXX how is it incomplete?
databases = Attribute( databases = Attribute(
"""A mapping from database name to DB (database) object. """A mapping from database name to DB (database) object.
...@@ -423,13 +428,16 @@ class IStorage(Interface): ...@@ -423,13 +428,16 @@ class IStorage(Interface):
def close(): def close():
"""Close the storage. """Close the storage.
Finalize the storage, releasing any external resources. The
storage should not be used after this method is called.
""" """
def getName(): def getName():
"""The name of the storage """The name of the storage
The format and interpretation of this name is storage The format and interpretation of this name is storage
dependent. It could be a file name, a database name, etc. dependent. It could be a file name, a database name, etc..
This is used soley for informational purposes. This is used soley for informational purposes.
""" """
...@@ -440,7 +448,7 @@ class IStorage(Interface): ...@@ -440,7 +448,7 @@ class IStorage(Interface):
This is used soley for informational purposes. This is used soley for informational purposes.
""" """
def history(oid, size=1): def history(oid, version='', size=1):
"""Return a sequence of history information dictionaries. """Return a sequence of history information dictionaries.
Up to size objects (including no objects) may be returned. Up to size objects (including no objects) may be returned.
...@@ -453,20 +461,31 @@ class IStorage(Interface): ...@@ -453,20 +461,31 @@ class IStorage(Interface):
time time
UTC seconds since the epoch (as in time.time) that the UTC seconds since the epoch (as in time.time) that the
object revision was committed. object revision was committed.
tid tid
The transaction identifier of the transaction that The transaction identifier of the transaction that
committed the version. committed the version.
serial
An alias for tid, which expected by older clients.
user_name user_name
The user identifier, if any (or an empty string) of the The user identifier, if any (or an empty string) of the
user on whos behalf the revision was committed. user on whos behalf the revision was committed.
description description
The transaction description for the transaction that The transaction description for the transaction that
committed the revision. committed the revision.
size size
The size of the revision data record. The size of the revision data record.
If the transaction had extension items, then these items are If the transaction had extension items, then these items are
also included if they don't conflict with the keys above. also included if they don't conflict with the keys above.
The version argument is provided for backward
compatibility. It should always be an empty string.
""" """
def isReadOnly(): def isReadOnly():
...@@ -476,6 +495,11 @@ class IStorage(Interface): ...@@ -476,6 +495,11 @@ class IStorage(Interface):
same value. Read-only-ness is a static property of a storage. same value. Read-only-ness is a static property of a storage.
""" """
# XXX Note that this method doesn't really buy us much,
# especially since we have to account for the fact that a
# ostensibly non-read-only storage may be read-only
# transiently. It would be better to just have read-only errors.
def lastTransaction(): def lastTransaction():
"""Return the id of the last committed transaction """Return the id of the last committed transaction
""" """
...@@ -486,9 +510,13 @@ class IStorage(Interface): ...@@ -486,9 +510,13 @@ class IStorage(Interface):
This is used soley for informational purposes. This is used soley for informational purposes.
""" """
def load(oid): def load(oid, version):
"""Load data for an object id """Load data for an object id
The version argumement should always be an empty string. It
exists soley for backward compatibility with older storage
implementations.
A data record and serial are returned. The serial is a A data record and serial are returned. The serial is a
transaction identifier of the transaction that wrote the data transaction identifier of the transaction that wrote the data
record. record.
...@@ -566,7 +594,7 @@ class IStorage(Interface): ...@@ -566,7 +594,7 @@ class IStorage(Interface):
has a reasonable chance of being unique. has a reasonable chance of being unique.
""" """
def store(oid, serial, data, transaction): def store(oid, serial, data, version, transaction):
"""Store data for the object id, oid. """Store data for the object id, oid.
Arguments: Arguments:
...@@ -585,12 +613,15 @@ class IStorage(Interface): ...@@ -585,12 +613,15 @@ class IStorage(Interface):
data data
The data record. This is opaque to the storage. The data record. This is opaque to the storage.
version
This must be an empty string. It exists for backward compatibility.
transaction transaction
A transaction object. This should match the current A transaction object. This should match the current
transaction for the storage, set by tpc_begin. transaction for the storage, set by tpc_begin.
The new serial for the object is returned, but not necessarily The new serial for the object is returned, but not necessarily
immediately. It may be returned directly, or un a subsequent immediately. It may be returned directly, or on a subsequent
store or tpc_vote call. store or tpc_vote call.
The return value may be: The return value may be:
...@@ -607,6 +638,21 @@ class IStorage(Interface): ...@@ -607,6 +638,21 @@ class IStorage(Interface):
ZODB.ConflictResolution.ResolvedSerial to indicate that a ZODB.ConflictResolution.ResolvedSerial to indicate that a
conflict occured and that the object should be invalidated. conflict occured and that the object should be invalidated.
Several different exceptions may be raised when an error occurs.
ConflictError
is raised when serial does not match the most recent serial
number for object oid and the conflict was not resolved by
the storage.
StorageTransactionError
is raised when transaction does not match the current
transaction.
StorageError or, more often, a subclass of it
is raised when an internal error occurs while the storage is
handling the store() call.
""" """
def tpc_abort(transaction): def tpc_abort(transaction):
...@@ -667,6 +713,13 @@ class IStorage(Interface): ...@@ -667,6 +713,13 @@ class IStorage(Interface):
""" """
class IStorageRestoreable(IStorage): class IStorageRestoreable(IStorage):
"""Copying Transactions
The IStorageRestoreable interface supports copying
already-committed transactions from one storage to another. This
is typically done for replication or for moving data from one
storage implementation to another.
"""
def tpc_begin(transaction, tid=None): def tpc_begin(transaction, tid=None):
"""Begin the two-phase commit process. """Begin the two-phase commit process.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment