2 Copyright 2004-2020 Chris Tallon
4 This file is part of VOMP.
6 VOMP is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 VOMP is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with VOMP. If not, see <https://www.gnu.org/licenses/>.
28 #include "vserverselect.h"
29 #include "messagequeue.h"
33 VConnect::VConnect(char* tServer)
36 boxstack = BoxStack::getInstance();
37 vdr = VDR::getInstance();
38 logger = Log::getInstance();
42 if (Video::getInstance()->getFormat() == Video::PAL)
44 setPosition(170, 200);
48 setPosition(160, 150);
57 vdr->cancelFindingServer();
64 logger->log("VConnect", Log::DEBUG, "Draw done");
67 int VConnect::handleCommand(int /* command */)
75 threadReqQuit = false;
76 connectThread = std::thread([this]
89 threadCond.notify_one();
94 void VConnect::threadMethod()
99 std::unique_lock<std::mutex> ul(threadMutex, std::defer_lock);
103 if (server) // Server is specified, fake a servers array
106 vdrserver.ip = new char[strlen(server)+1];
107 strcpy(vdrserver.ip, server);
108 vdrserver.name = new char[1];
109 vdrserver.name[0] = '\0';
110 vdrserver.port = 3024; // FIXME
111 servers.push_back(vdrserver);
115 setOneLiner(tr("Locating server"));
117 boxstack->update(this);
119 vdr->findServers(servers);
122 for(UINT k = 0; k < servers.size(); k++)
124 delete[] servers[k].ip;
125 delete[] servers[k].name;
132 if (servers.size() == 1)
139 VServerSelect* vs = new VServerSelect(servers, this);
142 boxstack->update(vs);
145 if (threadReqQuit) { ul.unlock(); return; }
152 for(UINT k = 0; k < servers.size(); k++)
154 delete[] servers[k].ip;
155 delete[] servers[k].name;
161 logger->log("VConnect", Log::NOTICE, "Connecting to server at %s %u", servers[selectedServer].ip, servers[selectedServer].port);
162 Wol::getInstance()->setWakeUpIP(servers[selectedServer].ip);
163 vdr->setServerIP(servers[selectedServer].ip);
164 vdr->setServerPort(servers[selectedServer].port);
166 // Clear the serverIPs vector
167 for(UINT k = 0; k < servers.size(); k++)
169 delete[] servers[k].ip;
170 delete[] servers[k].name;
175 setOneLiner(tr("Connecting to VDR"));
177 boxstack->update(this);
179 success = vdr->connect();
182 logger->log("VConnect", Log::DEBUG, "Connected ok, doing login");
183 unsigned int version_server_min,version_server_max,version_client;
185 success = vdr->doLogin(&version_server_min,&version_server_max,&version_client, Command::getInstance()->getASLList(), subtitles);
186 Command::getInstance()->setSubDefault(subtitles);
191 if (version_server_min >version_client || version_client > version_server_max) {
193 sprintf(buffer,"Version error: s min: %x s max: %x c: %x",version_server_min,version_server_max,version_client);
196 setOneLiner(tr("Login failed"));
203 setOneLiner(tr("Connection failed"));
208 boxstack->update(this);
213 logger->log("VConnect", Log::INFO, "Send VDR connected message");
214 Message* m = new Message(); // Must be done after this thread ends
216 m->to = Command::getInstance();
217 m->message = Message::VDR_CONNECTED;
218 MessageQueue::getInstance()->postMessage(m);
221 void VConnect::processMessage(Message* m)
223 if (m->message == Message::SERVER_SELECTED)
225 selectedServer = m->parameter;
226 threadCond.notify_one();