/* * INTEL CONFIDENTIAL * Copyright © 2011 Intel * Corporation All Rights Reserved. * * The source code contained or described herein and all documents related to * the source code ("Material") are owned by Intel Corporation or its suppliers * or licensors. Title to the Material remains with Intel Corporation or its * suppliers and licensors. The Material contains trade secrets and proprietary * and confidential information of Intel or its suppliers and licensors. The * Material is protected by worldwide copyright and trade secret laws and * treaty provisions. No part of the Material may be used, copied, reproduced, * modified, published, uploaded, posted, transmitted, distributed, or * disclosed in any way without Intel’s prior express written permission. * * No license under any patent, copyright, trade secret or other intellectual * property right is granted to or conferred upon you by disclosure or delivery * of the Materials, either expressly, by implication, inducement, estoppel or * otherwise. Any license under such intellectual property rights must be * express and approved by Intel in writing. * * CREATED: 2011-06-01 * UPDATED: 2011-07-27 */ #include #include #include #include #include "RequestMessage.h" #include "AnswerMessage.h" #include "ConnectionSocket.h" #include "NaiveTokenizer.h" using namespace std; class CRequestMessageGenerator { private: istream& _input; // File to read the commands from public: CRequestMessageGenerator(istream& input) : _input(input) {} enum EStatus { OK, STOP, EMPTY_LINE, ERROR }; EStatus next(CRequestMessage& requestMessage) { string sLine; char* pcLine; char* pcLine_backup; // pcLine will be modified by NaiveTokenizer // so we need to keep track of its original value char* pcToken; // Read a single line from the input file getline(_input, sLine); if (_input.eof() && (_input.gcount() == 0)) { return STOP; // No more commands } if (_input.fail()) { return ERROR; // Error while reading file } pcLine = strdup(sLine.c_str()); pcLine_backup = pcLine; if (!pcLine) { return ERROR; } // Set the first word as the command pcToken = NaiveTokenizer::getNextToken(&pcLine); if (!pcToken) { free(pcLine_backup); return EMPTY_LINE; } requestMessage.setCommand(pcToken); while ((pcToken = NaiveTokenizer::getNextToken(&pcLine)) != NULL) { // Add each word as arguments to the command requestMessage.addArgument(pcToken); } free(pcLine_backup); return OK; } }; bool sendAndDisplayCommand(CConnectionSocket &connectionSocket, CRequestMessage &requestMessage) { if (!requestMessage.serialize(&connectionSocket, true)) { cerr << "Unable to send command to target" << endl; return false; } ///// Get answer CAnswerMessage answerMessage; if (!answerMessage.serialize(&connectionSocket, false)) { cerr << "No answer received from target" << endl; return false; } // Success? if (!answerMessage.success()) { // Display error answer cerr << answerMessage.getAnswer() << endl; return false; } // Display success answer cout << answerMessage.getAnswer() << endl; return true; } // hostname port command [argument[s]] // or // hostname port < commands int main(int argc, char *argv[]) { bool bFromStdin = false; // Read commands from stdin instead of arguments // Enough args? if (argc < 3) { cerr << "Missing arguments" << endl; cerr << "Usage: " << endl; cerr << "Send a single command:" << endl; cerr << "\t" << argv[0] << " hostname port command [argument[s]]" << endl; cerr << "Send several commands, read from stdin:" << endl; cerr << "\t" << argv[0] << " hostname port" << endl; return 1; } else if (argc < 4) { bFromStdin = true; } // Get port number uint16_t uiPort = (uint16_t)strtoul(argv[2], NULL, 0); // Connect to target CConnectionSocket connectionSocket; // Set timeout connectionSocket.setTimeout(5000); string strError; // Connect if (!connectionSocket.connect(argv[1], uiPort, strError)) { cerr << strError << endl; return 1; } if (bFromStdin) { CRequestMessageGenerator generator(cin); CRequestMessage requestMessage; CRequestMessageGenerator::EStatus status; while (true) { status = generator.next(requestMessage); switch (status) { case CRequestMessageGenerator::OK: if (!sendAndDisplayCommand(connectionSocket, requestMessage)) { return 1; } break; case CRequestMessageGenerator::STOP: return 0; case CRequestMessageGenerator::ERROR: cerr << "Error while reading the input" << endl; return 1; case CRequestMessageGenerator::EMPTY_LINE: continue; } } } else { // Create command message CRequestMessage requestMessage(argv[3]); // Add arguments uint32_t uiArg; for (uiArg = 4; uiArg < (uint32_t)argc; uiArg++) { requestMessage.addArgument(argv[uiArg]); } if (!sendAndDisplayCommand(connectionSocket, requestMessage)) { return 1; } } // Program status return 0; }