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 * emimsg.h 00059 * 00060 * Declarations needed with EMI messages 00061 * Uoti Urpala 2001 */ 00062 00063 #ifndef EMIMSG_H 00064 #define EMIMSG_H 00065 00066 00067 #include "gwlib/gwlib.h" 00068 00069 00070 struct emimsg { 00071 int trn; 00072 char or; 00073 int ot; 00074 int num_fields; 00075 Octstr **fields; 00076 }; 00077 00078 /* Symbolic constants for the number of a field in a message */ 00079 00080 enum { 00081 E01_ADC, E01_OADC, E01_AC, E01_MT, E01_AMSG, SZ01 00082 }; 00083 00084 00085 /* All the 50-series messages have the same number of fields */ 00086 enum { 00087 E50_ADC, E50_OADC, E50_AC, E50_NRQ, E50_NADC, E50_NT, E50_NPID, E50_LRQ, 00088 E50_LRAD, E50_LPID, E50_DD, E50_DDT, E50_VP, E50_RPID, E50_SCTS, E50_DST, 00089 E50_RSN, E50_DSCTS, E50_MT, E50_NB, E50_NMSG=20, E50_AMSG=20, E50_TMSG=20, 00090 E50_MMS, E50_PR, E50_DCS, E50_MCLS, E50_RPI, E50_CPG, E50_RPLY, E50_OTOA, 00091 E50_HPLMN, E50_XSER, E50_RES4, E50_RES5, SZ50 00092 }; 00093 00094 00095 enum { 00096 E60_OADC, E60_OTON, E60_ONPI, E60_STYP, E60_PWD, E60_NPWD, E60_VERS, 00097 E60_LADC, E60_LTON, E60_LNPI, E60_OPID, E60_RES1, SZ60 00098 }; 00099 00100 00101 /* Create an EMI msg struct with operation type OT and TRN */ 00102 struct emimsg *emimsg_create_op(int ot, int trn, Octstr *whoami); 00103 00104 00105 /* Create an empty EMI msg struct as reply */ 00106 struct emimsg *emimsg_create_reply(int ot, int trn, int positive, 00107 Octstr *whoami); 00108 00109 00110 /* Destroy an EMI msg struct */ 00111 void emimsg_destroy(struct emimsg *emimsg); 00112 00113 00114 /* Duplicate an EMI msg struct */ 00115 struct emimsg *emimsg_duplicate(struct emimsg *emimsg); 00116 00117 00118 00119 /* Create an emimsg struct from the string. */ 00120 /* Doesn't check that the string is strictly according to format */ 00121 struct emimsg *get_fields(Octstr *message, Octstr *whoami); 00122 00123 00124 /* Send emimsg over conn using the EMI protocol. */ 00125 int emimsg_send(Connection *conn, struct emimsg *emimsg, 00126 Octstr *whoami); 00127 00128 #endif