Skip to content
Snippets Groups Projects
_plugin.py 2.28 KiB
Newer Older
# Copyright 2019 PrivateStorage.io, LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""
The Twisted plugin that glues the Secure Access Token system into
Tahoe-LAFS.
"""

import attr

from zope.interface import (
    implementer,
)

from twisted.internet.defer import (
    succeed,
)

from allmydata.interfaces import (
    IFoolscapStoragePlugin,
    IAnnounceableStorageServer,
from .api import (
    SecureAccessTokenAuthorizerStorageServer,
    SecureAccessTokenAuthorizerStorageClient,
)

from ._storage_server import (
    TOKEN_LENGTH,
from .resource import (
    from_configuration as resource_from_configuration,
)

@implementer(IAnnounceableStorageServer)
@attr.s
class AnnounceableStorageServer(object):
    announcement = attr.ib()
    storage_server = attr.ib()



@implementer(IFoolscapStoragePlugin)
class SecureAccessTokenAuthorizer(object):
    """
    A storage plugin which provides a token-based access control mechanism on
    top of the Tahoe-LAFS built-in storage server interface.
    """
    name = u"privatestorageio-satauthz-v1"

    def get_storage_server(self, configuration, get_anonymous_storage_server):
        announcement = {}
        storage_server = SecureAccessTokenAuthorizerStorageServer(
            get_anonymous_storage_server(),
            **configuration
        return succeed(
            AnnounceableStorageServer(
                announcement,
                storage_server,
            ),
        )

    def get_storage_client(self, configuration, announcement, get_rref):
        return succeed(
            SecureAccessTokenAuthorizerStorageClient(
                get_rref,
                lambda: [b"x" * TOKEN_LENGTH],
            )


    def get_client_resource(self, configuration):
        return resource_from_configuration(configuration)