/*
* Copyright (c) 2008-2009, Motorola, Inc.
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* - Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* - Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* - Neither the name of the Motorola, Inc. nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package javax.obex;
import java.io.IOException;
/**
* The SessionNotifier
interface defines a connection notifier for
* server-side OBEX connections. When a SessionNotifier
is created
* and calls acceptAndOpen()
, it will begin listening for clients
* to create a connection at the transport layer. When the transport layer
* connection is received, the acceptAndOpen()
method will return a
* javax.microedition.io.Connection
that is the connection to the
* client. The acceptAndOpen()
method also takes a
* ServerRequestHandler
argument that will process the requests
* from the client that connects to the server.
* @hide
*/
public interface SessionNotifier {
/**
* Waits for a transport layer connection to be established and specifies
* the handler to handle the requests from the client. No authenticator is
* associated with this connection, therefore, it is implementation
* dependent as to how an authentication challenge and authentication
* response header will be received and processed.
*
*
SessionNotifier
object that does not have a
* ServiceRecord
in the SDDB, the ServiceRecord
* for this object will be added to the SDDB. This method requests the BCC
* to put the local device in connectable mode so that it will respond to
* connection attempts by clients.
*
* The following checks are done to verify that the service record provided
* is valid. If any of these checks fail, then a
* ServiceRegistrationException
is thrown.
*
btgoep
service record, must be present in
* the ServiceRecord
associated with this notifier.
* ServiceRecord
associated with this notifier must not
* have changed the RFCOMM server channel number
*
* This method will not ensure that ServiceRecord
associated
* with this notifier is a completely valid service record. It is the
* responsibility of the application to ensure that the service record
* follows all of the applicable syntactic and semantic rules for service
* record correctness.
* @param handler the request handler that will respond to OBEX requests
* @return the connection to the client
* @throws IOException if an error occurs in the transport layer
* @throws NullPointerException if handler
is null
*/
ObexSession acceptAndOpen(ServerRequestHandler handler) throws IOException;
/**
* Waits for a transport layer connection to be established and specifies
* the handler to handle the requests from the client and the
* Authenticator
to use to respond to authentication challenge
* and authentication response headers.
*
*
SessionNotifier
object that does not have a
* ServiceRecord
in the SDDB, the ServiceRecord
* for this object will be added to the SDDB. This method requests the BCC
* to put the local device in connectable mode so that it will respond to
* connection attempts by clients.
*
* The following checks are done to verify that the service record provided
* is valid. If any of these checks fail, then a
* ServiceRegistrationException
is thrown.
*
btgoep
service record, must be present in
* the ServiceRecord
associated with this notifier.
* ServiceRecord
associated with this notifier must not
* have changed the RFCOMM server channel number
*
* This method will not ensure that ServiceRecord
associated
* with this notifier is a completely valid service record. It is the
* responsibility of the application to ensure that the service record
* follows all of the applicable syntactic and semantic rules for service
* record correctness.
* @param handler the request handler that will respond to OBEX requests
* @param auth the Authenticator
to use with this connection;
* if null
then no Authenticator
will be
* used
* @return the connection to the client
* @throws IOException if an error occurs in the transport layer
* @throws NullPointerException if handler
is null
*/
ObexSession acceptAndOpen(ServerRequestHandler handler, Authenticator auth) throws IOException;
}