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

dlr.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 /*
00058  * gw/dlr.h
00059  *
00060  * Implementation of handling delivery reports (DLRs)
00061  *
00062  * Andreas Fink <andreas@fink.org>, 18.08.2001
00063  * Stipe Tolj <stolj@wapme.de>, 22.03.2002
00064  */
00065 
00066 #ifndef DLR_H
00067 #define DLR_H 1
00068 
00069 #define DLR_UNDEFINED       -1
00070 #define DLR_NOTHING         0x00
00071 #define DLR_SUCCESS         0x01
00072 #define DLR_FAIL            0x02
00073 #define DLR_BUFFERED        0x04
00074 #define DLR_SMSC_SUCCESS    0x08
00075 #define DLR_SMSC_FAIL       0x10
00076 
00077 #define DLR_IS_DEFINED(dlr)          (dlr != DLR_UNDEFINED)
00078 #define DLR_IS_ENABLED(dlr)          (DLR_IS_DEFINED(dlr) && (dlr & (DLR_SUCCESS | DLR_FAIL | DLR_BUFFERED | DLR_SMSC_SUCCESS | DLR_SMSC_FAIL)))
00079 #define DLR_IS_ENABLED_DEVICE(dlr)   (DLR_IS_DEFINED(dlr) && (dlr & (DLR_SUCCESS | DLR_FAIL | DLR_BUFFERED)))
00080 #define DLR_IS_ENABLED_SMSC(dlr)     (DLR_IS_DEFINED(dlr) && (dlr & (DLR_SMSC_SUCCESS | DLR_SMSC_FAIL)))
00081 #define DLR_IS_NOT_FINAL(dlr)        (DLR_IS_DEFINED(dlr) && (dlr & (DLR_BUFFERED | DLR_SMSC_SUCCESS)))
00082 #define DLR_IS_SUCCESS_OR_FAIL(dlr)  (DLR_IS_DEFINED(dlr) && (dlr & (DLR_SUCCESS | DLR_FAIL)))
00083 #define DLR_IS_SUCCESS(dlr)          (DLR_IS_DEFINED(dlr) && (dlr & DLR_SUCCESS))
00084 #define DLR_IS_FAIL(dlr)             (DLR_IS_DEFINED(dlr) && (dlr & DLR_FAIL))
00085 #define DLR_IS_BUFFERED(dlr)         (DLR_IS_DEFINED(dlr) && (dlr & DLR_BUFFERED))
00086 #define DLR_IS_SMSC_SUCCESS(dlr)     (DLR_IS_DEFINED(dlr) && (dlr & DLR_SMSC_SUCCESS))
00087 #define DLR_IS_SMSC_FAIL(dlr)        (DLR_IS_DEFINED(dlr) && (dlr & DLR_SMSC_FAIL))
00088 
00089 /* DLR initialization routine (abstracted) */
00090 void dlr_init(Cfg *cfg);
00091 
00092 /* DLR shutdown routine (abstracted) */
00093 void dlr_shutdown(void);
00094 
00095 /* 
00096  * Add a new entry to the list
00097  */
00098 void dlr_add(const Octstr *smsc, const Octstr *ts, const Msg *msg);
00099 
00100 /* 
00101  * Find an entry in the list. If there is one a message is returned and 
00102  * the entry is removed from the list otherwhise the message returned is NULL 
00103  */
00104 Msg* dlr_find(const Octstr *smsc, const Octstr *ts, const Octstr *dst, int type);
00105 
00106 /* return the number of DLR messages in the current waiting queue */
00107 long dlr_messages(void);
00108 
00109 /* 
00110  * Flush all DLR messages in the current waiting queue.
00111  * Beware to take bearerbox to suspended state before doing this.
00112  */
00113 void dlr_flush(void);
00114 
00115 /*
00116  * Return type of dlr storage
00117  */
00118 const char* dlr_type(void);
00119 
00120 /*
00121  * Helper function, create DLR from given message
00122  */
00123 Msg* create_dlr_from_msg(const Octstr *smsc, const Msg *msg, const Octstr *reply, long stat);
00124 
00125 /*
00126  * Yet not used functions.
00127  */
00128 void dlr_save(const char *filename);
00129 void dlr_load(const char *filename);
00130 
00131 #endif /* DLR_H */
00132 
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.