The Hiking Pal tracking device firmware. See full description on the detail page: https://www.hackster.io/bowenfeng/hiking-pal-v1-07c02d

Dependencies:   FXOS8700CQ MODSERIAL mbed

Fork of Avnet_ATT_Cellular_IOT by Avnet

Committer:
bowenfeng
Date:
Thu Dec 22 06:52:58 2016 +0000
Revision:
85:43d791cd5967
Parent:
84:0bf8168b690a
Child:
86:5ff234988f53
Report data using the allocated session. Remove hard coded IDs.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
fkellermavnet 68:6e311c747045 1 /* ===================================================================
fkellermavnet 68:6e311c747045 2 Copyright © 2016, AVNET Inc.
fkellermavnet 68:6e311c747045 3
fkellermavnet 68:6e311c747045 4 Licensed under the Apache License, Version 2.0 (the "License");
fkellermavnet 68:6e311c747045 5 you may not use this file except in compliance with the License.
fkellermavnet 68:6e311c747045 6 You may obtain a copy of the License at
fkellermavnet 68:6e311c747045 7
fkellermavnet 68:6e311c747045 8 http://www.apache.org/licenses/LICENSE-2.0
fkellermavnet 68:6e311c747045 9
fkellermavnet 68:6e311c747045 10 Unless required by applicable law or agreed to in writing,
fkellermavnet 68:6e311c747045 11 software distributed under the License is distributed on an
fkellermavnet 68:6e311c747045 12 "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
fkellermavnet 68:6e311c747045 13 either express or implied. See the License for the specific
fkellermavnet 68:6e311c747045 14 language governing permissions and limitations under the License.
fkellermavnet 68:6e311c747045 15
fkellermavnet 68:6e311c747045 16 ======================================================================== */
fkellermavnet 68:6e311c747045 17
stefanrousseau 55:3abf9e3f42e6 18 #include "mbed.h"
JMF 0:9d5134074d84 19 #include <cctype>
JMF 0:9d5134074d84 20 #include <string>
JMF 2:0e2ef866af95 21 #include "config_me.h"
stefanrousseau 4:f83bedd9cab4 22 #include "sensors.h"
stefanrousseau 61:f6b93129f954 23 #include "cell_modem.h"
stefanrousseau 11:e6602513730f 24 #include "hardware.h"
stefanrousseau 11:e6602513730f 25
stefanrousseau 61:f6b93129f954 26 I2C i2c(PTC11, PTC10); //SDA, SCL -- define the I2C pins being used
stefanrousseau 56:cb42ff383dab 27 MODSERIAL pc(USBTX, USBRX, 256, 256); // tx, rx with default tx, rx buffer sizes
stefanrousseau 63:90d7c69993cd 28 MODSERIAL mdm(PTD3, PTD2, 4096, 4096);
stefanrousseau 16:17c5916f2d12 29 DigitalOut led_green(LED_GREEN);
stefanrousseau 16:17c5916f2d12 30 DigitalOut led_red(LED_RED);
stefanrousseau 16:17c5916f2d12 31 DigitalOut led_blue(LED_BLUE);
JMF 0:9d5134074d84 32
bowenfeng 85:43d791cd5967 33 #define OK_COLOR 0x2
bowenfeng 85:43d791cd5967 34 #define ERROR_COLOR 0x1
bowenfeng 85:43d791cd5967 35
JMF 0:9d5134074d84 36
stefanrousseau 3:26b3cc155f39 37 //********************************************************************************************************************************************
stefanrousseau 12:7c94ec5069dc 38 //* Create string with sensor readings that can be sent to flow as an HTTP get
stefanrousseau 3:26b3cc155f39 39 //********************************************************************************************************************************************
bowenfeng 84:0bf8168b690a 40 K64F_Sensors_t SENSOR_DATA = {
stefanrousseau 12:7c94ec5069dc 41 .Temperature = "0",
stefanrousseau 12:7c94ec5069dc 42 .Humidity = "0",
stefanrousseau 12:7c94ec5069dc 43 .AccelX = "0",
stefanrousseau 12:7c94ec5069dc 44 .AccelY = "0",
stefanrousseau 12:7c94ec5069dc 45 .AccelZ = "0",
stefanrousseau 12:7c94ec5069dc 46 .MagnetometerX = "0",
stefanrousseau 12:7c94ec5069dc 47 .MagnetometerY = "0",
stefanrousseau 12:7c94ec5069dc 48 .MagnetometerZ = "0",
stefanrousseau 12:7c94ec5069dc 49 .AmbientLightVis = "0",
stefanrousseau 12:7c94ec5069dc 50 .AmbientLightIr = "0",
stefanrousseau 12:7c94ec5069dc 51 .UVindex = "0",
stefanrousseau 12:7c94ec5069dc 52 .Proximity = "0",
stefanrousseau 12:7c94ec5069dc 53 .Temperature_Si7020 = "0",
stefanrousseau 55:3abf9e3f42e6 54 .Humidity_Si7020 = "0",
stefanrousseau 55:3abf9e3f42e6 55 .Virtual_Sensor1 = "0",
stefanrousseau 55:3abf9e3f42e6 56 .Virtual_Sensor2 = "0",
stefanrousseau 55:3abf9e3f42e6 57 .Virtual_Sensor3 = "0",
stefanrousseau 55:3abf9e3f42e6 58 .Virtual_Sensor4 = "0",
stefanrousseau 55:3abf9e3f42e6 59 .Virtual_Sensor5 = "0",
stefanrousseau 55:3abf9e3f42e6 60 .Virtual_Sensor6 = "0",
stefanrousseau 55:3abf9e3f42e6 61 .Virtual_Sensor7 = "0",
stefanrousseau 71:45a5e426df81 62 .Virtual_Sensor8 = "0",
stefanrousseau 72:b500e1507b5f 63 .GPS_Satellites = "0",
stefanrousseau 71:45a5e426df81 64 .GPS_Latitude = "0",
stefanrousseau 71:45a5e426df81 65 .GPS_Longitude = "0",
stefanrousseau 71:45a5e426df81 66 .GPS_Altitude = "0",
stefanrousseau 71:45a5e426df81 67 .GPS_Speed = "0",
stefanrousseau 71:45a5e426df81 68 .GPS_Course = "0"
stefanrousseau 3:26b3cc155f39 69 };
stefanrousseau 12:7c94ec5069dc 70
bowenfeng 85:43d791cd5967 71 char hid[20] = {0};
bowenfeng 85:43d791cd5967 72 char sid[20] = {0};
bowenfeng 85:43d791cd5967 73 char sessionName[20] = {0};
bowenfeng 85:43d791cd5967 74
bowenfeng 84:0bf8168b690a 75 void display_app_firmware_version(void) {
bowenfeng 85:43d791cd5967 76 PUTS("\r\n\r\nHiking Pal Firmware: Release 1.0 - built: "__DATE__" "__TIME__"\r\n\r\n");
fkellermavnet 77:c65eae5b9958 77 }
fkellermavnet 77:c65eae5b9958 78
stefanrousseau 3:26b3cc155f39 79 //Periodic timer
stefanrousseau 3:26b3cc155f39 80 Ticker OneMsTicker;
stefanrousseau 3:26b3cc155f39 81 volatile bool bTimerExpiredFlag = false;
stefanrousseau 3:26b3cc155f39 82 int OneMsTicks = 0;
stefanrousseau 3:26b3cc155f39 83 int iTimer1Interval_ms = 1000;
stefanrousseau 3:26b3cc155f39 84 //********************************************************************************************************************************************
stefanrousseau 3:26b3cc155f39 85 //* Periodic 1ms timer tick
stefanrousseau 3:26b3cc155f39 86 //********************************************************************************************************************************************
bowenfeng 84:0bf8168b690a 87 void OneMsFunction() {
stefanrousseau 3:26b3cc155f39 88 OneMsTicks++;
bowenfeng 84:0bf8168b690a 89 if ((OneMsTicks % iTimer1Interval_ms) == 0) {
stefanrousseau 3:26b3cc155f39 90 bTimerExpiredFlag = true;
stefanrousseau 3:26b3cc155f39 91 }
stefanrousseau 3:26b3cc155f39 92 } //OneMsFunction()
stefanrousseau 3:26b3cc155f39 93
stefanrousseau 16:17c5916f2d12 94 //********************************************************************************************************************************************
stefanrousseau 16:17c5916f2d12 95 //* Set the RGB LED's Color
stefanrousseau 16:17c5916f2d12 96 //* LED Color 0=Off to 7=White. 3 bits represent BGR (bit0=Red, bit1=Green, bit2=Blue)
stefanrousseau 16:17c5916f2d12 97 //********************************************************************************************************************************************
bowenfeng 84:0bf8168b690a 98 void SetLedColor(unsigned char ucColor) {
stefanrousseau 16:17c5916f2d12 99 //Note that when an LED is on, you write a 0 to it:
stefanrousseau 16:17c5916f2d12 100 led_red = !(ucColor & 0x1); //bit 0
stefanrousseau 16:17c5916f2d12 101 led_green = !(ucColor & 0x2); //bit 1
stefanrousseau 16:17c5916f2d12 102 led_blue = !(ucColor & 0x4); //bit 2
stefanrousseau 16:17c5916f2d12 103 } //SetLedColor()
stefanrousseau 16:17c5916f2d12 104
bowenfeng 84:0bf8168b690a 105 void extract_longlong(const char* s, char v[]) {
bowenfeng 84:0bf8168b690a 106 long long value = strtoll(s, NULL, 0);
bowenfeng 84:0bf8168b690a 107 sprintf(v, "%lld", value);
bowenfeng 84:0bf8168b690a 108 }
bowenfeng 84:0bf8168b690a 109
bowenfeng 84:0bf8168b690a 110 void find_longlong(const char* s, const char* token, char v[]) {
bowenfeng 84:0bf8168b690a 111 const char* tokenBegin = strstr(s, token);
bowenfeng 84:0bf8168b690a 112 if (tokenBegin != 0) {
bowenfeng 84:0bf8168b690a 113 extract_longlong(tokenBegin + strlen(token), v);
bowenfeng 84:0bf8168b690a 114 }
bowenfeng 84:0bf8168b690a 115 }
bowenfeng 84:0bf8168b690a 116
bowenfeng 85:43d791cd5967 117 int send_receive(char* request, char* response) {
bowenfeng 85:43d791cd5967 118 int result = cell_modem_Sendreceive(request, response);
bowenfeng 85:43d791cd5967 119 SetLedColor(result ? OK_COLOR : ERROR_COLOR);
bowenfeng 85:43d791cd5967 120 return result;
bowenfeng 85:43d791cd5967 121 }
bowenfeng 85:43d791cd5967 122
bowenfeng 85:43d791cd5967 123 int send_only(char* request) {
bowenfeng 85:43d791cd5967 124 char response[512];
bowenfeng 85:43d791cd5967 125 return send_receive(request, response);
bowenfeng 85:43d791cd5967 126 }
bowenfeng 85:43d791cd5967 127
bowenfeng 84:0bf8168b690a 128 void find_first_hiking(char hikingId[]) {
bowenfeng 84:0bf8168b690a 129 char request[512];
bowenfeng 84:0bf8168b690a 130 char response[512];
bowenfeng 84:0bf8168b690a 131 sprintf(request, "GET %s/hikings HTTP/1.1\r\nHost: %s\r\n\r\n", FLOW_BASE_URL, MY_SERVER_URL);
bowenfeng 85:43d791cd5967 132 if (send_receive(&request[0], &response[0])) {
bowenfeng 84:0bf8168b690a 133 find_longlong(response, "\"id\":", hikingId);
bowenfeng 84:0bf8168b690a 134 }
bowenfeng 84:0bf8168b690a 135 }
bowenfeng 84:0bf8168b690a 136
bowenfeng 84:0bf8168b690a 137 void join_hiking(const char* hikingId, const char* name, char sessionId[]) {
bowenfeng 84:0bf8168b690a 138 char request[512];
bowenfeng 84:0bf8168b690a 139 char response[512];
bowenfeng 84:0bf8168b690a 140 sprintf(request, "GET %s/hikings/%s/sessions?name=%s HTTP/1.1\r\nHost: %s\r\n\r\n", FLOW_BASE_URL, hikingId, name, MY_SERVER_URL);
bowenfeng 85:43d791cd5967 141 if (send_receive(&request[0], &response[0])) {
bowenfeng 84:0bf8168b690a 142 find_longlong(response, "\"id\":", sessionId);
bowenfeng 84:0bf8168b690a 143 }
bowenfeng 84:0bf8168b690a 144 }
bowenfeng 84:0bf8168b690a 145
bowenfeng 85:43d791cd5967 146 void generate_move_request(char request[], const char* hid, const char* sid) {
bowenfeng 85:43d791cd5967 147 sprintf(
bowenfeng 85:43d791cd5967 148 request,
bowenfeng 85:43d791cd5967 149 "GET %s/hikings/%s/sessions/%s/moves?lat=%s&lng=%s HTTP/1.1\r\nHost: %s\r\n\r\n",
bowenfeng 85:43d791cd5967 150 FLOW_BASE_URL,
bowenfeng 85:43d791cd5967 151 hid,
bowenfeng 85:43d791cd5967 152 sid,
bowenfeng 85:43d791cd5967 153 SENSOR_DATA.GPS_Latitude,
bowenfeng 85:43d791cd5967 154 SENSOR_DATA.GPS_Longitude,
bowenfeng 85:43d791cd5967 155 MY_SERVER_URL);
bowenfeng 85:43d791cd5967 156 }
bowenfeng 85:43d791cd5967 157 void report_move(const char* hid, const char* sid) {
bowenfeng 85:43d791cd5967 158 char request[512];
bowenfeng 85:43d791cd5967 159 generate_move_request(request, hid, sid);
bowenfeng 85:43d791cd5967 160 send_only(&request[0]);
bowenfeng 85:43d791cd5967 161 }
bowenfeng 85:43d791cd5967 162
JMF 0:9d5134074d84 163 int main() {
stefanrousseau 72:b500e1507b5f 164 //delay so that the debug terminal can open after power-on reset:
fkellermavnet 77:c65eae5b9958 165 wait (5.0);
stefanrousseau 61:f6b93129f954 166 pc.baud(115200);
fkellermavnet 77:c65eae5b9958 167
fkellermavnet 77:c65eae5b9958 168 display_app_firmware_version();
fkellermavnet 77:c65eae5b9958 169
bowenfeng 85:43d791cd5967 170 PRINTF(GRN "Hiking Pal tracking device started!\r\n\r\n");
JMF 0:9d5134074d84 171
stefanrousseau 61:f6b93129f954 172 //Initialize the I2C sensors that are present
stefanrousseau 11:e6602513730f 173 sensors_init();
stefanrousseau 12:7c94ec5069dc 174 read_sensors();
stefanrousseau 11:e6602513730f 175
stefanrousseau 61:f6b93129f954 176 // Set LED to RED until init finishes
stefanrousseau 61:f6b93129f954 177 SetLedColor(0x1); //Red
JMF 0:9d5134074d84 178 // Initialize the modem
stefanrousseau 64:09004cd610df 179 PRINTF("\r\n");
stefanrousseau 61:f6b93129f954 180 cell_modem_init();
fkellermavnet 77:c65eae5b9958 181 display_wnc_firmware_rev();
fkellermavnet 77:c65eae5b9958 182
stefanrousseau 61:f6b93129f954 183 // Set LED BLUE for partial init
stefanrousseau 61:f6b93129f954 184 SetLedColor(0x4); //Blue
JMF 0:9d5134074d84 185
stefanrousseau 3:26b3cc155f39 186 //Create a 1ms timer tick function:
stefanrousseau 61:f6b93129f954 187 iTimer1Interval_ms = SENSOR_UPDATE_INTERVAL_MS;
stefanrousseau 3:26b3cc155f39 188 OneMsTicker.attach(OneMsFunction, 0.001f) ;
bowenfeng 84:0bf8168b690a 189
bowenfeng 84:0bf8168b690a 190 sprintf(sessionName, "IoT-kit-%d", rand() % 1000);
bowenfeng 84:0bf8168b690a 191
bowenfeng 84:0bf8168b690a 192 find_first_hiking(hid);
bowenfeng 84:0bf8168b690a 193 PRINTF("Found Hiking ID: ");
bowenfeng 84:0bf8168b690a 194 PRINTF(hid);
bowenfeng 84:0bf8168b690a 195 PRINTF("\r\n");
bowenfeng 84:0bf8168b690a 196
bowenfeng 84:0bf8168b690a 197 join_hiking(hid, sessionName, sid);
bowenfeng 84:0bf8168b690a 198 PRINTF("Allocated Session ID: ");
bowenfeng 84:0bf8168b690a 199 PRINTF(sid);
bowenfeng 84:0bf8168b690a 200 PRINTF("\r\n");
fkellermavnet 26:8d6e7e7cdcae 201
JMF 2:0e2ef866af95 202 // Send and receive data perpetually
JMF 2:0e2ef866af95 203 while(1) {
bowenfeng 84:0bf8168b690a 204 if (bTimerExpiredFlag) {
stefanrousseau 3:26b3cc155f39 205 bTimerExpiredFlag = false;
stefanrousseau 4:f83bedd9cab4 206 read_sensors(); //read available external sensors from a PMOD and the on-board motion sensor
bowenfeng 85:43d791cd5967 207 report_move(hid, sid);
stefanrousseau 3:26b3cc155f39 208 } //forever loop
JMF 0:9d5134074d84 209 }