FreeCalypso > hg > themwi-system-sw
view smpp-trx-sa/pdu_out.c @ 275:def9f6e4f49e default tip
doc/Use-outside-USA: Fake-NANP-numbers article is here
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 27 Nov 2023 21:49:19 -0800 |
parents | 9d6e8d99d2b1 |
children |
line wrap: on
line source
/* * This module implements all functions related to sending outgoing PDUs * to the SMPP server. */ #include <sys/types.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <strings.h> #include <unistd.h> extern int tcpsock; static unsigned req_out_seq = 1; static void pdu_to_tcp(pdu, pdulen) u_char *pdu; unsigned pdulen; { int cc; cc = write(tcpsock, pdu, pdulen); if (cc != pdulen) { perror("write to TCP socket"); log_fatal_error("error writing to TCP socket"); exit(1); } } void send_bind_req(system_id, password) char *system_id, *password; { u_char bind_req[64], *dp; unsigned bind_req_len, slen; dp = bind_req + 4; /* length will be filled last */ /* command_id */ *dp++ = 0; *dp++ = 0; *dp++ = 0; *dp++ = 0x09; /* bind_transceiver */ /* empty command_status */ *dp++ = 0; *dp++ = 0; *dp++ = 0; *dp++ = 0; /* sequence_number */ *dp++ = 0; *dp++ = 0; *dp++ = 0; *dp++ = 1; /* system_id */ slen = strlen(system_id) + 1; bcopy(system_id, dp, slen); dp += slen; /* password */ slen = strlen(password) + 1; bcopy(password, dp, slen); dp += slen; /* system_type */ strcpy(dp, "SMPP"); dp += 5; /* interface_version */ *dp++ = 0x34; /* addr_ton */ *dp++ = 0; /* addr_npi */ *dp++ = 0; /* address_range */ *dp++ = 0; bind_req_len = dp - bind_req; bind_req[0] = bind_req_len >> 24; bind_req[1] = bind_req_len >> 16; bind_req[2] = bind_req_len >> 8; bind_req[3] = bind_req_len; pdu_to_tcp(bind_req, bind_req_len); log_sent_pdu(bind_req, bind_req_len); } void send_enq_link_resp(rx_hdr) u_char *rx_hdr; { u_char resp[16]; /* command_length */ resp[0] = 0; resp[1] = 0; resp[2] = 0; resp[3] = 16; /* command_id */ resp[4] = rx_hdr[4] | 0x80; resp[5] = rx_hdr[5]; resp[6] = rx_hdr[6]; resp[7] = rx_hdr[7]; /* command_status */ resp[8] = 0; resp[9] = 0; resp[10] = 0; resp[11] = 0; /* sequence_number */ resp[12] = rx_hdr[12]; resp[13] = rx_hdr[13]; resp[14] = rx_hdr[14]; resp[15] = rx_hdr[15]; /* good to go */ pdu_to_tcp(resp, 16); } void send_message_resp(rx_hdr) u_char *rx_hdr; { u_char resp[17]; /* command_length */ resp[0] = 0; resp[1] = 0; resp[2] = 0; resp[3] = 17; /* command_id */ resp[4] = rx_hdr[4] | 0x80; resp[5] = rx_hdr[5]; resp[6] = rx_hdr[6]; resp[7] = rx_hdr[7]; /* command_status */ resp[8] = 0; resp[9] = 0; resp[10] = 0; resp[11] = 0; /* sequence_number */ resp[12] = rx_hdr[12]; resp[13] = rx_hdr[13]; resp[14] = rx_hdr[14]; resp[15] = rx_hdr[15]; /* empty message_id */ resp[16] = 0; /* good to go */ pdu_to_tcp(resp, 17); log_sent_pdu(resp, 17); } void send_pdu_from_localsock(pdu, pdulen) u_char *pdu; unsigned pdulen; { /* assign incrementing sequence number */ req_out_seq++; if (req_out_seq > 0x7FFFFFFF) req_out_seq = 1; pdu[12] = req_out_seq >> 24; pdu[13] = req_out_seq >> 16; pdu[14] = req_out_seq >> 8; pdu[15] = req_out_seq; /* good to go */ pdu_to_tcp(pdu, pdulen); log_sent_pdu(pdu, pdulen); }