t3

Dependencies:   C027_Support

Fork of C027_SupportTest by u-blox

Revision:
34:bc82b26ec43b
Parent:
33:e27f40fada64
Child:
35:ead6b88cebeb
--- a/main.cpp	Thu Aug 11 07:12:02 2016 +0000
+++ b/main.cpp	Fri Sep 23 11:39:17 2016 +0000
@@ -20,19 +20,23 @@
 // These parameters are ignored for LISA-C200 variants and can be left NULL.
 //------------------------------------------------------------------------------------
 //! Set your secret SIM pin here (e.g. "1234"). Check your SIM manual.
-#define SIMPIN      "1922"
+#define SIMPIN      "1234"
 /*! The APN of your network operator SIM, sometimes it is "internet" check your 
     contract with the network operator. You can also try to look-up your settings in 
     google: https://www.google.de/search?q=APN+list */
-#define APN         NULL
+#define APN         "internet"
 //! Set the user name for your APN, or NULL if not needed
-#define USERNAME    NULL
+#define USERNAME    "dna"
 //! Set the password for your APN, or NULL if not needed
-#define PASSWORD    NULL 
+#define PASSWORD    "internet" 
 //------------------------------------------------------------------------------------
 
 //#define CELLOCATE
 
+AnalogIn temperature(A5);
+DigitalOut led1(LED1);
+
+
 int main(void)
 {
     int ret;
@@ -42,6 +46,32 @@
     char buf[512] = "";
 #endif
 
+    char buffer[500];
+    char csrfMiddleware[40]={0};
+    char csrfMiddleware2[50]={0};
+    char* buff; 
+
+    unsigned int macAddr[6] = {0x00,0x1d,0xc9,0x1b,0x94,0x3d};
+    int tlsData[256];
+    unsigned int TLSdata[2] = {1000,2000};
+    float lat=65.3256, lon=27.462;
+    unsigned int dataLen=0;
+    int contentLenStr[10];
+    int len=0, opcode=0, sleepTime=0;
+    char a[2];
+    char http_cmd[700] = {""};
+    
+    double la = 0, lo = 0;
+    bool mdmOk;
+
+    printf("Temperature1: %f \r\n", temperature.read());
+    printf("Temperature2: %3.3f \r\n", temperature.read()*100.0f);
+    led1 = (temperature > 0.5f) ? 1 : 0;
+    
+    printf("Voltage1: 0x%04X \r\n", temperature.read_u16());
+    printf("Voltage2: %f \r\n", temperature.read_u16()*(3.3/65536));
+    //float voltage = (f*(3.3/4096.0));
+
     // Create the GPS object
 #if 1   // use GPSI2C class
     GPSI2C gps;
@@ -50,28 +80,22 @@
 #endif
     // Create the modem object
     MDMSerial mdm; // use mdm(D1,D0) if you connect the cellular shield to a C027
-    //mdm.setDebug(4); // enable this for debugging issues 
+//    mdm.setDebug(4); // enable this for debugging issues 
+//    mdm.setDebug(1); // enable this for debugging issues 
     // initialize the modem 
     MDMParser::DevStatus devStatus = {};
     MDMParser::NetStatus netStatus = {};
-    bool mdmOk = mdm.init(SIMPIN, &devStatus);
-    mdm.dumpDevStatus(&devStatus);
+         
+    do {
+        mdmOk = mdm.init(SIMPIN, &devStatus);
+        wait(5);
+        mdm.dumpDevStatus(&devStatus);
+     
+        printf("mdmOk status=%d\r\n", mdmOk);
+        //wait(2);
+    }while (!mdmOk);
+    
     if (mdmOk) {
-#if 0
-        // file system API
-        const char* filename = "File";
-        char buf[] = "Hello World";
-        printf("writeFile \"%s\"\r\n", buf);
-        if (mdm.writeFile(filename, buf, sizeof(buf)))
-        {
-            memset(buf, 0, sizeof(buf));
-            int len = mdm.readFile(filename, buf, sizeof(buf));
-            if (len >= 0) 
-                printf("readFile %d \"%.*s\"\r\n", len, len, buf);
-            mdm.delFile(filename);
-        }
-#endif
-
         // wait until we are connected
         mdmOk = mdm.registerNet(&netStatus);
         mdm.dumpNetStatus(&netStatus);
@@ -87,123 +111,133 @@
             mdm.dumpIp(ip);
             printf("Make a Http Post Request\r\n");
             int socket = mdm.socketSocket(MDMParser::IPPROTO_TCP);
+            printf("Socket created: %d\r\n", socket);
             if (socket >= 0)
             {
-                mdm.socketSetBlocking(socket, 10000);
-                if (mdm.socketConnect(socket, "mbed.org", 80))
+                mdm.socketSetBlocking(socket, 10000);                
+                //if (mdm.socketConnect(socket, "mbed.org", 80))
+                if (mdm.socketConnect(socket, "212.116.37.180", 81))
                 {
-                    const char http[] = "GET /media/uploads/mbed_official/hello.txt HTTP/1.0\r\n\r\n";
-                    mdm.socketSend(socket, http, sizeof(http)-1);
+                    //const char http[] = "GET /media/uploads/mbed_official/hello.txt HTTP/1.0\r\n\r\n";
+                    //mdm.socketSend(socket, http, sizeof(http)-1);
+                    
+                    char http_cmdg[100] = "GET /cloudmgr/sensor/data/";
+                    strcat(http_cmdg, " HTTP/1.1");
+                    strcat(http_cmdg, "\r\n");
+                    strcat(http_cmdg, "Connection: keep-alive");
+                    strcat(http_cmdg, "\r\n");    
+                    strcat(http_cmdg, "Host: 212.116.37.180:81");    
+                    strcat(http_cmdg, "\r\n\r\n");
+                    strcat(http_cmdg, "\0");
+                    int leng = strlen(http_cmdg);
+                    printf("Sending %d chars to server:\r\n%s\r\n", leng, http_cmdg);
+                    //sock.send_all(http_cmdg, leng);
+                    mdm.socketSend(socket, http_cmdg, leng);
                 
-                    ret = mdm.socketRecv(socket, buf, sizeof(buf)-1);
-                    if (ret > 0)
-                        printf("Socket Recv \"%*s\"\r\n", ret, buf);
+                    ret = mdm.socketRecv(socket, buffer, sizeof(buffer)-1);
+                    if (ret > 0) {
+                        buffer[ret] = '\0';
+                        printf("Socket Recv \"%*s\"\r\n", ret, buffer);
+                        if(ret > 100) {
+                            buff=strstr(buffer, "csrftoken=");
+                            strncpy(csrfMiddleware, &buff[10], 32); 
+                            strncpy(csrfMiddleware2, &buff[0], 42); 
+                            printf("Received csrfMiddleware= %s\r\n", csrfMiddleware);
+                            printf("Received csrfMiddleware2= %s\r\n", csrfMiddleware2);
+                            //break;
+                        }
+                    }
+                    
+                    /*Prepare data to send to server*/
+                    printf("Prepare to POST\r\n");                    
+                    sprintf((char *)tlsData, "csrfmiddlewaretoken=%s&serial=%x%x%x%x%x%x&value=%d&gpslat=%f&gpslon=%f",
+                        csrfMiddleware, macAddr[0],macAddr[1],macAddr[2],macAddr[3],macAddr[4],macAddr[5], 4096-TLSdata[1], lat, lon); //req_value for POST
+                          
+                    dataLen = strlen((char const*)tlsData);
+                    sprintf((char *)&contentLenStr[0],"%d", dataLen);                    
+                    memset(buffer, 0, sizeof(buffer));
+                        
+                    /*Send a POST message to server*/
+                    //char http_cmd[700] = "POST /cloudmgr/sensor/data/";
+                    strcat(http_cmd, "POST /cloudmgr/sensor/data/");
+                    strcat(http_cmd, " HTTP/1.1");
+                    strcat(http_cmd, "\r\n");    
+                    strcat(http_cmd, "Connection: keep-alive");    
+                    strcat(http_cmd, "\r\n"); 
+                    strcat(http_cmd, "Host: 212.116.37.180:81");  
+                    strcat(http_cmd, "\r\n");   
+                    strcat(http_cmd, "Content-Type: application/x-www-form-urlencoded");
+                    strcat(http_cmd, "\r\n"); 
+                    strcat(http_cmd, "Content-Length: ");
+                    strcat(http_cmd, (char const*)contentLenStr);
+                    strcat(http_cmd, "\r\n");
+                    strcat(http_cmd, "Cookie: ");
+                    strcat(http_cmd, csrfMiddleware2);
+                    strcat(http_cmd, "\r\n\r\n");
+                    strcat(http_cmd, (char const*)tlsData);
+                    strcat(http_cmd, "\0");
+                    len = strlen(http_cmd);
+                    printf("Sending %d chars to server:\n%s\r\n", len, http_cmd);
+                    //sock.send_all(http_cmd, len);
+                    mdm.socketSend(socket, http_cmd, len);
+                    ret=1;    
+                    
+                    /*reveive answer message (sleeptime) from server*/      
+                    while (true) {
+                        ret = mdm.socketRecv(socket, buffer, sizeof(buffer)-1);
+                        if (ret <= 0) {
+                            printf("Received %d chars from server:\r\n%s\r\n", ret, buffer);
+                            break;
+                        }
+                        buffer[ret] = '\0';
+                    
+                        printf("Received %d chars from server:\r\n%s\r\n", ret, buffer);
+                        
+                        if((strncmp((char const*)buffer, "200", 3))) {
+                            strncpy(a, &buffer[ret-1], 1); 
+                            opcode = atoi(a);
+                            //printf("Received opcode= %d, %s\r\n", opcode, a);
+                            switch (opcode) {
+                                case 1 :
+                                  sleepTime = 5;
+                                  break;              
+                                case 2 :
+                                  sleepTime = 30;
+                                  break;
+                                case 3 :
+                                  sleepTime = 300;
+                                  break;
+                                default :
+                                  sleepTime = 5;
+                                  break; 
+                            }
+                            printf("Received sleeptime= %d\r\n", sleepTime);
+                            break;
+                            
+                        }
+                        else {
+                            break;
+                        }
+                    }    
+                        
                     mdm.socketClose(socket);
                 }
                 mdm.socketFree(socket);
             }
-            
-            int port = 7;
-            const char* host = "echo.u-blox.com";
-            MDMParser::IP ip = mdm.gethostbyname(host);
-            char data[] = "\r\nxxx Socket Hello World\r\n"
-#ifdef LARGE_DATA
-                        "00  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "01  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "02  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "03  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "04  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        
-                        "05  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "06  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "07  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "08  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "09  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-            
-                        "10  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "11  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "12  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "13  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "14  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        
-                        "15  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "16  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "17  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "18  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-                        "19  0123456789 0123456789 0123456789 0123456789 0123456789 \r\n"
-#endif            
-                        "End\r\n";
-                
-            printf("Testing TCP sockets with ECHO server\r\n");
-            socket = mdm.socketSocket(MDMParser::IPPROTO_TCP);
-            if (socket >= 0)
-            {
-                mdm.socketSetBlocking(socket, 10000);
-                if (mdm.socketConnect(socket, host, port)) {
-                    memcpy(data, "\r\nTCP", 5); 
-                    ret = mdm.socketSend(socket, data, sizeof(data)-1);
-                    if (ret == sizeof(data)-1) {
-                        printf("Socket Send %d \"%s\"\r\n", ret, data);
-                    }
-                    ret = mdm.socketRecv(socket, buf, sizeof(buf)-1);
-                    if (ret >= 0) {
-                        printf("Socket Recv %d \"%.*s\"\r\n", ret, ret, buf);
-                    }
-                    mdm.socketClose(socket);
-                }
-                mdm.socketFree(socket);
-            }
-
-            printf("Testing UDP sockets with ECHO server\r\n");
-            socket = mdm.socketSocket(MDMParser::IPPROTO_UDP, port);
-            if (socket >= 0)
-            {
-                mdm.socketSetBlocking(socket, 10000);
-                memcpy(data, "\r\nUDP", 5); 
-                ret = mdm.socketSendTo(socket, ip, port, data, sizeof(data)-1);
-                if (ret == sizeof(data)-1) {
-                    printf("Socket SendTo %s:%d " IPSTR " %d \"%s\"\r\n", host, port, IPNUM(ip), ret, data);
-                }
-                ret = mdm.socketRecvFrom(socket, &ip, &port, buf, sizeof(buf)-1);
-                if (ret >= 0) {
-                    printf("Socket RecvFrom " IPSTR ":%d %d \"%.*s\" \r\n", IPNUM(ip),port, ret, ret,buf);
-                }
-                mdm.socketFree(socket);
-            }
-            
             // disconnect  
             mdm.disconnect();
         }
-    
-        // http://www.geckobeach.com/cellular/secrets/gsmcodes.php
-        // http://de.wikipedia.org/wiki/USSD-Codes
-        const char* ussd = "*130#"; // You may get answer "UNKNOWN APPLICATION"
-        printf("Ussd Send Command %s\r\n", ussd);
-        ret = mdm.ussdCommand(ussd, buf);
-        if (ret > 0) 
-            printf("Ussd Got Answer: \"%s\"\r\n", buf);
+            
     }
