Add the basic plugin interfaces and some documentation
This commit is contained in:
parent
3f9f4537b9
commit
e10a032fc3
|
@ -1,5 +1,8 @@
|
||||||
|
|
||||||
from zope.interface import Interface, Attribute
|
from zope.interface import Interface, Attribute
|
||||||
|
from twisted.plugin import (
|
||||||
|
IPlugin,
|
||||||
|
)
|
||||||
from foolscap.api import StringConstraint, ListOf, TupleOf, SetOf, DictOf, \
|
from foolscap.api import StringConstraint, ListOf, TupleOf, SetOf, DictOf, \
|
||||||
ChoiceOf, IntegerConstraint, Any, RemoteInterface, Referenceable
|
ChoiceOf, IntegerConstraint, Any, RemoteInterface, Referenceable
|
||||||
|
|
||||||
|
@ -3023,3 +3026,125 @@ class IConnectionStatus(Interface):
|
||||||
connection hint and the handler it is using) to the status string
|
connection hint and the handler it is using) to the status string
|
||||||
(pending, connected, refused, or other errors).
|
(pending, connected, refused, or other errors).
|
||||||
""")
|
""")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class IFoolscapStoragePlugin(IPlugin):
|
||||||
|
"""
|
||||||
|
An ``IStoragePlugin`` provides client- and server-side implementations of
|
||||||
|
a Foolscap-based protocol which can be used to store and retrieve data.
|
||||||
|
|
||||||
|
Implementations are free to apply access control or authorization policies
|
||||||
|
to this storage service and doing so is a large part of the motivation for
|
||||||
|
providing this point of pluggability.
|
||||||
|
|
||||||
|
There should be enough information and hook points to support at
|
||||||
|
least these use-cases:
|
||||||
|
|
||||||
|
- anonymous, everything allowed (current default)
|
||||||
|
- "storage club" / "friend-net" (possibly identity based)
|
||||||
|
- cryptocurrencies (ideally, paying for each API call)
|
||||||
|
- anonymous tokens (payment for service, but without identities)
|
||||||
|
"""
|
||||||
|
human_name = Attribute(
|
||||||
|
"""
|
||||||
|
How this plugin shall be referred to (e.g. in Storage Server
|
||||||
|
announcements, to users, etc). This is intended as a mostly unique,
|
||||||
|
human-facing identifier for the plugin.
|
||||||
|
|
||||||
|
:type: ``unicode``
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
id = Attribute(
|
||||||
|
"""
|
||||||
|
|
||||||
|
A globally unique identifier for this specific storage plugin.
|
||||||
|
Identifiers are represented as URLs. The domain portion of the URL
|
||||||
|
provides a self-organization hierarchy for avoid collisions between
|
||||||
|
plugins maintained by different agencies. A recommended structure for
|
||||||
|
such URLs is::
|
||||||
|
|
||||||
|
https://example.org/tahoe-lafs/storage/foobar/v1
|
||||||
|
|
||||||
|
:type: ``hyperlink.URL``
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
def get_storage_server(configuration, get_anonymous_storage_server):
|
||||||
|
"""
|
||||||
|
Get an ``IAnnounceableStorageServer`` provider that gives an announcement
|
||||||
|
for and an implementation of the server side of the storage protocol.
|
||||||
|
This will be exposed and offered to clients in the storage server's
|
||||||
|
announcement.
|
||||||
|
|
||||||
|
:param dict configuration: Any configuration given in the section for
|
||||||
|
this plugin in the node's configuration file. As an example, the
|
||||||
|
configuration for the original anonymous-access filesystem-based
|
||||||
|
storage server might look like::
|
||||||
|
|
||||||
|
{u"storedir": u"/foo/bar/storage",
|
||||||
|
u"nodeid": u"abcdefg...",
|
||||||
|
u"reserved_space": 0,
|
||||||
|
u"discard_storage": False,
|
||||||
|
u"readonly_storage": False,
|
||||||
|
u"expiration_enabled": False,
|
||||||
|
u"expiration_mode": u"age",
|
||||||
|
u"expiration_override_lease_duration": None,
|
||||||
|
u"expiration_cutoff_date": None,
|
||||||
|
u"expiration_sharetypes": ("mutable, "immutable"),
|
||||||
|
}
|
||||||
|
|
||||||
|
:param get_anonymous_storage_server: A no-argument callable which
|
||||||
|
returns a single instance of the original, anonymous-access
|
||||||
|
storage server. This may be helpful in providing actual storage
|
||||||
|
implementation behavior for a wrapper-style plugin. This is also
|
||||||
|
provided to keep the Python API offered by Tahoe-LAFS to plugin
|
||||||
|
developers narrow (do not try to find and instantiate the original
|
||||||
|
storage server yourself; if you want it, call this).
|
||||||
|
|
||||||
|
:rtype: ``Deferred`` firing with ``IAnnounceableStorageServer``
|
||||||
|
"""
|
||||||
|
|
||||||
|
def get_storage_client(configuration, announcement):
|
||||||
|
"""
|
||||||
|
Get an ``IStorageServer`` provider that implements the client side of the
|
||||||
|
storage protocol.
|
||||||
|
|
||||||
|
:param dict configuration: Any configuration given in the section for
|
||||||
|
this plugin in the node's configuration file.
|
||||||
|
|
||||||
|
:param dict announcement: The announcement for the corresponding
|
||||||
|
server portion of this plugin received from a storage server which
|
||||||
|
is offering it.
|
||||||
|
|
||||||
|
:rtype: ``Deferred`` firing with ``IStorageServer``
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
class IAnnounceableStorageServer(Interface):
|
||||||
|
announcement = Attribute(
|
||||||
|
"""
|
||||||
|
Data for an announcement for the associated storage server.
|
||||||
|
|
||||||
|
:note: This does not include the storage server nickname nor Foolscap
|
||||||
|
fURL. These will be added to the announcement automatically. It
|
||||||
|
may be usual for this announcement to contain no information.
|
||||||
|
Once the client connects to this server it can use other methods
|
||||||
|
to query for additional information (eg, in the manner of
|
||||||
|
``RIStorageServer.remote_get_version``). The announcement only
|
||||||
|
needs to contain information to help the client determine how to
|
||||||
|
connect.
|
||||||
|
|
||||||
|
:type: ``dict`` of JSON-serializable types
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
||||||
|
storage_server = Attribute(
|
||||||
|
"""
|
||||||
|
A Foolscap referenceable object implementing the server side of the
|
||||||
|
storage protocol.
|
||||||
|
|
||||||
|
:type: ``IReferenceable`` provider
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
|
Loading…
Reference in New Issue