source: ntrip/trunk/BNC/bncnetqueryv1.cpp@ 1551

Last change on this file since 1551 was 1535, checked in by mervart, 15 years ago

* empty log message *

File size: 4.7 KB
RevLine 
[1382]1/* -------------------------------------------------------------------------
2 * BKG NTRIP Client
3 * -------------------------------------------------------------------------
4 *
[1383]5 * Class: bncNetQueryV1
[1382]6 *
7 * Purpose: Blocking Network Requests (NTRIP Version 1)
8 *
9 * Author: L. Mervart
10 *
11 * Created: 27-Dec-2008
12 *
13 * Changes:
14 *
15 * -----------------------------------------------------------------------*/
16
17#include <iostream>
18#include <iomanip>
19
[1385]20#include "bncnetqueryv1.h"
[1535]21#include "bncsettings.h"
[1382]22
23using namespace std;
24
25#define BNCVERSION "1.7"
26
27// Constructor
28////////////////////////////////////////////////////////////////////////////
[1383]29bncNetQueryV1::bncNetQueryV1() {
[1500]30 _socket = 0;
31 _timeOut = 20000;
[1382]32}
33
34// Destructor
35////////////////////////////////////////////////////////////////////////////
[1383]36bncNetQueryV1::~bncNetQueryV1() {
[1382]37 delete _socket;
38}
39
40//
41////////////////////////////////////////////////////////////////////////////
[1390]42void bncNetQueryV1::stop() {
[1408]43#ifndef sparc
44 if (_socket) {
45 _socket->abort();
46 }
47#endif
[1403]48 _status = finished;
[1390]49}
50
51//
52////////////////////////////////////////////////////////////////////////////
[1402]53void bncNetQueryV1::waitForRequestResult(const QUrl&, QByteArray&) {
[1382]54}
55
56//
57////////////////////////////////////////////////////////////////////////////
[1384]58void bncNetQueryV1::waitForReadyRead(QByteArray& outData) {
[1500]59 if (_socket && _socket->state() == QAbstractSocket::ConnectedState) {
60 while (true) {
61 int nBytes = _socket->bytesAvailable();
62 if (nBytes > 0) {
63 outData = _socket->readAll();
64 return;
65 }
66 else if (!_socket->waitForReadyRead(_timeOut)) {
67 delete _socket;
68 _socket = 0;
69 _status = error;
70 emit newMessage(_url.path().toAscii() + " read timeout", true);
71 return;
72 }
[1402]73 }
74 }
[1382]75}
76
77// Connect to Caster, send the Request
78////////////////////////////////////////////////////////////////////////////
[1384]79void bncNetQueryV1::startRequest(const QUrl& url, const QByteArray& gga) {
[1382]80
[1385]81 _status = running;
82
[1382]83 delete _socket;
84 _socket = new QTcpSocket();
85
[1385]86 // Default scheme and path
87 // -----------------------
[1500]88 _url = url;
89 if (_url.scheme().isEmpty()) {
90 _url.setScheme("http");
[1385]91 }
[1500]92 if (_url.path().isEmpty()) {
93 _url.setPath("/");
[1385]94 }
95
[1382]96 // Connect the Socket
97 // ------------------
[1535]98 bncSettings settings;
[1382]99 QString proxyHost = settings.value("proxyHost").toString();
100 int proxyPort = settings.value("proxyPort").toInt();
101
102 if ( proxyHost.isEmpty() ) {
[1500]103 _socket->connectToHost(_url.host(), _url.port());
[1382]104 }
105 else {
106 _socket->connectToHost(proxyHost, proxyPort);
107 }
[1500]108 if (!_socket->waitForConnected(_timeOut)) {
[1382]109 delete _socket;
110 _socket = 0;
[1385]111 _status = error;
112 return;
[1382]113 }
114
115 // Send Request
116 // ------------
[1500]117 QString uName = QUrl::fromPercentEncoding(_url.userName().toAscii());
118 QString passW = QUrl::fromPercentEncoding(_url.password().toAscii());
[1382]119 QByteArray userAndPwd;
120
[1385]121 if(!uName.isEmpty() || !passW.isEmpty()) {
[1382]122 userAndPwd = "Authorization: Basic " + (uName.toAscii() + ":" +
123 passW.toAscii()).toBase64() + "\r\n";
124 }
125
126 QByteArray reqStr;
127 if ( proxyHost.isEmpty() ) {
[1500]128 if (_url.path().indexOf("/") != 0) _url.setPath("/");
129 reqStr = "GET " + _url.path().toAscii() + " HTTP/1.0\r\n"
[1382]130 + "User-Agent: NTRIP BNC/" BNCVERSION "\r\n"
131 + userAndPwd + "\r\n";
132 } else {
[1500]133 reqStr = "GET " + _url.toEncoded() + " HTTP/1.0\r\n"
[1382]134 + "User-Agent: NTRIP BNC/" BNCVERSION "\r\n"
[1500]135 + "Host: " + _url.host().toAscii() + "\r\n"
[1382]136 + userAndPwd + "\r\n";
137 }
138
139 // NMEA string to handle VRS stream
140 // --------------------------------
[1385]141 if (!gga.isEmpty()) {
142 reqStr += gga + "\r\n";
[1382]143 }
144
145 _socket->write(reqStr, reqStr.length());
146
[1500]147 if (!_socket->waitForBytesWritten(_timeOut)) {
[1382]148 delete _socket;
149 _socket = 0;
[1385]150 _status = error;
[1500]151 emit newMessage(_url.path().toAscii() + " write timeout", true);
[1498]152 return;
[1382]153 }
[1498]154
155 // Read Caster Response
156 // --------------------
[1502]157 QStringList response;
[1498]158 while (true) {
[1500]159 if (!_socket->waitForReadyRead(_timeOut)) {
[1498]160 delete _socket;
161 _socket = 0;
162 _status = error;
[1500]163 emit newMessage(_url.path().toAscii() + " read timeout", true);
[1498]164 return;
165 }
166 if (_socket->canReadLine()) {
167 QString line = _socket->readLine();
[1502]168 response.push_back(line);
169 if (line.trimmed().isEmpty()) {
170 break;
171 }
[1534]172 if (line.indexOf("200 OK") != -1) {
[1502]173 response.clear();
[1498]174 break;
175 }
176 }
177 }
[1502]178 if (response.size() > 0) {
179 delete _socket;
180 _socket = 0;
181 _status = error;
182 emit newMessage(_url.path().toAscii() + " wrong caster response\n" +
183 response.join("\n").toAscii(), true);
184 }
[1382]185}
186
Note: See TracBrowser for help on using the repository browser.