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
Line 
1/* -------------------------------------------------------------------------
2 * BKG NTRIP Client
3 * -------------------------------------------------------------------------
4 *
5 * Class: bncNetQueryV1
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
20#include "bncnetqueryv1.h"
21#include "bncsettings.h"
22
23using namespace std;
24
25#define BNCVERSION "1.7"
26
27// Constructor
28////////////////////////////////////////////////////////////////////////////
29bncNetQueryV1::bncNetQueryV1() {
30 _socket = 0;
31 _timeOut = 20000;
32}
33
34// Destructor
35////////////////////////////////////////////////////////////////////////////
36bncNetQueryV1::~bncNetQueryV1() {
37 delete _socket;
38}
39
40//
41////////////////////////////////////////////////////////////////////////////
42void bncNetQueryV1::stop() {
43#ifndef sparc
44 if (_socket) {
45 _socket->abort();
46 }
47#endif
48 _status = finished;
49}
50
51//
52////////////////////////////////////////////////////////////////////////////
53void bncNetQueryV1::waitForRequestResult(const QUrl&, QByteArray&) {
54}
55
56//
57////////////////////////////////////////////////////////////////////////////
58void bncNetQueryV1::waitForReadyRead(QByteArray& outData) {
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 }
73 }
74 }
75}
76
77// Connect to Caster, send the Request
78////////////////////////////////////////////////////////////////////////////
79void bncNetQueryV1::startRequest(const QUrl& url, const QByteArray& gga) {
80
81 _status = running;
82
83 delete _socket;
84 _socket = new QTcpSocket();
85
86 // Default scheme and path
87 // -----------------------
88 _url = url;
89 if (_url.scheme().isEmpty()) {
90 _url.setScheme("http");
91 }
92 if (_url.path().isEmpty()) {
93 _url.setPath("/");
94 }
95
96 // Connect the Socket
97 // ------------------
98 bncSettings settings;
99 QString proxyHost = settings.value("proxyHost").toString();
100 int proxyPort = settings.value("proxyPort").toInt();
101
102 if ( proxyHost.isEmpty() ) {
103 _socket->connectToHost(_url.host(), _url.port());
104 }
105 else {
106 _socket->connectToHost(proxyHost, proxyPort);
107 }
108 if (!_socket->waitForConnected(_timeOut)) {
109 delete _socket;
110 _socket = 0;
111 _status = error;
112 return;
113 }
114
115 // Send Request
116 // ------------
117 QString uName = QUrl::fromPercentEncoding(_url.userName().toAscii());
118 QString passW = QUrl::fromPercentEncoding(_url.password().toAscii());
119 QByteArray userAndPwd;
120
121 if(!uName.isEmpty() || !passW.isEmpty()) {
122 userAndPwd = "Authorization: Basic " + (uName.toAscii() + ":" +
123 passW.toAscii()).toBase64() + "\r\n";
124 }
125
126 QByteArray reqStr;
127 if ( proxyHost.isEmpty() ) {
128 if (_url.path().indexOf("/") != 0) _url.setPath("/");
129 reqStr = "GET " + _url.path().toAscii() + " HTTP/1.0\r\n"
130 + "User-Agent: NTRIP BNC/" BNCVERSION "\r\n"
131 + userAndPwd + "\r\n";
132 } else {
133 reqStr = "GET " + _url.toEncoded() + " HTTP/1.0\r\n"
134 + "User-Agent: NTRIP BNC/" BNCVERSION "\r\n"
135 + "Host: " + _url.host().toAscii() + "\r\n"
136 + userAndPwd + "\r\n";
137 }
138
139 // NMEA string to handle VRS stream
140 // --------------------------------
141 if (!gga.isEmpty()) {
142 reqStr += gga + "\r\n";
143 }
144
145 _socket->write(reqStr, reqStr.length());
146
147 if (!_socket->waitForBytesWritten(_timeOut)) {
148 delete _socket;
149 _socket = 0;
150 _status = error;
151 emit newMessage(_url.path().toAscii() + " write timeout", true);
152 return;
153 }
154
155 // Read Caster Response
156 // --------------------
157 QStringList response;
158 while (true) {
159 if (!_socket->waitForReadyRead(_timeOut)) {
160 delete _socket;
161 _socket = 0;
162 _status = error;
163 emit newMessage(_url.path().toAscii() + " read timeout", true);
164 return;
165 }
166 if (_socket->canReadLine()) {
167 QString line = _socket->readLine();
168 response.push_back(line);
169 if (line.trimmed().isEmpty()) {
170 break;
171 }
172 if (line.indexOf("200 OK") != -1) {
173 response.clear();
174 break;
175 }
176 }
177 }
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 }
185}
186
Note: See TracBrowser for help on using the repository browser.