|  | /* | 
|  | * 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 <code>SessionNotifier</code> interface defines a connection notifier for | 
|  | * server-side OBEX connections. When a <code>SessionNotifier</code> is created | 
|  | * and calls <code>acceptAndOpen()</code>, it will begin listening for clients | 
|  | * to create a connection at the transport layer. When the transport layer | 
|  | * connection is received, the <code>acceptAndOpen()</code> method will return a | 
|  | * <code>javax.microedition.io.Connection</code> that is the connection to the | 
|  | * client. The <code>acceptAndOpen()</code> method also takes a | 
|  | * <code>ServerRequestHandler</code> 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. | 
|  | * <P> | 
|  | * <H4>Additional Note for OBEX over Bluetooth</H4> If this method is called | 
|  | * on a <code>SessionNotifier</code> object that does not have a | 
|  | * <code>ServiceRecord</code> in the SDDB, the <code>ServiceRecord</code> | 
|  | * 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. | 
|  | * <P> | 
|  | * The following checks are done to verify that the service record provided | 
|  | * is valid. If any of these checks fail, then a | 
|  | * <code>ServiceRegistrationException</code> is thrown. | 
|  | * <UL> | 
|  | * <LI>ServiceClassIDList and ProtocolDescriptorList, the mandatory service | 
|  | * attributes for a <code>btgoep</code> service record, must be present in | 
|  | * the <code>ServiceRecord</code> associated with this notifier. | 
|  | * <LI>L2CAP, RFCOMM and OBEX must all be in the ProtocolDescriptorList | 
|  | * <LI>The <code>ServiceRecord</code> associated with this notifier must not | 
|  | * have changed the RFCOMM server channel number | 
|  | * </UL> | 
|  | * <P> | 
|  | * This method will not ensure that <code>ServiceRecord</code> 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 <code>handler</code> is <code>null</code> | 
|  | */ | 
|  | 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 | 
|  | * <code>Authenticator</code> to use to respond to authentication challenge | 
|  | * and authentication response headers. | 
|  | * <P> | 
|  | * <H4>Additional Note for OBEX over Bluetooth</H4> If this method is called | 
|  | * on a <code>SessionNotifier</code> object that does not have a | 
|  | * <code>ServiceRecord</code> in the SDDB, the <code>ServiceRecord</code> | 
|  | * 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. | 
|  | * <P> | 
|  | * The following checks are done to verify that the service record provided | 
|  | * is valid. If any of these checks fail, then a | 
|  | * <code>ServiceRegistrationException</code> is thrown. | 
|  | * <UL> | 
|  | * <LI>ServiceClassIDList and ProtocolDescriptorList, the mandatory service | 
|  | * attributes for a <code>btgoep</code> service record, must be present in | 
|  | * the <code>ServiceRecord</code> associated with this notifier. | 
|  | * <LI>L2CAP, RFCOMM and OBEX must all be in the ProtocolDescriptorList | 
|  | * <LI>The <code>ServiceRecord</code> associated with this notifier must not | 
|  | * have changed the RFCOMM server channel number | 
|  | * </UL> | 
|  | * <P> | 
|  | * This method will not ensure that <code>ServiceRecord</code> 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 <code>Authenticator</code> to use with this connection; | 
|  | *        if <code>null</code> then no <code>Authenticator</code> will be | 
|  | *        used | 
|  | * @return the connection to the client | 
|  | * @throws IOException if an error occurs in the transport layer | 
|  | * @throws NullPointerException if <code>handler</code> is <code>null</code> | 
|  | */ | 
|  | ObexSession acceptAndOpen(ServerRequestHandler handler, Authenticator auth) throws IOException; | 
|  | } |