Used in Live Traffic Update Nokia LCD Display Project

Fork of NetServices by Segundo Equipo

Committer:
rrajan8
Date:
Wed Mar 06 19:07:23 2013 +0000
Revision:
8:92b57208ab99
Parent:
0:ac1725ba162c
This project utilizes mbed's networking features to display live traffic updates on the Nokia LCD using the MapQuest API's Traffic Web Service.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
segundo 0:ac1725ba162c 1
segundo 0:ac1725ba162c 2 /*
segundo 0:ac1725ba162c 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
segundo 0:ac1725ba162c 4
segundo 0:ac1725ba162c 5 Permission is hereby granted, free of charge, to any person obtaining a copy
segundo 0:ac1725ba162c 6 of this software and associated documentation files (the "Software"), to deal
segundo 0:ac1725ba162c 7 in the Software without restriction, including without limitation the rights
segundo 0:ac1725ba162c 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
segundo 0:ac1725ba162c 9 copies of the Software, and to permit persons to whom the Software is
segundo 0:ac1725ba162c 10 furnished to do so, subject to the following conditions:
segundo 0:ac1725ba162c 11
segundo 0:ac1725ba162c 12 The above copyright notice and this permission notice shall be included in
segundo 0:ac1725ba162c 13 all copies or substantial portions of the Software.
segundo 0:ac1725ba162c 14
segundo 0:ac1725ba162c 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
segundo 0:ac1725ba162c 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
segundo 0:ac1725ba162c 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
segundo 0:ac1725ba162c 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
segundo 0:ac1725ba162c 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
segundo 0:ac1725ba162c 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
segundo 0:ac1725ba162c 21 THE SOFTWARE.
segundo 0:ac1725ba162c 22 */
segundo 0:ac1725ba162c 23
segundo 0:ac1725ba162c 24 #include "HTTPMap.h"
segundo 0:ac1725ba162c 25 #include "../../util/url.h"
segundo 0:ac1725ba162c 26
segundo 0:ac1725ba162c 27 //#define __DEBUG
segundo 0:ac1725ba162c 28 #include "dbg/dbg.h"
segundo 0:ac1725ba162c 29
segundo 0:ac1725ba162c 30 HTTPMap::HTTPMap(const string& keyValueSep /*= "="*/, const string& pairSep /*= "&"*/) :
segundo 0:ac1725ba162c 31 HTTPData(), Dictionary(), m_buf(), m_len(0), m_chunked(false), m_keyValueSep(keyValueSep), m_pairSep(pairSep)
segundo 0:ac1725ba162c 32 {
segundo 0:ac1725ba162c 33
segundo 0:ac1725ba162c 34 }
segundo 0:ac1725ba162c 35
segundo 0:ac1725ba162c 36 HTTPMap::~HTTPMap()
segundo 0:ac1725ba162c 37 {
segundo 0:ac1725ba162c 38
segundo 0:ac1725ba162c 39 }
segundo 0:ac1725ba162c 40
segundo 0:ac1725ba162c 41 void HTTPMap::clear()
segundo 0:ac1725ba162c 42 {
segundo 0:ac1725ba162c 43 m_buf.clear();
segundo 0:ac1725ba162c 44 }
segundo 0:ac1725ba162c 45
segundo 0:ac1725ba162c 46 int HTTPMap::read(char* buf, int len)
segundo 0:ac1725ba162c 47 {
segundo 0:ac1725ba162c 48 memcpy( (void*)buf, (void*)m_buf.data(), len );
segundo 0:ac1725ba162c 49 m_buf.erase(0, len); //Erase these chars
segundo 0:ac1725ba162c 50 return len;
segundo 0:ac1725ba162c 51 }
segundo 0:ac1725ba162c 52
segundo 0:ac1725ba162c 53 int HTTPMap::write(const char* buf, int len)
segundo 0:ac1725ba162c 54 {
segundo 0:ac1725ba162c 55 m_buf.append( buf, len );
segundo 0:ac1725ba162c 56 if( ( m_chunked && !len ) ||
segundo 0:ac1725ba162c 57 ( !m_chunked && ( m_buf.length() >= m_len ) ) ) //Last chunk or EOF
segundo 0:ac1725ba162c 58 {
segundo 0:ac1725ba162c 59 parseString();
segundo 0:ac1725ba162c 60 }
segundo 0:ac1725ba162c 61 return len;
segundo 0:ac1725ba162c 62 }
segundo 0:ac1725ba162c 63
segundo 0:ac1725ba162c 64 string HTTPMap::getDataType() //Internet media type for Content-Type header
segundo 0:ac1725ba162c 65 {
segundo 0:ac1725ba162c 66 return "application/x-www-form-urlencoded";
segundo 0:ac1725ba162c 67 }
segundo 0:ac1725ba162c 68
segundo 0:ac1725ba162c 69 void HTTPMap::setDataType(const string& type) //Internet media type from Content-Type header
segundo 0:ac1725ba162c 70 {
segundo 0:ac1725ba162c 71 //Do not really care here
segundo 0:ac1725ba162c 72 }
segundo 0:ac1725ba162c 73
segundo 0:ac1725ba162c 74 int HTTPMap::getDataLen() //For Content-Length header
segundo 0:ac1725ba162c 75 {
segundo 0:ac1725ba162c 76 //This will be called before any read occurs, so let's generate our string object
segundo 0:ac1725ba162c 77 //Generate string
segundo 0:ac1725ba162c 78 generateString();
segundo 0:ac1725ba162c 79 return m_len;
segundo 0:ac1725ba162c 80 }
segundo 0:ac1725ba162c 81
segundo 0:ac1725ba162c 82 bool HTTPMap::getIsChunked() //For Transfer-Encoding header
segundo 0:ac1725ba162c 83 {
segundo 0:ac1725ba162c 84 return false; //We don't want to chunk this
segundo 0:ac1725ba162c 85 }
segundo 0:ac1725ba162c 86
segundo 0:ac1725ba162c 87 void HTTPMap::setIsChunked(bool chunked) //From Transfer-Encoding header
segundo 0:ac1725ba162c 88 {
segundo 0:ac1725ba162c 89 m_chunked = chunked;
segundo 0:ac1725ba162c 90 }
segundo 0:ac1725ba162c 91
segundo 0:ac1725ba162c 92 void HTTPMap::setDataLen(int len) //From Content-Length header, or if the transfer is chunked, next chunk length
segundo 0:ac1725ba162c 93 {
segundo 0:ac1725ba162c 94 m_len += len; //Useful so that we can parse string when last byte is written if not chunked
segundo 0:ac1725ba162c 95 m_buf.reserve( m_len );
segundo 0:ac1725ba162c 96 }
segundo 0:ac1725ba162c 97
segundo 0:ac1725ba162c 98 void HTTPMap::generateString()
segundo 0:ac1725ba162c 99 {
segundo 0:ac1725ba162c 100 Dictionary::iterator it;
segundo 0:ac1725ba162c 101 bool first = true;
segundo 0:ac1725ba162c 102 while( !Dictionary::empty() )
segundo 0:ac1725ba162c 103 {
segundo 0:ac1725ba162c 104 if(!first)
segundo 0:ac1725ba162c 105 {
segundo 0:ac1725ba162c 106 m_buf.append( m_pairSep );
segundo 0:ac1725ba162c 107 }
segundo 0:ac1725ba162c 108 else
segundo 0:ac1725ba162c 109 {
segundo 0:ac1725ba162c 110 first = false;
segundo 0:ac1725ba162c 111 }
segundo 0:ac1725ba162c 112 it = Dictionary::begin();
segundo 0:ac1725ba162c 113 m_buf.append( Url::encode( (*it).first ) );
segundo 0:ac1725ba162c 114 m_buf.append( m_keyValueSep );
segundo 0:ac1725ba162c 115 m_buf.append( Url::encode( (*it).second ) );
segundo 0:ac1725ba162c 116 Dictionary::erase(it); //Free memory as we process data
segundo 0:ac1725ba162c 117 }
segundo 0:ac1725ba162c 118 m_len = m_buf.length();
segundo 0:ac1725ba162c 119 DBG("\r\nData [len %d]:\r\n%s\r\n", m_len, m_buf.c_str());
segundo 0:ac1725ba162c 120 }
segundo 0:ac1725ba162c 121
segundo 0:ac1725ba162c 122 void HTTPMap::parseString()
segundo 0:ac1725ba162c 123 {
segundo 0:ac1725ba162c 124 string key;
segundo 0:ac1725ba162c 125 string value;
segundo 0:ac1725ba162c 126
segundo 0:ac1725ba162c 127 int pos = 0;
segundo 0:ac1725ba162c 128
segundo 0:ac1725ba162c 129 int key_pos;
segundo 0:ac1725ba162c 130 int key_len;
segundo 0:ac1725ba162c 131
segundo 0:ac1725ba162c 132 int value_pos;
segundo 0:ac1725ba162c 133 int value_len;
segundo 0:ac1725ba162c 134
segundo 0:ac1725ba162c 135 bool eof = false;
segundo 0:ac1725ba162c 136 while(!eof)
segundo 0:ac1725ba162c 137 {
segundo 0:ac1725ba162c 138 key_pos = pos;
segundo 0:ac1725ba162c 139 value_pos = m_buf.find(m_keyValueSep, pos);
segundo 0:ac1725ba162c 140 if(value_pos < 0)
segundo 0:ac1725ba162c 141 {
segundo 0:ac1725ba162c 142 //Parse error, break
segundo 0:ac1725ba162c 143 break;
segundo 0:ac1725ba162c 144 }
segundo 0:ac1725ba162c 145
segundo 0:ac1725ba162c 146 key_len = value_pos - key_pos;
segundo 0:ac1725ba162c 147
segundo 0:ac1725ba162c 148 value_pos+= m_keyValueSep.length();
segundo 0:ac1725ba162c 149
segundo 0:ac1725ba162c 150 pos = m_buf.find( m_pairSep, value_pos );
segundo 0:ac1725ba162c 151 if(pos < 0) //Not found
segundo 0:ac1725ba162c 152 {
segundo 0:ac1725ba162c 153 pos = m_buf.length();
segundo 0:ac1725ba162c 154 eof = true;
segundo 0:ac1725ba162c 155 }
segundo 0:ac1725ba162c 156
segundo 0:ac1725ba162c 157 value_len = pos - value_pos;
segundo 0:ac1725ba162c 158
segundo 0:ac1725ba162c 159 pos += m_pairSep.length();
segundo 0:ac1725ba162c 160
segundo 0:ac1725ba162c 161 //Append elenent
segundo 0:ac1725ba162c 162 Dictionary::operator[]( Url::decode( m_buf.substr(key_pos, key_len) ) ) = Url::decode( m_buf.substr(value_pos, value_len) );
segundo 0:ac1725ba162c 163 }
segundo 0:ac1725ba162c 164
segundo 0:ac1725ba162c 165 m_buf.clear(); //Free data
segundo 0:ac1725ba162c 166
segundo 0:ac1725ba162c 167 }