publish final code
Dependencies: WncControllerK64F
Fork of WNCInterface by
Diff: Sms/IOTSMS.h
- Revision:
- 7:fded23f50479
diff -r 7cda15f762fe -r fded23f50479 Sms/IOTSMS.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Sms/IOTSMS.h Thu Oct 06 21:17:18 2016 +0000 @@ -0,0 +1,90 @@ +/* ===================================================================== + Copyright © 2016, Avnet (R) + + Contributors: + * James M Flynn, www.em.avnet.com + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, + software distributed under the License is distributed on an + "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, + either express or implied. See the License for the specific + language governing permissions and limitations under the License. + + @file IOTSMS.h + @version 1.0 + @date Oct 2016 + +======================================================================== */ + +#ifndef WNCSms_H_ +#define WNCSms_H_ + +#include "mbed.h" +#include "rtos.h" + +#include "WNCInterface.h" +#include "RtosTimer.h" +#include "Callback.h" + +typedef struct SmsMsg { + string number; + string date; + string time; + string msg; + } WNCSmsMsg; + +/** Component to use the Short Messages Service (SMS) **/ +class WNCSms +{ +private: + unsigned int m_smsinit; + void m_smscheck(void); + uint32_t m_timer; + +protected: + WNCSmsMsg m_MsgText; + RtosTimer *m_SMStimer; + struct WncController_fk::WncController::WncSmsList m_smsmsgs; //use the WncSmsList structure to hold messages + mbed::Callback<void (WNCSmsMsg&)> m_callback; //pointer to the call-back function the user specified + +public: + WNCSms(); /** Create SMSInterface instance */ + + /** Initialize interface **/ + int init(uint32_t poll=0, void ((*cb)(WNCSmsMsg& s))=NULL); + + /** Send a SM + @param string& receiver's contact number + @param string& the message to send + @return 0 on success, error code on failure + */ + int send(const string& number, const string& message); + + + /** Receive a SM + @param string Pointer to the sender's phone number + @param string Pointer to store the the incoming message into + @return 0 on success, error code on failure + */ + int get(string& number, string& message); + + /** Get the users number to use for SMS messaging + @param none + @return character pointer on success, NULL on failure + */ + char * getSMSNbr( void ); + + /** Attached a callback function for a Receive SMS + @param fp(string&) a function that takes a string as an input argument + */ + void attach(void (*fp)(WNCSmsMsg& s)) {m_callback.attach(fp);} + +}; + +#endif /* WNCSms_H_ */