##############################################################################
#
# Copyright (c) 2001, 2002 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Browser Interfaces
$Id: browser.py 67630 2006-04-27 00:54:03Z jim $
"""
__docformat__ = "reStructuredText"
from zope.interface import Interface, Attribute, directlyProvides
from zope.interface.interfaces import IInterface
from zope.component.interfaces import IView
from zope.publisher.interfaces import IPublication
from zope.publisher.interfaces import IPublishTraverse
from zope.publisher.interfaces.http import IHTTPApplicationRequest
from zope.publisher.interfaces.http import IHTTPRequest
class IBrowserApplicationRequest(IHTTPApplicationRequest):
    """Browser-specific requests
    """
    def __getitem__(key):
        """Return Browser request data
        Request data are retrieved from one of:
        - Environment variables
          These variables include input headers, server data, and other
          request-related data.  The variable names are as specified
          in the CGI
          specification
        - Cookies
          These are the cookie data, if present.
        - Form data
        Form data are searched before cookies, which are searched
        before environmental data.
        """
    form = Attribute(
        """Form data
        This is a read-only mapping from name to form value for the name.
        """)
class IBrowserPublication(IPublication):
    """Object publication framework.
    """
    def getDefaultTraversal(request, ob):
        """Get the default published object for the request
        Allows a default view to be added to traversal.
        Returns (ob, steps_reversed).
        """
class IBrowserRequest(IHTTPRequest):
    """Browser-specific Request functionality.
    Note that the browser is special in many ways, since it exposes
    the Request object to the end-developer.
    """
class IBrowserPublisher(IPublishTraverse):
    def browserDefault(request):
        """Provide the default object
        The default object is expressed as a (possibly different)
        object and/or additional traversal steps.
        Returns an object and a sequence of names.  If the sequence of
        names is not empty, then a traversal step is made for each name.
        After the publisher gets to the end of the sequence, it will
        call browserDefault on the last traversed object.
        Normal usage is to return self for object and a default view name.
        The publisher calls this method at the end of each traversal path. If
        a non-empty sequence of names is returned, the publisher will traverse
        those names and call browserDefault again at the end.
        Note that if additional traversal steps are indicated (via a
        nonempty sequence of names), then the publisher will try to adjust
        the base href.
        """
class IBrowserPage(IBrowserPublisher):
    """Browser page"""
    def __call__(*args, **kw):
        """Compute a response body"""
class IBrowserView(IView):
    """Browser View"""
class IDefaultBrowserLayer(IBrowserRequest):
    """The default layer."""
class IBrowserSkinType(IInterface):
    """A skin is a set of layers."""
##############################################################################
#
# BBB 2006/02/18, to be removed after 12 months
#
# mark the default layer for BBB reasons
from zope.publisher.interfaces.back35 import ILayer
directlyProvides(IDefaultBrowserLayer, ILayer)
import zope.deprecation
ISkin = IBrowserSkinType
zope.deprecation.deprecated('ISkin',
                            'The zope.publisher.interfaces.browser.ISkin '
                            'interface has been renamed to IBrowserSkinType. '
                            'The old alias will go away in Zope 3.5.')
#
##############################################################################
class IDefaultSkin(Interface):
    """Any component providing this interface must be a skin.
    This is a marker interface, so that we can register the default skin as an
    adapter from the presentation type to `IDefaultSkin`.
    """