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