243 lines
7.7 KiB
C
243 lines
7.7 KiB
C
/*
|
|
* Copyright (C) 2006 Raul Tremsal
|
|
* File : smpp34_dumpPdu.c
|
|
* Author: Raul Tremsal <ultraismo@yahoo.com>
|
|
*
|
|
* This file is part of libsmpp34 (c-open-smpp3.4 library).
|
|
*
|
|
* The libsmpp34 library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public License as
|
|
* published by the Free Software Foundation; either version 2.1 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
* License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this library; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*
|
|
*/
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <sys/types.h>
|
|
#include <netinet/in.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "smpp34.h"
|
|
#include "smpp34_structs.h"
|
|
#include "smpp34_params.h"
|
|
|
|
/* GLOBALS ********************************************************************/
|
|
/* EXTERN *********************************************************************/
|
|
extern int smpp34_errno;
|
|
extern char smpp34_strerror[2048];
|
|
extern char *ptrerror;
|
|
|
|
/* FUNCTIONS ******************************************************************/
|
|
int
|
|
smpp34_dumpPdu(uint32_t type, uint8_t *dest, int size_dest, void* tt)
|
|
{
|
|
|
|
char dummy_b[SMALL_BUFF];
|
|
int left = size_dest;
|
|
int lenval = 0;
|
|
uint8_t l_dest[512];
|
|
int lefterror = 0;
|
|
|
|
memset(smpp34_strerror, 0, sizeof(smpp34_strerror));
|
|
ptrerror = smpp34_strerror;
|
|
lefterror = sizeof(smpp34_strerror);
|
|
memset(l_dest, 0, sizeof(l_dest));
|
|
|
|
|
|
#define instancia t1->
|
|
|
|
#define U32( inst, par, _str ){\
|
|
_str(inst par, dummy_b);\
|
|
if( strcmp( dummy_b, "" ) == 0 ){\
|
|
PUTLOG("[%s:%08X(%s)]", par, inst par, "Value is invalid");\
|
|
} else {\
|
|
PUTLOG("[%s:%08X(%s)]", par, inst par, "OK");\
|
|
};\
|
|
lenval = snprintf((char*)l_dest, sizeof(l_dest), "%-30s[%08X] - [%s]\n",\
|
|
#par,inst par,dummy_b);\
|
|
if( lenval >= left ){\
|
|
PUTLOG("[%s:%08X(%s)]", par, inst par,\
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= lenval; dest += lenval;\
|
|
}
|
|
|
|
#define U16( inst, par, _str ){\
|
|
_str(inst par, dummy_b);\
|
|
if( strcmp( dummy_b, "" ) == 0 ){\
|
|
PUTLOG("[%s:%04X(%s)]", par, inst par, "Value is invalid");\
|
|
} else {\
|
|
PUTLOG("[%s:%04X(%s)]", par, inst par, "OK");\
|
|
};\
|
|
lenval = snprintf((char*)l_dest, sizeof(l_dest),\
|
|
"%-30s[%04X] [%s]\n",#par,inst par,dummy_b);\
|
|
if( lenval >= left ){\
|
|
PUTLOG("[%s:%04X(%s)]", par, inst par,\
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= (uint8_t)lenval; dest += (uint8_t) lenval;\
|
|
}
|
|
|
|
#define U08( inst, par, _str ){\
|
|
_str(inst par, dummy_b);\
|
|
if( strcmp( dummy_b, "" ) == 0 ){\
|
|
PUTLOG("[%s:%02X(%s)]", par, inst par, "Value is invalid");\
|
|
} else {\
|
|
PUTLOG("[%s:%02X(%s)]", par, inst par, "OK");\
|
|
};\
|
|
lenval = snprintf((char*)l_dest, sizeof(l_dest), "%-30s[%02X] - [%s]\n",\
|
|
#par,inst par, dummy_b);\
|
|
if( lenval >= left ){\
|
|
PUTLOG("[%s:%02X(%s)]", par, inst par,\
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= lenval; dest += lenval;\
|
|
}
|
|
|
|
#define _op(inst, par, size ){\
|
|
lenval = snprintf((char*)l_dest, sizeof(l_dest), "%-30s[%."#size"s]\n",\
|
|
#par, inst par);\
|
|
if( lenval >= left ){\
|
|
PUTLOG("[%s:%s(%s)]", par, inst par, \
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
PUTLOG("[%s:%s(%s)]", par, inst par, "OK");\
|
|
snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= lenval; dest += lenval;\
|
|
}
|
|
|
|
#define O_C_OCTET( inst, par, sizeval ){\
|
|
if( !(inst command_status) ){\
|
|
C_OCTET( inst, par, sizeval );\
|
|
} else {\
|
|
PUTLOG("[%s:%s(%s)]", par, inst par, "OK");\
|
|
};\
|
|
}
|
|
|
|
#define C_OCTET( inst, par, size ) {\
|
|
_op(inst, par, size )\
|
|
}
|
|
|
|
#define OCTET8( inst, par, size, lenval ){\
|
|
int i = 0;\
|
|
uint8_t *p = l_dest;\
|
|
int dummy = 0;\
|
|
if( (lenval + 33) >= left ){\
|
|
PUTLOG("[%s:%s(%s)]", par, inst par, \
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
PUTLOG("[%s:%s(%s)]", par, "<bin>", "OK");\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), "%-30s[", #par);\
|
|
for(i = 0 ; i < lenval; i++){\
|
|
if( *((inst par)+i) < ' ' || *((inst par)+i) > '~' ){\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), ".");\
|
|
} else {\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), "%c",\
|
|
*((inst par)+i));\
|
|
};\
|
|
};\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), "]\n");\
|
|
dummy = snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= dummy; dest += dummy;\
|
|
};
|
|
|
|
|
|
#define OCTET16( inst, par, size ){\
|
|
int i = 0;\
|
|
uint8_t *p = l_dest;\
|
|
int dummy = 0;\
|
|
uint16_t l_lenval = 0;\
|
|
memcpy(&l_lenval, ((inst par) - sizeof(uint16_t)), sizeof(uint16_t));\
|
|
if( (l_lenval + 33) >= left ){\
|
|
PUTLOG("[%s:%s(%s)]", par, inst par, \
|
|
"Value length exceed buffer length");\
|
|
return( -1 );\
|
|
};\
|
|
PUTLOG("[%s:%s(%s)]", par, "<bin>", "OK");\
|
|
p += snprintf((char*)p, (sizeof(l_dest) - (p - l_dest)), "%-30s[", #par);\
|
|
for( i = 0; i < l_lenval; i++){\
|
|
if( *((inst par)+i) < ' ' || *((inst par)+i) > '~' ){\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), ".");\
|
|
} else {\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), "%c",\
|
|
*((inst par)+i));\
|
|
};\
|
|
};\
|
|
p += snprintf((char*)p, (sizeof(l_dest)-(p-l_dest)), "]\n");\
|
|
dummy = snprintf((char*)dest, left, "%s", l_dest);\
|
|
left -= dummy; dest += dummy;\
|
|
};
|
|
|
|
|
|
#define TLV( inst, tlv1, do_tlv ){\
|
|
tlv_t *aux_tlv = inst tlv1;\
|
|
while( aux_tlv != NULL ){\
|
|
do_tlv( aux_tlv );\
|
|
aux_tlv = aux_tlv->next;\
|
|
};\
|
|
};
|
|
|
|
#define DAD( inst, dad1, do_dad ){\
|
|
dad_t *aux_dad = inst dad1;\
|
|
while( aux_dad != NULL ){\
|
|
do_dad( aux_dad );\
|
|
aux_dad = aux_dad->next;\
|
|
};\
|
|
};
|
|
|
|
#define UDAD( inst, udad1, do_udad ){\
|
|
udad_t *aux_udad = inst udad1;\
|
|
while( aux_udad != NULL ){\
|
|
do_udad( aux_udad );\
|
|
aux_udad = aux_udad->next;\
|
|
};\
|
|
};
|
|
|
|
#include "def_frame/alert_notification.tlv"
|
|
#include "def_frame/bind_receiver_resp.tlv"
|
|
#include "def_frame/bind_transceiver_resp.tlv"
|
|
#include "def_frame/bind_transmitter_resp.tlv"
|
|
#include "def_frame/data_sm.tlv"
|
|
#include "def_frame/data_sm_resp.tlv"
|
|
#include "def_frame/deliver_sm.tlv"
|
|
#include "def_frame/submit_multi_resp.udad"
|
|
#include "def_frame/submit_multi.dad"
|
|
#include "def_frame/submit_multi.tlv"
|
|
#include "def_frame/submit_sm.tlv"
|
|
#include "def_list/smpp34_protocol.def"
|
|
|
|
#include "def_frame/clean.frame"
|
|
|
|
return( 0 );
|
|
};
|
|
|
|
|
|
|
|
int
|
|
smpp34_dumpPdu2(uint8_t *dest, int size_dest, void* tt)
|
|
{
|
|
uint32_t cmdid;
|
|
memcpy(&cmdid, tt+4, sizeof(uint32_t));
|
|
return( smpp34_dumpPdu(cmdid, dest, size_dest, tt) );
|
|
};
|
|
|