Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

bb_smscconn_cb.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 #ifndef BB_SMSCCONN_CB
00058 #define BB_SMSCCONN_CB
00059 
00060 #include "msg.h"
00061 #include "smscconn.h"
00062 
00063 /* Callback functions for SMSC Connection implementations.
00064  * All functions return immediately.
00065  *
00066  * NOTE: These callback functions MUST be called by SMSCConn
00067  *   implementations in given times! See smscconn_p.h for details
00068  */
00069 
00070 
00071 /* called immediately after startup is done. This is called
00072  * AUTOMATICALLY by smscconn_create, no need to call it from
00073  * various implementations */
00074 void bb_smscconn_ready(SMSCConn *conn);
00075 
00076 /* called each time when SMS center connected
00077  */
00078 void bb_smscconn_connected(SMSCConn *conn);
00079 
00080 
00081 /* called after SMSCConn is shutdown or it kills itself
00082  * because of non-recoverable problems. SMSC Connection has already
00083  * destroyed all its private data areas and set status as SMSCCONN_DEAD.
00084  * Calling this function must be the last thing done by SMSC Connection
00085  * before exiting with the last thread
00086  */
00087 void bb_smscconn_killed(void);
00088 
00089 
00090 /*
00091  * Called after successful sending of Msg 'sms'. Generate dlr message if
00092  * DLR_SMSC_SUCCESS mask is set. 'reply' will be passed as msgdata to
00093  * generated dlr message. This callback takes
00094  * care of 'sms' and 'reply' and it CAN NOT be used by caller again.
00095  */
00096 void bb_smscconn_sent(SMSCConn *conn, Msg *sms, Octstr *reply);
00097 
00098 
00099 /*
00100  * Called after failed sending of 'sms'. Generate dlr message if
00101  * DLR_SMSC_FAIL or DLR_FAIL mask is set. 'reply' will be passed as
00102  * msgdata to generated dlr message.Reason is set accordingly.
00103  * callback handles 'sms' and 'reply' and MAY NOT be used by caller again
00104  */
00105 void bb_smscconn_send_failed(SMSCConn *conn, Msg *sms, int reason, Octstr *reply);
00106 
00107 enum {
00108     SMSCCONN_SUCCESS = 0,
00109     SMSCCONN_QUEUED,
00110     SMSCCONN_FAILED_SHUTDOWN,
00111     SMSCCONN_FAILED_REJECTED,
00112     SMSCCONN_FAILED_MALFORMED,
00113     SMSCCONN_FAILED_TEMPORARILY,
00114     SMSCCONN_FAILED_DISCARDED,
00115     SMSCCONN_FAILED_QFULL
00116 };
00117 
00118 
00119 /* called when a new message 'sms' received. Callback handles
00120  * 'sms' and MAY NOT be used by caller again. Return SMSCCONN_SUCCESS if all went
00121  * fine, SMSCCONN_FAILED_QFULL if incoming queue full, SMSCCONN_FAILED_TEMPORARILY
00122  * if store enabled and failed, and SMSCCONN_FAILED_REJECTED if bearerbox does
00123  * NOT accept the 'sms' (black/whitelisted) */
00124 long bb_smscconn_receive(SMSCConn *conn, Msg *sms);
00125 
00126 
00127 #endif
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.