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/>.
31 #include "vserverselect.h"
32 #include "messagequeue.h"
39 boxstack = BoxStack::getInstance();
40 vdr = VDR::getInstance();
41 logger = Log::getInstance();
45 if (Video::getInstance()->getFormat() == Video::PAL)
47 setPosition(170, 200);
51 setPosition(160, 150);
67 logger->log("VConnect", Log::DEBUG, "Draw done");
70 int VConnect::handleCommand(int /* command */)
78 threadReqQuit = false;
79 connectThread = std::thread([this]
92 vdr->abortConnect(); // If this and vdr are connecting, cancel it
93 threadCond.notify_one();
98 void VConnect::threadMethod()
100 logger->log("VConnect", Log::DEBUG, "start threadMethod");
105 std::unique_lock<std::mutex> ul(threadMutex, std::defer_lock);
107 std::string commandLineServer;
108 Config::getInstance()->getString("main", "argv_server", commandLineServer);
112 logger->log("VConnect", Log::CRIT, "Failed to init VDPC");
118 if (!commandLineServer.empty()) // Server is specified, fake a servers array
120 //servers.emplace_back(commandLineServer, "", 3024, 0);
121 vdpc.TEMPaddCLIServer(commandLineServer); // FIXME move to new config system NCONFIG
125 setOneLiner(tr("Locating server"));
127 boxstack->update(this);
129 if (threadReqQuit) return;
132 for (ULONG i = 0; i < vdpc.numServers(); i++)
133 logger->log("VConnect", Log::INFO, "Found server: %i %s %s %u", vdpc[i].ipVersion, vdpc[i].ip.c_str(), vdpc[i].name.c_str(), vdpc[i].port, vdpc[i].version);
135 if (vdpc.numServers() == 1)
142 VServerSelect* vs = new VServerSelect(vdpc, this);
145 boxstack->update(vs);
148 if (threadReqQuit) { ul.unlock(); return; }
153 if (threadReqQuit) return;
155 logger->log("VConnect", Log::NOTICE, "Connecting to server at %s %u", vdpc[selectedServer].ip.c_str(), vdpc[selectedServer].port);
156 Wol::getInstance()->setWakeUpIP(vdpc[selectedServer].ip.c_str());
157 vdr->setServerIP(vdpc[selectedServer].ip.c_str());
158 vdr->setServerPort(vdpc[selectedServer].port);
160 setOneLiner(tr("Connecting to VDR"));
162 boxstack->update(this);
164 if (threadReqQuit) return;
165 success = vdr->connect();
166 if (threadReqQuit) return;
170 logger->log("VConnect", Log::DEBUG, "Connected ok, doing login");
171 unsigned int version_server_min, version_server_max, version_client;
173 success = vdr->doLogin(&version_server_min, &version_server_max, &version_client, Control::getInstance()->getASLList(), subtitles);
174 Control::getInstance()->setSubDefault(subtitles);
179 if (version_server_min >version_client || version_client > version_server_max) {
181 sprintf(buffer,"Version error: s min: %x s max: %x c: %x",version_server_min,version_server_max,version_client);
184 setOneLiner(tr("Login failed"));
191 setOneLiner(tr("Connection failed"));
196 boxstack->update(this);
198 MILLISLEEP(delay); // FIXME wait on cond?
199 if (threadReqQuit) return;
202 logger->log("VConnect", Log::INFO, "Send VDR connected message");
203 Message* m = new Message(); // Must be done after this thread ends
205 m->p_to = Message::CONTROL;
206 m->message = Message::VDR_CONNECTED;
207 MessageQueue::getInstance()->postMessage(m);
210 void VConnect::processMessage(Message* m)
212 if (m->message == Message::SERVER_SELECTED)
214 selectedServer = m->parameter;
215 threadCond.notify_one();