Petri Ingalsuo
/
C027_LT_Test3G
t3
Fork of C027_SupportTest by
Diff: main.cpp
- 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);