diff options
author | Mamadou DIOP <bossiel@yahoo.fr> | 2015-08-17 01:56:35 +0200 |
---|---|---|
committer | Mamadou DIOP <bossiel@yahoo.fr> | 2015-08-17 01:56:35 +0200 |
commit | 631fffee8a28b1bec5ed1f1d26a20e0135967f99 (patch) | |
tree | 74afe3bf3efe15aa82bcd0272b2b0f4d48c2d837 /tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h | |
parent | 7908865936604036e6f200f1b5e069f8752f3a3a (diff) | |
download | doubango-631fffee8a28b1bec5ed1f1d26a20e0135967f99.zip doubango-631fffee8a28b1bec5ed1f1d26a20e0135967f99.tar.gz |
-
Diffstat (limited to 'tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h')
-rw-r--r-- | tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h b/tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h new file mode 100644 index 0000000..4191a8f --- /dev/null +++ b/tinySMS/include/tinysms/tpdu/tsms_tpdu_submit.h @@ -0,0 +1,130 @@ +/* +* Copyright (C) 2009 Mamadou Diop. +* +* Contact: Mamadou Diop <diopmamadou(at)doubango.org> +* +* This file is part of Open Source Doubango Framework. +* +* DOUBANGO is free software: you can redistribute it and/or modify +* it under the terms of the GNU General Public License as published by +* the Free Software Foundation, either version 3 of the License, or +* (at your option) any later version. +* +* DOUBANGO 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 General Public License for more details. +* +* You should have received a copy of the GNU General Public License +* along with DOUBANGO. +* +*/ + +/**@file tsms_tpdu_submit.h + * @brief SMS TPDU SMS-SUBMIT (MO) message as per 3GPP TS 23.040 section 9.2.2.2. + * + * @author Mamadou Diop <diopmamadou(at)doubango.org> + * + + */ +#ifndef TINYSMS_TSMS_TPDU_SUBMIT_H +#define TINYSMS_TSMS_TPDU_SUBMIT_H + +#include "tinysms_config.h" + +#include "tinysms/tsms_common.h" + +TSMS_BEGIN_DECLS + + +/** SMS @a SMS-SUBMIT message as per 3GPP TS 23.040 section 9.2.2.2 +*/ +typedef struct tsms_tpdu_submit_s +{ + TSMS_DECLARE_TPDU_MESSAGE; + + tsms_address_t* smsc; + + /** TP Reject Duplicates (M - 1b) + * Parameter indicating whether or not the SC shall accept an SMS SUBMIT for an + * SM still held in the SC which has the same TP MR and the same TP DA as a + * previously submitted SM from the same OA. */ + unsigned rd:1; + /** TP Validity Period Format (M - 2b) + * Parameter indicating whether or not the TP VP field is present. */ + tsms_tpdu_vpf_t vpf; + /** TP Reply Path (M - 1b) + * Parameter indicating the request for Reply Path. */ + unsigned rp:1; + /** TP User Data Header Indicator (O - 1b) + * Parameter indicating that the TP UD field contains a Header. */ + unsigned udhi:1; + /** TP Status Report Request (O - 1b) + * Parameter indicating if the MS is requesting a status report. */ + unsigned srr:1; + /** TP Message Reference (M - I) + * Parameter identifying the SMS SUBMIT. */ + uint8_t mr; + /** TP Destination Address (M - 2-12o) + * Address of the destination SME. */ + tsms_address_t* da; + /** TP Protocol Identifier (M - o) + * Parameter identifying the above layer protocol, if any. */ + //(base)uint8_t pid; + /** TP Data Coding Scheme (M - o) + * Parameter identifying the coding scheme within the TP User Data. */ + //(base)uint8_t dcs; + /** TP Validity Period (O - o/7o) + * Parameter identifying the time from where the message is no longer valid. */ + uint8_t vp[7]; + /** TP User Data Length (M - I) + * Parameter indicating the length of the TP User Data field to follow. */ + //(base)uint8_t udl; + /** TP User Data (O - v) + * User data. */ + //(base)tsk_buffer_t* ud; +} +tsms_tpdu_submit_t; + +/** cast any pointer to tsms_tpdu_submit_t* */ +#define TSMS_TPDU_SUBMIT(self) ((tsms_tpdu_submit_t*)(self)) + +TINYSMS_API tsms_tpdu_submit_t* tsms_tpdu_submit_create(uint8_t mr, const tsms_address_string_t smsc, const tsms_address_string_t dest); + +/**@ingroup tsms_tpdu_group +* @def tsms_tpdu_submit_serialize +* Serializes a @a SMS-SUBMIT message as binary content. +* @param self A pointer to the @a SMS-SUBMIT (@ref tsms_tpdu_submit_t) message to serialize. +* @param output A pointer to the output buffer. Should be valid. +* @retval Zero if succeed and non-zero error code otherwise. +* +* See For more information, see @ref tsms_tpdu_group_SUBMIT "SMS-SUBMIT". +*/ +/**@ingroup tsms_tpdu_group +* @def tsms_tpdu_submit_tohexastring +* Serializes a @a SMS-SUBMIT message as hexa-string content. +* @param self A pointer to the @a SMS-SUBMIT (@ref tsms_tpdu_submit_t) message to serialize. +* @retval A pointer to the hexa-string if succeed and Null otherwise. +* +* See For more information, see @ref tsms_tpdu_group_SUBMIT "SMS-SUBMIT". +*/ +/**@ingroup tsms_tpdu_group +* @def tsms_tpdu_submit_set_userdata +* Sets the content of the @a SMS-SUBMIT message. +* @param self A pointer to the @a SMS-SUBMIT (@ref tsms_tpdu_submit_t). +* @param udata A pointer to the content. +* @param alpha The alphabet used to encode the content. +* @retval Zero if succeed and non-zero error code otherwise. +* +* See For more information, see @ref tsms_tpdu_group_SUBMIT "SMS-SUBMIT". +*/ +#define tsms_tpdu_submit_serialize(self, output) tsms_tpdu_message_serialize(TSMS_TPDU_MESSAGE(self), output, tsk_true) +#define tsms_tpdu_submit_tostring(self) tsms_tpdu_message_tostring(TSMS_TPDU_MESSAGE(self), tsk_true) +#define tsms_tpdu_submit_tohexastring(self) tsms_tpdu_message_tohexastring(TSMS_TPDU_MESSAGE(self), tsk_true) +#define tsms_tpdu_submit_set_userdata(self, udata, alpha) tsms_tpdu_message_set_userdata(TSMS_TPDU_MESSAGE(self), udata, alpha) + +TINYSMS_GEXTERN const tsk_object_def_t *tsms_tpdu_submit_def_t; + +TSMS_END_DECLS + +#endif /* TINYSMS_TSMS_TPDU_SUBMIT_H */ |