Vodafone Test Suite

Dependencies:   mbed-rtos mbed HTTPClient VodafoneUSBModem

main.cpp

Committer:
ashleymills
Date:
2012-08-22
Revision:
0:6d8a9f4b2cc6
Child:
1:0d63e4db8503

File content as of revision 0:6d8a9f4b2cc6:

#define __DEBUG__ 4 //Maximum verbosity
#ifndef __MODULE__
#define __MODULE__ "net_3g_basic_http_test.cpp"
#endif

#include "mbed.h"
#include "socket/bsd_socket.h"

#include "rtos.h"

#include "VodafoneUSBModem.h"

DigitalOut led1(LED1);
DigitalOut led2(LED2);
DigitalOut led3(LED3);
DigitalOut led4(LED4);

extern "C" void HardFault_Handler()
{
  error("Hard Fault!\n");
}

void test(void const*) {
  VodafoneUSBModem modem;
  // socket stuff
  int sockfd;
  uint16_t port = 3232;
  struct sockaddr_in serverAddress;
  struct hostent *server;
  char urlBuffer[128];
  int urlBufferLength = 128;

  // declare space for phone number and message storage
  char numBuffer[20], msgBuffer[512];
  size_t numSMS; // variable to track number of received messages

  DBG("Hello!");
  
  modem.sendUSSD("*#100#", msgBuffer, 512);
  
  DBG("ussd: %s",msgBuffer);


  int ret = modem.connect("internet","web","web");
 
  if (ret == OK) {
    int count = 30;
    while(1) {
        int rssi;
        LinkMonitor::REGISTRATION_STATE regState;
        LinkMonitor::BEARER bearer;
        
        modem.getLinkState(&rssi, &regState, &bearer);
        DBG("RSSI: %d dBm; Reg state: %d; Bearer: %d", rssi, regState, bearer);

        DBG("Checking SM count");

        // retrieve the short message count into numSMS
        if(modem.getSMCount(&numSMS)==OK) {
            DBG("getSMCount success");
            DBG("numSMS: %d",numSMS);
            // check if any short messages have been received
            if(numSMS>0) {
                DBG("SM count > 0");
                // get the oldest short message in the queue
                if(modem.getSM(numBuffer,msgBuffer,256)==OK) {
                    DBG("message received");
                    DBG("num: %s",numBuffer);
                    DBG("msg: %s",msgBuffer);
                    
                    // connect to socket and push message
                    
                    // create the socket
                    if((sockfd=::socket(AF_INET,SOCK_STREAM,0))<0) { DBG("Error opening socket\r\n"); } else { DBG("Socket open\r\n"); }
                         
                    // create the socket address
                    std::memset(&serverAddress, 0, sizeof(struct sockaddr_in));
                    if((server=::gethostbyname("m2mthings.com"))==NULL)  {
                         DBG("Error resolving address, setting manually.");
                         serverAddress.sin_addr.s_addr = inet_addr("109.74.199.96");
                    } else {
                         DBG("Address resolved OK");
                         memcpy((char*)&serverAddress.sin_addr.s_addr, (char*)server->h_addr_list[0], server->h_length);
                    }
                    // set server address family
                    serverAddress.sin_family = AF_INET;
                    // set server port
                    serverAddress.sin_port = htons(port);
         
                    // do socket connect
                    DBG("Connecting socket to %s:%d", inet_ntoa(serverAddress.sin_addr), ntohs(serverAddress.sin_port));
                    if((ret=::connect(sockfd, (const struct sockaddr *)&serverAddress, sizeof(serverAddress)))<0) {
                         ::close(sockfd);
                         DBG("Could not connect");
                    } else {
                         DBG("Connection OK");
                    }
                    
                    DBG("Sending password");
                    ::write(sockfd,"hi3h892!",8);
                    
                    ret = ::recv(sockfd,urlBuffer,urlBufferLength,0);
                    if (ret<0) {
                        DBG("Error receiving ACK.");
                    } else {
                        DBG("Received(%d): %s",urlBufferLength,urlBuffer);
                        modem.sendSM(numBuffer,urlBuffer);
                    }
                    
                    ::close(sockfd);
    

                }
            }
        }
        // wait 500ms
        Thread::wait(1000);
    }
    
  }
  
  modem.disconnect();
  DBG("Disconnected");

  while (1) {
    Thread::wait(100);
  }
}

void keepAlive(void const*)
{
  while (1)
  {
    led1 = !led1;
    Thread::wait(500);
    led1 = !led1;
    Thread::wait(30000);
  }
}


int main() {

  DBG_INIT();
  DBG_SET_SPEED(115200);
  DBG_SET_NEWLINE("\r\n");

  Thread testTask(test, NULL, osPriorityNormal, 1024 * 5);
  keepAlive(NULL);

  return 0;
}