/** * Copyright (C) 2012, BMW AG * * This file is part of GENIVI Project AudioManager. * * Contributions are licensed to the GENIVI Alliance under one or more * Contribution License Agreements. * * \copyright * This Source Code Form is subject to the terms of the * Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with * this file, You can obtain one at http://mozilla.org/MPL/2.0/. * * * \author Christian Mueller, christian.ei.mueller@bmw.de BMW 2011,2012 * \author Frank Herchet, frank.fh.herchet@bmw.de BMW 2012 * * \file CAmTelnetMenuHelper.cpp * For further information see http://www.genivi.org/. * */ #include "CAmTelnetMenuHelper.h" #include #include "config.h" #include "CAmRouter.h" #include "CAmTelnetServer.h" #include "IAmDatabaseHandler.h" #include "CAmControlSender.h" #include "CAmCommandSender.h" #include "CAmRoutingSender.h" #include "CAmRoutingReceiver.h" #include "CAmCommandReceiver.h" #include "CAmControlReceiver.h" #include "shared/CAmDltWrapper.h" static const std::string COLOR_WELCOME("\033[1;33m\033[44m"); static const std::string COLOR_HEAD("\033[1m\033[42m"); static const std::string COLOR_DEFAULT("\033[0m"); namespace am { CAmTelnetMenuHelper* CAmTelnetMenuHelper::instance = NULL; /****************************************************************************/ CAmTelnetMenuHelper::CAmTelnetMenuHelper(CAmSocketHandler *iSocketHandler, CAmCommandSender *iCommandSender, CAmCommandReceiver *iCommandReceiver, CAmRoutingSender *iRoutingSender, CAmRoutingReceiver *iRoutingReceiver, CAmControlSender *iControlSender, CAmControlReceiver *iControlReceiver, IAmDatabaseHandler *iDatabasehandler, CAmRouter *iRouter, CAmTelnetServer *iTelnetServer) /****************************************************************************/ :mpTelenetServer(iTelnetServer), mpSocketHandler(iSocketHandler), mpCommandSender(iCommandSender), mpCommandReceiver(iCommandReceiver), mpRoutingSender(iRoutingSender), mpRoutingReceiver(iRoutingReceiver), mpControlSender(iControlSender), mpControlReceiver(iControlReceiver), mpDatabasehandler(iDatabasehandler), mpRouter(iRouter) { instance = this; createCommandMaps(); } /****************************************************************************/ CAmTelnetMenuHelper::~CAmTelnetMenuHelper() /****************************************************************************/ { } /****************************************************************************/ void CAmTelnetMenuHelper::createCommandMaps() /****************************************************************************/ { // ROOT commands mRootCommands.clear(); mRootCommands.insert(std::make_pair("help", sCommandPrototypeInfo("show all possible commands", &CAmTelnetMenuHelper::helpCommand))); mRootCommands.insert(std::make_pair("list", sCommandPrototypeInfo("Go into 'list'-submenu", &CAmTelnetMenuHelper::rootListCommand))); mRootCommands.insert(std::make_pair("info", sCommandPrototypeInfo("Go into 'info'-submenu", &CAmTelnetMenuHelper::rootInfoCommand))); mRootCommands.insert(std::make_pair("set", sCommandPrototypeInfo("Go into 'set'-submenu", &CAmTelnetMenuHelper::rootSetCommand))); mRootCommands.insert(std::make_pair("get", sCommandPrototypeInfo("Go into 'get'-submenu", &CAmTelnetMenuHelper::rootGetCommand))); mRootCommands.insert(std::make_pair("exit", sCommandPrototypeInfo("quit telnet session", &CAmTelnetMenuHelper::exitCommand))); // List commands mListCommands.insert(std::make_pair("help", sCommandPrototypeInfo(std::string("show all possible commands"), &CAmTelnetMenuHelper::helpCommand))); mListCommands.insert(std::make_pair("conn", sCommandPrototypeInfo("list all connections", &CAmTelnetMenuHelper::listConnectionsCommand))); mListCommands.insert(std::make_pair("sources", sCommandPrototypeInfo("list all available sources", &CAmTelnetMenuHelper::listSourcesCommand))); mListCommands.insert(std::make_pair("sinks", sCommandPrototypeInfo("list all available sinks", &CAmTelnetMenuHelper::listSinksCommands))); mListCommands.insert(std::make_pair("crfader", sCommandPrototypeInfo("list all crossfaders", &CAmTelnetMenuHelper::listCrossfaders))); mListCommands.insert(std::make_pair("domains", sCommandPrototypeInfo("list all domains", &CAmTelnetMenuHelper::listDomainsCommand))); mListCommands.insert(std::make_pair("gws", sCommandPrototypeInfo("list all gateways", &CAmTelnetMenuHelper::listGatewaysCommand))); mListCommands.insert(std::make_pair("mainconn", sCommandPrototypeInfo("list all main connections", &CAmTelnetMenuHelper::listMainConnectionsCommand))); mListCommands.insert(std::make_pair("mainsinks", sCommandPrototypeInfo("list all main sinks", &CAmTelnetMenuHelper::listMainSinksCommand))); mListCommands.insert(std::make_pair("mainsources", sCommandPrototypeInfo("list all main sources", &CAmTelnetMenuHelper::listMainSourcesCommand))); mListCommands.insert(std::make_pair("..", sCommandPrototypeInfo("one step back in menu tree (back to root folder)", &CAmTelnetMenuHelper::oneStepBackCommand))); mListCommands.insert(std::make_pair("exit", sCommandPrototypeInfo("close telnet session", &CAmTelnetMenuHelper::exitCommand))); // Set commands mSetCommands.insert(std::make_pair("help", sCommandPrototypeInfo(std::string("show all possible commands"), &CAmTelnetMenuHelper::helpCommand))); mSetCommands.insert(std::make_pair("..", sCommandPrototypeInfo("one step back in menu tree (back to root folder)", &CAmTelnetMenuHelper::oneStepBackCommand))); mSetCommands.insert(std::make_pair("exit", sCommandPrototypeInfo("close telnet session", &CAmTelnetMenuHelper::exitCommand))); mSetCommands.insert(std::make_pair("conn", sCommandPrototypeInfo("use 'conn sourceId sinkId' to connect a source and a sink", &CAmTelnetMenuHelper::setConnection))); mSetCommands.insert(std::make_pair("routing", sCommandPrototypeInfo("use 'routing sourceId sinkId' to get all\n\t possible routes between a sourceID and a sinkID", &CAmTelnetMenuHelper::setRoutingCommand))); mSetCommands.insert(std::make_pair("disc", sCommandPrototypeInfo("use 'disc connectionID' to disconnect \n\t this connection", &CAmTelnetMenuHelper::setDisconnectConnId))); mSetCommands.insert(std::make_pair("sinkvolume", sCommandPrototypeInfo("use 'sinkvolume sinkID volume' to set \n\t absorption in db of sink", &CAmTelnetMenuHelper::setSinkVolume))); mSetCommands.insert(std::make_pair("sinkvolstep", sCommandPrototypeInfo("use 'sinkvolstep sinkID volumestep' to increment \n\t or decrement volume", &CAmTelnetMenuHelper::setVolumeStep))); mSetCommands.insert(std::make_pair("sinkprop", sCommandPrototypeInfo("use 'sinkprop type value' to set \n\t a specific sinksoundproperty", &CAmTelnetMenuHelper::setSinkSoundProperty))); mSetCommands.insert(std::make_pair("sinkmute", sCommandPrototypeInfo("use 'sinkmute sinkid mutestate' to mute \n\t or unmute", &CAmTelnetMenuHelper::setSinkMuteState))); mSetCommands.insert(std::make_pair("sourceprop", sCommandPrototypeInfo("use 'sourceprop type value' to set \n\t a specific sinksoundproperty", &CAmTelnetMenuHelper::setSourceSoundProperty))); // Get commands mGetCommands.insert(std::make_pair("help", sCommandPrototypeInfo(std::string("show all possible commands"), &CAmTelnetMenuHelper::helpCommand))); mGetCommands.insert(std::make_pair("routing", sCommandPrototypeInfo("show current routing", &CAmTelnetMenuHelper::getRoutingCommand))); mGetCommands.insert(std::make_pair("sendv", sCommandPrototypeInfo("show senderversion", &CAmTelnetMenuHelper::getSenderversionCommand))); mGetCommands.insert(std::make_pair("recv", sCommandPrototypeInfo("show receiverversion ", &CAmTelnetMenuHelper::getReceiverversionCommand))); mGetCommands.insert(std::make_pair("..", sCommandPrototypeInfo("one step back in menu tree (back to root folder)", &CAmTelnetMenuHelper::oneStepBackCommand))); mGetCommands.insert(std::make_pair("exit", sCommandPrototypeInfo("close telnet session", &CAmTelnetMenuHelper::exitCommand))); // Info comands mInfoCommands.insert(std::make_pair("help", sCommandPrototypeInfo(std::string("show all possible commands"), &CAmTelnetMenuHelper::helpCommand))); mInfoCommands.insert(std::make_pair("sysprop", sCommandPrototypeInfo("show all systemproperties", &CAmTelnetMenuHelper::infoSystempropertiesCommand))); mInfoCommands.insert(std::make_pair("dump", sCommandPrototypeInfo("create a database dump of currently used data", &CAmTelnetMenuHelper::infoDumpCommand))); mInfoCommands.insert(std::make_pair("..", sCommandPrototypeInfo("one step back in menu tree (back to root folder)", &CAmTelnetMenuHelper::oneStepBackCommand))); mInfoCommands.insert(std::make_pair("exit", sCommandPrototypeInfo("close telnet session", &CAmTelnetMenuHelper::exitCommand))); } /****************************************************************************/ void CAmTelnetMenuHelper::newSocketConnection(int filedescriptor) /****************************************************************************/ { EMainState state = eRootState; std::map::iterator it; std::stringstream welcome; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { // socket connection already exists, delete entry and go back to root state mCurrentMainStateMap.erase(it); } it = mCurrentMainStateMap.begin(); // insert new socket connection mCurrentMainStateMap.insert(it, std::make_pair(filedescriptor, state)); // Send welcome message welcome << COLOR_WELCOME << "Welcome to GENIVI AudioManager " << DAEMONVERSION << COLOR_DEFAULT << "\n>"; assert(send(filedescriptor, welcome.str().c_str(), welcome.str().size(), 0)>=0); logInfo("[TN] New connection: ", filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::socketConnectionsClosed(int filedescriptor) /****************************************************************************/ { std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { mCurrentMainStateMap.erase(it); } else { logError("[TN] socketConnectionsClosed, fd not found, ", filedescriptor); } } /****************************************************************************/ void CAmTelnetMenuHelper::enterCmdQueue(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { std::map::iterator it; std::string cmd; tCommandMap::iterator cmditer; // find current filedescriptor to get the current state of the telnet session it = mCurrentMainStateMap.find(filedescriptor); while (!CmdQueue.empty()) { cmd = CmdQueue.front(); // Now remove the first command, it's stored in 'cmd' CmdQueue.pop(); // telnet session found. depending on the current state, different commands are available switch (it->second) { case eRootState: cmditer = mRootCommands.find(cmd); if (mRootCommands.end() != cmditer) cmditer->second.CommandPrototype(CmdQueue, filedescriptor); else sendError(filedescriptor, "Command not found\n"); break; case eListState: cmditer = mListCommands.find(cmd); if (mListCommands.end() != cmditer) cmditer->second.CommandPrototype(CmdQueue, filedescriptor); else sendError(filedescriptor, "Command not found\n"); break; case eInfoState: cmditer = mInfoCommands.find(cmd); if (mInfoCommands.end() != cmditer) cmditer->second.CommandPrototype(CmdQueue, filedescriptor); else sendError(filedescriptor, "Command not found\n"); break; case eGetState: cmditer = mGetCommands.find(cmd); if (mGetCommands.end() != cmditer) cmditer->second.CommandPrototype(CmdQueue, filedescriptor); else sendError(filedescriptor, "Command not found\n"); break; case eSetState: cmditer = mSetCommands.find(cmd); if (mSetCommands.end() != cmditer) cmditer->second.CommandPrototype(CmdQueue, filedescriptor); else sendError(filedescriptor, "Command not found\n"); break; default: break; } } sendCurrentCmdPrompt(filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::sendError(int& filedescriptor, std::string error_string) /****************************************************************************/ { assert(send(filedescriptor, error_string.c_str(), error_string.size(), 0)>=0); } /****************************************************************************/ void CAmTelnetMenuHelper::sendTelnetLine(int& filedescriptor, std::stringstream& line) /****************************************************************************/ { assert(send(filedescriptor, line.str().c_str(), line.str().size(), 0)>=0); } /****************************************************************************/ void CAmTelnetMenuHelper::sendCurrentCmdPrompt(int& filedescriptor) /****************************************************************************/ { std::map::iterator it; std::stringstream outputstream; outputstream << std::endl; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { switch (it->second) { case eRootState: outputstream << "\\>"; break; case eListState: outputstream << "\\List>"; break; case eGetState: outputstream << "\\Get>"; break; case eSetState: outputstream << "\\Set>"; break; case eInfoState: outputstream << "\\Info>"; break; default: break; } assert(send(filedescriptor, outputstream.str().c_str(), outputstream.str().size(), 0)>=0); } else { logInfo("[TN] sendCurrentCmdPrompt, fd not found: ", filedescriptor); } } /****************************************************************************/ void CAmTelnetMenuHelper::exitCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->exitCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::oneStepBackCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { switch (it->second) { case eRootState: it->second = eRootState; break; case eListState: it->second = eRootState; ; break; case eGetState: it->second = eRootState; ; break; case eSetState: it->second = eRootState; ; break; case eInfoState: it->second = eRootState; ; break; default: it->second = eRootState; break; } logInfo("[TN] oneStepBackCommandExec, state: ", it->second); } } /****************************************************************************/ void CAmTelnetMenuHelper::oneStepBackCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->oneStepBackCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::exitCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; std::stringstream line; std::stringstream output; // Sending a last message to the client output << "bye!" << COLOR_DEFAULT << std::endl; sendTelnetLine(filedescriptor, output); tCommandMap::iterator iter; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { if (NULL != mpTelenetServer) { logInfo("[TN] exitCommandExec, removing fd ", filedescriptor); mpTelenetServer->disconnectClient(filedescriptor); mCurrentMainStateMap.erase(it); } else { logError("[TN] exitCommandExec, mpTelenetServer == NULL, fd ", filedescriptor); } } } /****************************************************************************/ void CAmTelnetMenuHelper::helpCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->helpCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::helpCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; std::stringstream line; tCommandMap::iterator cmdIter; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { line << COLOR_HEAD << "###################################################" << COLOR_DEFAULT << std::endl; line << COLOR_HEAD << "###### The following commands are supported: ######" << COLOR_DEFAULT << std::endl; line << COLOR_HEAD << "###################################################" << COLOR_DEFAULT << std::endl << std::endl; switch (it->second) { case eRootState: cmdIter = mRootCommands.begin(); while (cmdIter != mRootCommands.end()) { line << cmdIter->first << "\t\t- " << cmdIter->second.info << std::endl; cmdIter++; } break; case eListState: cmdIter = mListCommands.begin(); while (cmdIter != mListCommands.end()) { line << cmdIter->first << "\t\t- " << cmdIter->second.info << std::endl; cmdIter++; } break; case eGetState: cmdIter = mGetCommands.begin(); while (cmdIter != mGetCommands.end()) { line << cmdIter->first << "\t\t- " << cmdIter->second.info << std::endl; cmdIter++; } break; case eSetState: cmdIter = mSetCommands.begin(); while (cmdIter != mSetCommands.end()) { line << cmdIter->first << "\t\t- " << cmdIter->second.info << std::endl; cmdIter++; } break; case eInfoState: cmdIter = mInfoCommands.begin(); while (cmdIter != mInfoCommands.end()) { line << cmdIter->first << "\t\t- " << cmdIter->second.info << std::endl; cmdIter++; } break; default: break; } sendTelnetLine(filedescriptor, line); } } /****************************************************************************/ void CAmTelnetMenuHelper::rootGetCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->rootGetCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::rootGetCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { it->second = eGetState; } } /****************************************************************************/ void CAmTelnetMenuHelper::rootSetCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->rootSetCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::rootSetCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { it->second = eSetState; } } /****************************************************************************/ void CAmTelnetMenuHelper::rootListCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->rootListCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::rootListCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { it->second = eListState; } } /****************************************************************************/ void CAmTelnetMenuHelper::rootInfoCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->rootInfoCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::rootInfoCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::map::iterator it; it = mCurrentMainStateMap.find(filedescriptor); if (it != mCurrentMainStateMap.end()) { it->second = eInfoState; } } /****************************************************************************/ void CAmTelnetMenuHelper::listConnectionsCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listConnectionsCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listConnectionsCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Connection_s > listConnections; if (E_OK == mpDatabasehandler->getListConnections(listConnections)) { std::stringstream output; output << "\tConnections: " << listConnections.size() << std::endl; for (std::vector::iterator iter(listConnections.begin()); iter < listConnections.end(); iter++) { output << "\tID: " << iter->connectionID << "\tSrcID: " << iter->sourceID << "\tSinkID: " << iter->sinkID << "\tFormat: " << iter->connectionFormat << "\tdelay: " << iter->delay << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListConnections"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listSourcesCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listSourcesCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listSourcesCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Source_s > listSources; if (E_OK == mpDatabasehandler->getListSources(listSources)) { std::stringstream output; output << "\tSources: " << listSources.size() << std::endl; for (std::vector::iterator iter(listSources.begin()); iter < listSources.end(); iter++) { output << "\tID: " << iter->sourceID << "\tName: " << iter->name << "\tDomainID: " << iter->domainID << "\tState: " << iter->sourceState << "\tVolume: " << iter->volume << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListSources"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listSinksCommands(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listSinksCommandsExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listSinksCommandsExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Sink_s > listSinks; if (E_OK == mpDatabasehandler->getListSinks(listSinks)) { std::stringstream output; output << "\tSinks: " << listSinks.size() << std::endl; for (std::vector::iterator iter(listSinks.begin()); iter < listSinks.end(); iter++) { output << "\tID: " << iter->sinkID << "\tDomainID: " << iter->domainID << "\tName: " << iter->name << "\tAvailable: " << iter->available.availability << "\tVolume: " << iter->volume << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListSinks"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listCrossfaders(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listCrossfadersExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listCrossfadersExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Crossfader_s > listCrossfaders; if (E_OK == mpDatabasehandler->getListCrossfaders(listCrossfaders)) { std::stringstream output; output << "\tCrossfader: " << listCrossfaders.size() << std::endl; for (std::vector::iterator iter(listCrossfaders.begin()); iter < listCrossfaders.end(); iter++) { output << "\tID: " << iter->crossfaderID << "\tName: " << iter->name << "\tSinkA: " << iter->sinkID_A << "\tSinkB: " << iter->sinkID_B << "\tSourceID: " << iter->sourceID << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListCrossfaders"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listDomainsCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listDomainsCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listDomainsCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Domain_s > listDomains; if (E_OK == mpDatabasehandler->getListDomains(listDomains)) { std::stringstream output; output << "\tDomains: " << listDomains.size() << std::endl; for (std::vector::iterator iter(listDomains.begin()); iter < listDomains.end(); iter++) { output << "\tID: " << iter->domainID << "\tName: " << iter->name << "\tBusname: " << iter->busname << "\tNodename: " << iter->nodename << "\tState: " << static_cast(iter->state) << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListDomains"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listGatewaysCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listGatewaysCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listGatewaysCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_Gateway_s > listGateways; if (E_OK == mpDatabasehandler->getListGateways(listGateways)) { std::stringstream output; output << "\tGateways: " << listGateways.size(); for (std::vector::iterator iter(listGateways.begin()); iter < listGateways.end(); iter++) { output << "\tID: " << iter->gatewayID << "\tName: " << iter->name << "\tSourceID: " << iter->sourceID << "\tSinkID: " << iter->sinkID << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListGateways"); } } /****************************************************************************/ void CAmTelnetMenuHelper::getRoutingCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->getRoutingCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::getRoutingCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); (void) (filedescriptor); //TODO: fill with function } /****************************************************************************/ void CAmTelnetMenuHelper::getSenderversionCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->getSenderversionCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::getSenderversionCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::stringstream output; std::string versionCommand; std::string versionRouting; std::string versionControl; mpControlSender->getInterfaceVersion(versionControl); mpRoutingSender->getInterfaceVersion(versionRouting); mpCommandSender->getInterfaceVersion(versionCommand); output << "\tSender versions:" << std::endl << "\tCtrl: " << versionControl << " | " << "Cmd: " << versionCommand << " | " << "Routing: " << versionRouting << std::endl; sendTelnetLine(filedescriptor, output); } /****************************************************************************/ void CAmTelnetMenuHelper::getReceiverversionCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->getReceiverversionCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::getReceiverversionCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::stringstream output; std::string versionCommand; std::string versionRouting; std::string versionControl; mpControlReceiver->getInterfaceVersion(versionControl); mpRoutingReceiver->getInterfaceVersion(versionRouting); mpCommandReceiver->getInterfaceVersion(versionCommand); output << "\tReceiver versions:" << std::endl << "\tCtrl: " << versionControl << " | " << "Cmd: " << versionCommand << " | " << "Routing: " << versionRouting << std::endl; sendTelnetLine(filedescriptor, output); } /****************************************************************************/ void CAmTelnetMenuHelper::infoSystempropertiesCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->infoSystempropertiesCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::infoDumpCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->infoDumpCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setVolumeStep(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setSinkVolumeExec(CmdQueue,filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setVolumeStepExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { if (CmdQueue.size() >= 2) { int16_t volumestep = 0; am_sinkID_t sinkID = 0; bool error = false; std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_volumestep(CmdQueue.front()); CmdQueue.pop(); if (!(istream_volumestep >> volumestep)) error = true; if (!(istream_sinkID >> sinkID)) error = true; if (error) { sendError(filedescriptor, "Error parsing setVolumeStep 'sinkID' or 'volumestep'"); return; } if (E_OK == mpCommandReceiver->volumeStep(sinkID,volumestep)) { std::stringstream output; output << "SetSinkVolumeStep set: " << sinkID << "->" << volumestep << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error SetSinkVolumeStep"); } } else { sendError(filedescriptor, "Not enough arguments to set SetSinkVolumeStep, please enter 'sinkID' and 'volumestep' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkMuteState(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setSinkMuteStateExec(CmdQueue,filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkMuteStateExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { if (CmdQueue.size() >= 2) { u_int16_t tmp = 0; am_MuteState_e MuteState = MS_UNKNOWN; am_sinkID_t sinkID = 0; bool error = false; std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_mutestate(CmdQueue.front()); CmdQueue.pop(); if (!(istream_mutestate >> tmp)) error = true; if (!(istream_sinkID >> sinkID)) error = true; if(tmp < MS_MAX) { MuteState = static_cast(tmp); } else { sendError(filedescriptor, "You tried to set an invalid am_MuteState_e"); error = true; } if (error) { sendError(filedescriptor, "Error parsing setSinkMuteState 'sinkID' or 'mutestate'"); return; } if (E_OK == mpCommandReceiver->setSinkMuteState(sinkID,MuteState)) { std::stringstream output; output << "setSinkMuteState set: " << sinkID << "->" << MuteState << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error setSinkMuteState"); } } else { sendError(filedescriptor, "Not enough arguments to set setSinkMuteState, please enter 'sinkID' and 'mutestate' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setSourceSoundProperty(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setSourceSoundPropertiesExec(CmdQueue,filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setSourceSoundPropertyExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { unsigned int tmpType = 0; bool error = false; if (CmdQueue.size() >= 3) { std::istringstream istream_sourceID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_type(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_value(CmdQueue.front()); CmdQueue.pop(); if (!(istream_type >> tmpType)) error = true; am_MainSoundProperty_s soundProperty; if (tmpType < MSP_MAX) soundProperty.type = static_cast(tmpType); else error = true; if (!(istream_value >> soundProperty.value)) error = true; am_sourceID_t sourceID = 0; if (!(istream_sourceID >> sourceID)) error = true; if (error) { sendError(filedescriptor, "Error parsing setMainSourceSoundProperty 'type', 'value' or 'sourceID'"); return; } if (E_OK == mpCommandReceiver->setMainSourceSoundProperty(soundProperty, sourceID)) { std::stringstream output; output << "setMainSourceSoundProperty set: " << soundProperty.type << "->" << soundProperty.value << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error setMainSourceSoundProperty"); } } else { sendError(filedescriptor, "Not enough arguments to set setMainSourceSoundProperty, please enter 'sourceID', 'type' and 'value' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::infoSystempropertiesCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_SystemProperty_s > listSystemProperties; if (E_OK == mpDatabasehandler->getListSystemProperties(listSystemProperties)) { std::stringstream output; output << "\tSystemproperties: " << listSystemProperties.size() << std::endl; std::vector::iterator it; for (it = listSystemProperties.begin(); it < listSystemProperties.end(); it++) { output << "\tType: " << it->type << " Value: " << it->value << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListSystemProperties"); } } /****************************************************************************/ void CAmTelnetMenuHelper::infoDumpCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::stringstream *pOutput = new std::stringstream(); mpDatabasehandler->dump(*pOutput); sendTelnetLine(filedescriptor, *pOutput); delete pOutput; } /****************************************************************************/ void CAmTelnetMenuHelper::setRoutingCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setRoutingCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setRoutingCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { if (CmdQueue.size() >= 2) { bool error = false; std::istringstream istream_sourceID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); am_sourceID_t sourceID = 0; if (!(istream_sourceID >> sourceID)) error = true; am_sinkID_t sinkID = 0; if (!(istream_sinkID >> sinkID)) error = true; if (error) { sendError(filedescriptor, "Error parsing sourcID and sinkID"); return; } std::vector < am_Route_s > routingList; if (E_OK == mpRouter->getRoute(true, sourceID, sinkID, routingList)) { std::stringstream output; std::vector::iterator rlIter = routingList.begin(); for (int rlCnt = 1; rlIter < routingList.end(); rlIter++) { output << "#" << rlCnt << " "; std::vector::iterator reIter = rlIter->route.begin(); for (; reIter < rlIter->route.end(); reIter++) { output << ">(" << reIter->sourceID << ")->--[D:" << reIter->domainID << "][F:" << reIter->connectionFormat << "]-->-(" << reIter->sinkID << ")" << std::endl; } rlCnt++; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error getting route"); } } else { if (!CmdQueue.empty()) CmdQueue.pop(); sendError(filedescriptor, "Not enough arguments to set routing. Please enter sourceID and sinkID after command"); } } /****************************************************************************/ void CAmTelnetMenuHelper::setConnection(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setConnectionExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setConnectionExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { bool error = false; am_Error_e rError = E_OK; if (CmdQueue.size() >= 2) { std::istringstream istream_sourceID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); am_sourceID_t sourceID = 0; if (!(istream_sourceID >> sourceID)) error = true; am_sinkID_t sinkID = 0; if (!(istream_sinkID >> sinkID)) error = true; if (error) { sendError(filedescriptor, "Error parsing sinkID and/or sourceID"); return; } // Try to set up connection am_mainConnectionID_t connID = 0; rError = mpCommandReceiver->connect(sourceID, sinkID, connID); if (E_OK == rError) { std::stringstream output; output << "ConnID: " << connID << "\tSrc: " << sourceID << " ---> Sink: " << sinkID << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error connecting sourceID and sinkID"); } } else { // remove 1 element if list is not empty if (!CmdQueue.empty()) CmdQueue.pop(); sendError(filedescriptor, "Not enough arguments to set routing. Please enter sourceID and sinkID after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setDisconnectConnId(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setDisconnectConnIdExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setDisconnectConnIdExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { am_mainConnectionID_t connID = 0; bool error = false; am_Error_e rError = E_OK; if (CmdQueue.size() >= 1) { std::istringstream istream_connID(CmdQueue.front()); CmdQueue.pop(); if (!(istream_connID >> connID)) error = true; if (error) { sendError(filedescriptor, "Error parsing connID"); return; } // Try to disconnect connection id rError = mpCommandReceiver->disconnect(connID); if (E_OK == rError) { std::stringstream output; output << "ConnID " << connID << " closed successfully! " << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error disconnecting connectionID"); } } else { sendError(filedescriptor, "Not enough arguments to disconnect a Main Connection, please enter 'connectionID' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setSourceSoundProperties(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setConnectionExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setSourceSoundPropertiesExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { if (CmdQueue.size() >= 3) { bool error = false; std::istringstream istream_sourceID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_type(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_value(CmdQueue.front()); CmdQueue.pop(); unsigned int tmpType = 0; if (!(istream_type >> tmpType)) error = true; am_MainSoundProperty_s soundProperty; if (tmpType < MSP_MAX) soundProperty.type = static_cast(tmpType); else error = true; if (!(istream_value >> soundProperty.value)) error = true; am_sinkID_t sourceID = 0; if (!(istream_sourceID >> sourceID)) error = true; if (error) { sendError(filedescriptor, "Error parsing MainSinkSoundProperty 'type', 'value' or 'sourceID'"); return; } if (E_OK == mpCommandReceiver->setMainSourceSoundProperty(soundProperty, sourceID)) { std::stringstream output; output << "MainSourceSoundProperty set: " << soundProperty.type << "->" << soundProperty.value << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error setMainSourceSoundProperty"); } } else { sendError(filedescriptor, "Not enough arguments to set MainSourceSoundProperty, please enter 'sourceID', 'type' and 'value' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkSoundProperty(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setSinkSoundPropertyExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkSoundPropertyExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { unsigned int tmpType = 0; bool error = false; if (CmdQueue.size() >= 3) { std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_type(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_value(CmdQueue.front()); CmdQueue.pop(); if (!(istream_type >> tmpType)) error = true; am_MainSoundProperty_s soundProperty; if (tmpType < MSP_MAX) soundProperty.type = static_cast(tmpType); else error = true; if (!(istream_value >> soundProperty.value)) error = true; am_sinkID_t sinkID = 0; if (!(istream_sinkID >> sinkID)) error = true; if (error) { sendError(filedescriptor, "Error parsing MainSinkSoundProperty 'type', 'value' or 'sinkID'"); return; } if (E_OK == mpCommandReceiver->setMainSinkSoundProperty(soundProperty, sinkID)) { std::stringstream output; output << "MainSinkSoundProperty set: " << soundProperty.type << "->" << soundProperty.value << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error setMainSinkSoundProperty"); } } else { sendError(filedescriptor, "Not enough arguments to set MainSinkSoundProperty, please enter 'sinkID', 'type' and 'value' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkVolume(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->setSinkVolumeExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::setSinkVolumeExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { if (CmdQueue.size() >= 2) { am_volume_t volume = 0; am_sinkID_t sinkID = 0; bool error = false; std::istringstream istream_sinkID(CmdQueue.front()); CmdQueue.pop(); std::istringstream istream_volume(CmdQueue.front()); CmdQueue.pop(); if (!(istream_volume >> volume)) error = true; if (!(istream_sinkID >> sinkID)) error = true; if (error) { sendError(filedescriptor, "Error parsing SetSinkVolume 'sinkID' or 'volume'"); return; } if (E_OK == mpCommandReceiver->setVolume(sinkID,volume)) { std::stringstream output; output << "setVolume set: " << sinkID << "->" << volume << std::endl; sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "Error setVolume"); } } else { sendError(filedescriptor, "Not enough arguments to set setVolume, please enter 'sinkID' and 'volume' after command"); return; } } /****************************************************************************/ void CAmTelnetMenuHelper::listPluginsCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listPluginsCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listPluginsCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < std::string > PlugInNames; std::vector::iterator iter; std::stringstream output; if (E_OK == mpCommandSender->getListPlugins(PlugInNames)) { output << "\tCommandSender Plugins loaded: " << PlugInNames.size() << std::endl; for (iter = PlugInNames.begin(); iter < PlugInNames.end(); iter++) { output << iter->c_str() << std::endl; } } else { sendError(filedescriptor, "ERROR: mCommandSender->getListPlugins"); } if (E_OK == mpRoutingSender->getListPlugins(PlugInNames)) { output << std::endl << "\tRoutingSender Plugins loaded: " << PlugInNames.size() << std::endl; for (iter = PlugInNames.begin(); iter < PlugInNames.end(); iter++) { output << iter->c_str() << std::endl; } } else { sendError(filedescriptor, "ERROR: mRoutingSender->getListPlugins"); } sendTelnetLine(filedescriptor, output); } /****************************************************************************/ void CAmTelnetMenuHelper::listMainSourcesCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listMainSourcesCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listMainSourcesCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_SourceType_s > listMainSources; if (E_OK == mpDatabasehandler->getListMainSources(listMainSources)) { std::stringstream output; output << std::endl << "\tMainSources: " << listMainSources.size() << std::endl; std::vector::iterator iter; for (iter = listMainSources.begin(); iter < listMainSources.end(); iter++) { output << "\tID: " << iter->sourceID << "\tName: " << iter->name << "\tsourceClassID: " << iter->sourceClassID << "\tavailability: " << iter->availability.availability << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListMainSources"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listMainSinksCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listMainSinksCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listMainSinksCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector < am_SinkType_s > listMainSinks; if (E_OK == mpDatabasehandler->getListMainSinks(listMainSinks)) { std::stringstream output; output << std::endl << "\tMainSinks: " << listMainSinks.size() << std::endl; std::vector::iterator iter; for (iter = listMainSinks.begin(); iter < listMainSinks.end(); iter++) { output << "\tID: " << iter->sinkID << "\tsinkClassID: " << iter->sinkClassID << "\tName: " << iter->name << "\tAvailable: " << iter->availability.availability << "\tVolume: " << iter->volume << std::endl; } sendTelnetLine(filedescriptor, output); } else { sendError(filedescriptor, "ERROR: mDatabasehandler->getListMainSinks"); } } /****************************************************************************/ void CAmTelnetMenuHelper::listMainConnectionsCommand(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { instance->listMainConnectionsCommandExec(CmdQueue, filedescriptor); } /****************************************************************************/ void CAmTelnetMenuHelper::listMainConnectionsCommandExec(std::queue& CmdQueue, int& filedescriptor) /****************************************************************************/ { (void) (CmdQueue); std::vector listMainConnections; if(E_OK == mpDatabasehandler->getListMainConnections(listMainConnections)) { std::stringstream output; output << std::endl << "\tMainConnections: " << listMainConnections.size() << std::endl; std::vector::iterator iter; for (iter = listMainConnections.begin(); iter < listMainConnections.end(); iter++) { output << "\tID: " << iter->mainConnectionID << "\tState: " << iter->connectionState << "\tDelay: " << iter->delay << "\tsourceID: " << iter->sourceID << "\tsinkID: " << iter->sinkID << std::endl; output << "ConnectionIDs: "; std::vector::iterator list_connIDs_iter = iter->listConnectionID.begin(); for(;list_connIDs_iter < iter->listConnectionID.end();list_connIDs_iter++) { output << *list_connIDs_iter << " "; } output << std::endl; } sendTelnetLine(filedescriptor,output); } else { sendError(filedescriptor,"ERROR: mDatabasehandler->getListMainSinks"); } } }