+
+
  
     printf("SMS and GPS Loop\r\n");
     char link[128] = "";
     unsigned int i = 0xFFFFFFFF;
     const int wait = 100;
     bool abort = false;
-#ifdef CELLOCATE    
-    const int sensorMask = 3;  // Hybrid: GNSS + CellLocate       
-    const int timeoutMargin = 5; // seconds
-    const int submitPeriod = 60; // 1 minutes in seconds
-    const int targetAccuracy = 1; // meters
-    unsigned int j = submitPeriod * 1000/wait;
-    bool cellLocWait = false;
-    MDMParser::CellLocData loc;
-    
-    //Token can be released from u-blox site, when you got one replace "TOKEN" below 
-    if (!mdm.cellLocSrvHttp("TOKEN"))
-            mdm.cellLocSrvUdp();        
-    mdm.cellLocConfigSensor(1);   // Deep scan mode
-    //mdm.cellUnsolIndication(1);
-#endif
+
     //DigitalOut led(LED1);
     while (!abort) {
     //    led = !led;
@@ -218,7 +252,7 @@
                 if ((buf[0] == '$') || buf[1] == 'G') {
                     #define _CHECK_TALKER(s) ((buf[3] == s[0]) && (buf[4] == s[1]) && (buf[5] == s[2]))
                     if (_CHECK_TALKER("GLL")) {
-                        double la = 0, lo = 0;
+                        
                         char ch;
                         if (gps.getNmeaAngle(1,buf,len,la) && 
                             gps.getNmeaAngle(3,buf,len,lo) && 
@@ -241,26 +275,7 @@
             }
         }
 #endif        
-#ifdef CELLOCATE
-        if (mdmOk && (j++ == submitPeriod * 1000/wait)) {   
-            j=0;
-            printf("CellLocate Request\r\n");
-            mdm.cellLocRequest(sensorMask, submitPeriod-timeoutMargin, targetAccuracy);
-            cellLocWait = true;
-        }
-        if (cellLocWait && mdm.cellLocGet(&loc)){           
-            cellLocWait = false;     
-            printf("CellLocate position received, sensor_used: %d,  \r\n", loc.sensorUsed );           
-            printf("  latitude: %0.5f, longitude: %0.5f, altitute: %d\r\n", loc.latitue, loc.longitude, loc.altitutude);
-            if (loc.sensorUsed == 1)
-                printf("  uncertainty: %d, speed: %d, direction: %d, vertical_acc: %d, satellite used: %d \r\n", loc.uncertainty,loc.speed,loc.direction,loc.verticalAcc,loc.svUsed);        
-            if (loc.sensorUsed == 1 || loc.sensorUsed == 2)
-            sprintf(link, "I am here!\n"
-                        "https://maps.google.com/?q=%.5f,%.5f", loc.latitue, loc.longitude);       
-        }
-        if (cellLocWait && (j%100 == 0 ))
-            printf("Waiting for CellLocate...\r\n");                
-#endif        
+    
         if (mdmOk && (i++ == 5000/wait)) {
             i = 0;
             // check the network status
@@ -268,28 +283,114 @@
                 mdm.dumpNetStatus(&netStatus, fprintf, stdout);
             }
                 
-            // checking unread sms
-            int ix[8];
-            int n = mdm.smsList("REC UNREAD", ix, 8);
-            if (8 < n) n = 8;
-            while (0 < n--)
+
+            printf("Voltage A5: %f \r\n", temperature.read_u16()*(3.3/65536));
+            led1 = (temperature > 0.5f) ? 1 : 0;
+            
+            
+            
+            if (mdmOk)
             {
-                char num[32];
-                printf("Unread SMS at index %d\r\n", ix[n]);
-                if (mdm.smsRead(ix[n], num, buf, sizeof(buf))) {
-                    printf("Got SMS from \"%s\" with text \"%s\"\r\n", num, buf);
-                    printf("Delete SMS at index %d\r\n", ix[n]);
-                    mdm.smsDelete(ix[n]);
-                    // provide a reply
-                    const char* reply = "Hello my friend";
-                    if (strstr(buf, /*w*/"here are you"))
-                        reply = *link ? link : "I don't know"; // reply wil location link
-                    else if (strstr(buf, /*s*/"hutdown"))
-                        abort = true, reply = "bye bye";
-                    printf("Send SMS reply \"%s\" to \"%s\"\r\n", reply, num);
-                    mdm.smsSend(num, reply);
+                // join the internet connection 
+                MDMParser::IP ip = mdm.join(APN,USERNAME,PASSWORD);
+                if (ip == NOIP)
+                    printf("Not able to join network");
+                else
+                {
+                    mdm.dumpIp(ip);
+                    printf("Make a Http Post Request\r\n");
+                    int socket = mdm.socketSocket(MDMParser::IPPROTO_TCP);
+                    printf("Socket created: %d\r\n", socket);
+                    if (socket >= 0)
+                    {
+                        mdm.socketSetBlocking(socket, 10000);                
+                        //if (mdm.socketConnect(socket, "mbed.org", 80))
+                        if (mdm.socketConnect(socket, "212.116.37.180", 81))
+                        {
+                           
+                            printf("Prepare to POST\r\n");                    
+                            sprintf((char *)tlsData, "csrfmiddlewaretoken=%s&serial=%x%x%x%x%x%x&value=%d&gpslat=%f&gpslon=%f",
+                                csrfMiddleware, macAddr[0],macAddr[1],macAddr[2],macAddr[3],macAddr[4],macAddr[5], 65536-temperature.read_u16(), la, lo); //req_value for POST
+                                  
+                            dataLen = strlen((char const*)tlsData);
+                            sprintf((char *)&contentLenStr[0],"%d", dataLen);                    
+                            memset(buffer, 0, sizeof(buffer));
+                            memset(http_cmd, 0, sizeof(http_cmd));
+                                
+                            /*Send a POST message to server*/                            
+                            strcat(http_cmd, "POST /cloudmgr/sensor/data/");
+                            strcat(http_cmd, " HTTP/1.1");
+                            strcat(http_cmd, "\r\n");    
+                            strcat(http_cmd, "Connection: keep-alive");    
+                            strcat(http_cmd, "\r\n"); 
+                            strcat(http_cmd, "Host: 212.116.37.180:81");  
+                            strcat(http_cmd, "\r\n");   
+                            strcat(http_cmd, "Content-Type: application/x-www-form-urlencoded");
+                            strcat(http_cmd, "\r\n"); 
+                            strcat(http_cmd, "Content-Length: ");
+                            strcat(http_cmd, (char const*)contentLenStr);
+                            strcat(http_cmd, "\r\n");
+                            strcat(http_cmd, "Cookie: ");
+                            strcat(http_cmd, csrfMiddleware2);
+                            strcat(http_cmd, "\r\n\r\n");
+                            strcat(http_cmd, (char const*)tlsData);
+                            strcat(http_cmd, "\0");
+                            len = strlen(http_cmd);
+                            printf("Sending %d chars to server:\r\n%s\r\n", len, http_cmd);
+                            //sock.send_all(http_cmd, len);
+                            mdm.socketSend(socket, http_cmd, len);
+                            ret=1;    
+                            
+                            /*reveive answer message (sleeptime) from server*/      
+                            while (true) {
+                                ret = mdm.socketRecv(socket, buffer, sizeof(buffer)-1);
+                                if (ret <= 0) {
+                                    printf("Received %d chars from server:\r\n%s\r\n", ret, buffer);
+                                    break;
+                                }
+                                buffer[ret] = '\0';
+                            
+                                printf("Received %d chars from server:\r\n%s\r\n", ret, buffer);
+                                
+                                if((strncmp((char const*)buffer, "200", 3))) {
+                                    strncpy(a, &buffer[ret-1], 1); 
+                                    opcode = atoi(a);
+                                    //printf("Received opcode= %d, %s\r\n", opcode, a);
+                                    switch (opcode) {
+                                        case 1 :
+                                          sleepTime = 5;
+                                          break;              
+                                        case 2 :
+                                          sleepTime = 30;
+                                          break;
+                                        case 3 :
+                                          sleepTime = 300;
+                                          break;
+                                        default :
+                                          sleepTime = 5;
+                                          break; 
+                                    }
+                                    printf("Received sleeptime= %d\r\n", sleepTime);
+                                    break;
+                                    
+                                }
+                                else {
+                                    break;
+                                }
+                            }    
+                                
+                            mdm.socketClose(socket);
+                        }
+                        mdm.socketFree(socket);
+                    }
+                    // disconnect  
+                    mdm.disconnect();
                 }
+                    
             }
+            
+            
+            
         }
 #ifdef RTOS_H
         Thread::wait(wait);