ACKme
/
wiconnect-http_get_example
Simple app demonstrating the HTTP GET feature of the WiConnect Host Library.
Revision 0:cc6ec9345a81, committed 2014-08-13
- Comitter:
- dan_ackme
- Date:
- Wed Aug 13 10:35:40 2014 +0000
- Child:
- 1:40ed62996887
- Commit message:
- Initial check-in
Changed in this revision
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Wiconnect.lib Wed Aug 13 10:35:40 2014 +0000 @@ -0,0 +1,1 @@ +http://mbed.org/teams/ACKme/code/Wiconnect/#d3cd02b201e1
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Wed Aug 13 10:35:40 2014 +0000 @@ -0,0 +1,135 @@ +/** + * @example http_get/example.cpp + * + * This is an example of using the http socket API to + * download a webpage. + * + * It works as follows: + * 1. Instantiate the WiConnect Library + * 2. Initiate Communication with WiFi Module + * 3. Issue a HTTP GET request (Note: The module must have valid network credentials See @ref web_setup/example.cpp) + * 4. Read the HTTP page and print + * 5. That's it! + * + */ + + +/****************************************************************************** + * Example Variables + */ + +// the URL of the webpage to GET +#define HTTP_URL "http://ack.me" + + + + + +/****************************************************************************** + * Includes + */ + +// include C library headers +#include <stdio.h> // needed for printf + +// include target specific defines +#include "target_config.h" +// include the Wiconnect Host Library API header +#include "Wiconnect.h" + + + + +/****************************************************************************** + * Global Defines + */ + + +// Serial used for printfs to terminal (i.e. NOT used for WiConnect) +static Serial consoleSerial(STDIO_UART_TX, STDIO_UART_RX); + + + +/****************************************************************************** + * Starting point of application + */ +int main(int argc, char **argv) +{ + consoleSerial.baud(115200); // console terminal to 115200 baud + + //------------------------------------------------------------------------- + // STEP 1: Instantiate WiConnect Library + //------------------------------------------------------------------------- + + // Setup wiconnect serial interface configuration + // Here we only specify the rx buffer size and not rx buffer pointer, this means + // The serial RX buffer will be dynamically allocated + SerialConfig serialConfig(WICONNECT_RX_PIN, WICONNECT_TX_PIN, 256, NULL); + + // Instantiate and initialize the Wiconnect library + // Here we only specify the buffer size and not buffer pointer, this means + // The internal buffer will be dynamically allocated + Wiconnect wiconnect(serialConfig, 256, NULL, WICONNECT_RESET_PIN); + + // set the default timeout to 15s as some websites take awhile to respond + wiconnect.setCommandDefaultTimeout(15000); + + //------------------------------------------------------------------------- + // STEP 2: Initiate Communication with WiFi Module + //------------------------------------------------------------------------- + + printf("Initializing WiConnect Library...\r\n"); + + // Initialize communication with WiFi module + if(wiconnect.init(true) != WICONNECT_SUCCESS) + { + printf("Failed to initialize communication with WiFi module!\r\n" + "Make sure the wires are connected correctly\r\n"); + for(;;); // infinite loop + } + + + //------------------------------------------------------------------------- + // STEP 3: Issue a HTTP GET request + //------------------------------------------------------------------------- + + // Initiate a socket with an RX buffer of 256 bytes + // We're not specifying the rx buffer pointer so that means it's dynamically allocated + Socket socket(256); + + + printf("Issuing HTTP Request: %s\r\n", HTTP_URL); + + // Issue HTTP request + // NOTE: the module must have valid network credentials + if(wiconnect.httpGet(socket, HTTP_URL) != WICONNECT_SUCCESS) + { + printf("Failed to issue HTTP request. Does the module have valid network credentials?\r\n"); + for(;;); // infinite loop + } + + //------------------------------------------------------------------------- + // STEP 4: Read the HTTP page and print + //------------------------------------------------------------------------- + + uint8_t *dataPtr; + uint16_t dataLength; + + // while there's data to read, retreive and print it + while(socket.read(&dataPtr, &dataLength) == WICONNECT_SUCCESS) + { + fwrite(dataPtr, 1, dataLength, stdout); + } + + //------------------------------------------------------------------------- + // STEP 5: Done! + //------------------------------------------------------------------------- + + printf("HTTP GET example has completed!\r\n"); + + for(;;); // infinite loop + + return 0; +} + +
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed.bld Wed Aug 13 10:35:40 2014 +0000 @@ -0,0 +1,1 @@ +http://mbed.org/users/mbed_official/code/mbed/builds/6213f644d804 \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/target_config.h Wed Aug 13 10:35:40 2014 +0000 @@ -0,0 +1,73 @@ +/* + * Copyright 2014, ACKme Networks + * All Rights Reserved. + * + * This is UNPUBLISHED PROPRIETARY SOURCE CODE of ACKme Networks; + * the contents of this file may not be disclosed to third parties, copied + * or duplicated in any form, in whole or in part, without the prior + * written permission of ACKme Networks. + */ + +#pragma once + + +// The BAUD rate your PC/MAC/Linux terminal uses with the eval board +#define CONSOLE_BAUD 115200 + + +// Uncomment this to enable WiConnect serial interface hardware flow control +// NOTE: your platform must support the serial flow control api functions +//#define ENABLE_FLOW_CONTROL + + +#define WICONNECT_INTERNAL_BUFFER_SIZE (4*1024) +#define WICONNECT_SERIAL_RX_BUFFER_SIZE (4*1024) + +#define DEFAULT_CMD_GETCHAR_TIMEOUT 250 +#define DEFAULT_COMMAND_LINE_LENGTH_MAX 128 +#define DEFAULT_COMMAND_MAX_HISTORY 16 +#define DEFAULT_CMD_PROMPT_STR "> " +#define DEFAULT_COMMAND_MAX_ARGV 16 + +#define TEST_NONBLOCKING_API false +#define TEST_BUFFER_LENGTH 4*1024 + + +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +// Seabass Target Configuration +#ifdef TARGET_SEABASS + +#define WICONNECT_TX_PIN PA_9 +#define WICONNECT_RX_PIN PA_10 +#define WICONNECT_RESET_PIN PB_0 +#define WICONNECT_WAKE_PIN NC + +#ifdef ENABLE_FLOW_CONTROL +#define WICONNECT_CTS_PIN PA_11 +#define WICONNECT_RTS_PIN PA_12 +#else +#define WICONNECT_CTS_PIN NC +#define WICONNECT_RTS_PIN NC +#endif + +#endif + + +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +// Nucleo F401RE Target Configuration +#ifdef TARGET_NUCLEO_F401RE + +#define WICONNECT_TX_PIN PA_9 +#define WICONNECT_RX_PIN PA_10 +#define WICONNECT_RESET_PIN PC_7 +#define WICONNECT_WAKE_PIN NC + +#ifdef ENABLE_FLOW_CONTROL +#define WICONNECT_CTS_PIN PA_11 +#define WICONNECT_RTS_PIN PA_12 +#else +#define WICONNECT_CTS_PIN NC +#define WICONNECT_RTS_PIN NC +#endif + +#endif