François
5 months ago
4 changed files with 382 additions and 11 deletions
@ -0,0 +1,8 @@ |
|||||
|
#!/bin/bash |
||||
|
|
||||
|
TMP_LOG="$(mktemp)" |
||||
|
|
||||
|
#trap "rm -rf ${TMP_LOG}" 0 1 2 3 15 |
||||
|
|
||||
|
cat > ${TMP_LOG} |
||||
|
cat ${TMP_LOG} |
@ -0,0 +1,223 @@ |
|||||
|
////////////////////////////////////////////////////////////////////////////
|
||||
|
// Copyright KAZ 2021 //
|
||||
|
// //
|
||||
|
// contact (at) kaz.bzh //
|
||||
|
// //
|
||||
|
// This software is a filter to shrink email by attachment extraction. //
|
||||
|
// //
|
||||
|
// This software is governed by the CeCILL-B license under French law and //
|
||||
|
// abiding by the rules of distribution of free software. You can use, //
|
||||
|
// modify and/or redistribute the software under the terms of the //
|
||||
|
// CeCILL-B license as circulated by CEA, CNRS and INRIA at the following //
|
||||
|
// URL "http://www.cecill.info". //
|
||||
|
// //
|
||||
|
// As a counterpart to the access to the source code and rights to copy, //
|
||||
|
// modify and redistribute granted by the license, users are provided //
|
||||
|
// only with a limited warranty and the software's author, the holder of //
|
||||
|
// the economic rights, and the successive licensors have only limited //
|
||||
|
// liability. //
|
||||
|
// //
|
||||
|
// In this respect, the user's attention is drawn to the risks associated //
|
||||
|
// with loading, using, modifying and/or developing or reproducing the //
|
||||
|
// software by the user in light of its specific status of free software, //
|
||||
|
// that may mean that it is complicated to manipulate, and that also //
|
||||
|
// therefore means that it is reserved for developers and experienced //
|
||||
|
// professionals having in-depth computer knowledge. Users are therefore //
|
||||
|
// encouraged to load and test the software's suitability as regards //
|
||||
|
// their requirements in conditions enabling the security of their //
|
||||
|
// systems and/or data to be ensured and, more generally, to use and //
|
||||
|
// operate it in the same conditions as regards security. //
|
||||
|
// //
|
||||
|
// The fact that you are presently reading this means that you have had //
|
||||
|
// knowledge of the CeCILL-B license and that you accept its terms. //
|
||||
|
////////////////////////////////////////////////////////////////////////////
|
||||
|
|
||||
|
#include <boost/program_options.hpp> |
||||
|
#include <fcntl.h> |
||||
|
#include <map> |
||||
|
#include <netinet/in.h> |
||||
|
#include <poll.h> |
||||
|
#include <stdio.h> |
||||
|
#include <stdlib.h> |
||||
|
#include <string> |
||||
|
#include <sys/socket.h> |
||||
|
#include <unistd.h> |
||||
|
#include <vector> |
||||
|
|
||||
|
#include "kazDebug.hpp" |
||||
|
#include "kazMisc.hpp" |
||||
|
|
||||
|
using namespace std; |
||||
|
using namespace boost; |
||||
|
using namespace boost::program_options; |
||||
|
using namespace kaz; |
||||
|
|
||||
|
#define CONSOLE(expr) {if (!quietFlag) {std::cerr << Log::getLocalTimeStr () << " " << expr << std::endl << std::flush; }} |
||||
|
|
||||
|
// ================================================================================
|
||||
|
const string LAST_VERSION_NUM ("3.0"); |
||||
|
const string LAST_VERSION_DATE ("2024-01-01"); |
||||
|
const string LAST_VERSION (LAST_VERSION_NUM+" "+LAST_VERSION_DATE+" server"); |
||||
|
|
||||
|
#define PORT 8080 |
||||
|
|
||||
|
const string BASH ("/bin/bash"); |
||||
|
const string FILTER_CMD ("src/bash/testCopyInOut.sh"); |
||||
|
|
||||
|
// ================================================================================
|
||||
|
static options_description mainDescription ("Main options", getCols ()); |
||||
|
static options_description hide ("Hidded options", getCols ()); |
||||
|
static const char *prog = NULL; |
||||
|
|
||||
|
// ================================================================================
|
||||
|
void |
||||
|
usage (const string &msg = "", const bool &hidden = false) { |
||||
|
if (!msg.empty ()) { |
||||
|
cout << msg << endl; |
||||
|
exit (1); |
||||
|
} |
||||
|
cout << endl |
||||
|
<< "Usage: " << endl |
||||
|
<< " " << prog << " [-p port] [-f filterFileName.sh]" << endl |
||||
|
<< endl << mainDescription |
||||
|
<< endl; |
||||
|
if (hidden) |
||||
|
cout << hide << endl; |
||||
|
exit (0); |
||||
|
} |
||||
|
|
||||
|
void |
||||
|
version () { |
||||
|
cout << LAST_VERSION << " KAZ team production (https://kaz.bzh/)" << endl; |
||||
|
exit (0); |
||||
|
} |
||||
|
|
||||
|
// ================================================================================
|
||||
|
int |
||||
|
main (int argc, const char *argv[], char **envp) { |
||||
|
// uncomment next line in case of debug parse options
|
||||
|
// Log::debug = true;
|
||||
|
DEF_LOG ("main:", LAST_VERSION); |
||||
|
prog = argv [0]; |
||||
|
bool |
||||
|
helpFlag (false), |
||||
|
versionFlag (false), |
||||
|
quietFlag (false), |
||||
|
useTheForceLuke (false), |
||||
|
debugFlag (false); |
||||
|
int port (PORT); |
||||
|
string filterFileName (FILTER_CMD); |
||||
|
|
||||
|
try { |
||||
|
mainDescription.add_options () |
||||
|
("help,h", bool_switch (&helpFlag), "produce this help message") |
||||
|
("version,v", bool_switch (&versionFlag), "display version information") |
||||
|
("quiet,q", bool_switch (&quietFlag), "quiet mode") |
||||
|
("port,p", value<int> (&port)->default_value (port), "server port number") |
||||
|
("filter,f", value<string> (&filterFileName)->default_value (filterFileName), "filter file name script") |
||||
|
; |
||||
|
|
||||
|
hide.add_options () |
||||
|
("useTheForceLuke", bool_switch (&useTheForceLuke), "display hidded options") |
||||
|
("debug,g", bool_switch (&debugFlag), "debug mode") |
||||
|
; |
||||
|
options_description cmd ("All options"); |
||||
|
cmd.add (mainDescription).add (hide).add_options (); |
||||
|
|
||||
|
variables_map vm; |
||||
|
store (parse_command_line(argc, argv, cmd), vm); |
||||
|
notify (vm); |
||||
|
|
||||
|
if (debugFlag) { |
||||
|
#ifdef DISABLE_LOG |
||||
|
cerr << "No debug option available (was compiled with -DDISABLE_LOG)" << endl; |
||||
|
#endif |
||||
|
} |
||||
|
Log::debug = debugFlag; |
||||
|
|
||||
|
if (useTheForceLuke) |
||||
|
usage ("", true); |
||||
|
if (versionFlag) |
||||
|
version (); |
||||
|
if (helpFlag) |
||||
|
usage (); |
||||
|
|
||||
|
|
||||
|
} catch (std::exception &e) { |
||||
|
cerr << "error: " << e.what() << endl; |
||||
|
usage (); |
||||
|
return 1; |
||||
|
} catch (...) { |
||||
|
cerr << "Exception of unknown type!" << endl; |
||||
|
return 1; |
||||
|
} |
||||
|
|
||||
|
struct sockaddr_in address; |
||||
|
int opt = 1; |
||||
|
socklen_t addrlen = sizeof (address); |
||||
|
|
||||
|
LOG ("create socket"); |
||||
|
int serverSocket (socket (AF_INET, SOCK_STREAM, 0)); |
||||
|
if (serverSocket < 0) { |
||||
|
perror ("socket failed"); |
||||
|
exit (EXIT_FAILURE); |
||||
|
} |
||||
|
|
||||
|
LOG ("set socket options"); |
||||
|
if (setsockopt (serverSocket, SOL_SOCKET, |
||||
|
SO_REUSEADDR | SO_REUSEPORT, &opt, |
||||
|
sizeof (opt))) { |
||||
|
perror ("setsockopt"); |
||||
|
exit (EXIT_FAILURE); |
||||
|
} |
||||
|
address.sin_family = AF_INET; |
||||
|
address.sin_addr.s_addr = INADDR_ANY; |
||||
|
address.sin_port = htons (port); |
||||
|
|
||||
|
LOG ("bind"); |
||||
|
if (bind (serverSocket, (struct sockaddr*)&address, sizeof (address)) < 0) { |
||||
|
perror ("bind failed"); |
||||
|
exit (EXIT_FAILURE); |
||||
|
} |
||||
|
|
||||
|
LOG ("listen"); |
||||
|
if (listen (serverSocket, 3) < 0) { |
||||
|
perror ("listen"); |
||||
|
exit (EXIT_FAILURE); |
||||
|
} |
||||
|
|
||||
|
CONSOLE ("Server started on port " << port); |
||||
|
for (;;) { |
||||
|
LOG ("accept"); |
||||
|
int clientSocket (accept (serverSocket, (struct sockaddr*) &address, &addrlen)); |
||||
|
if (clientSocket < 0) { |
||||
|
perror ("accept"); |
||||
|
// XXX ne pas quitter
|
||||
|
exit (EXIT_FAILURE); |
||||
|
} |
||||
|
char *command[] = {const_cast<char *> (BASH.c_str ()), |
||||
|
const_cast<char *> (filterFileName.c_str ()), NULL}; |
||||
|
switch (fork ()) { |
||||
|
case -1: |
||||
|
perror ("fork"); |
||||
|
exit (EXIT_FAILURE); |
||||
|
case 0: |
||||
|
CONSOLE ("New request"); |
||||
|
close (STDOUT_FILENO); |
||||
|
close (STDIN_FILENO); |
||||
|
dup2 (clientSocket, STDIN_FILENO); |
||||
|
dup2 (clientSocket, STDOUT_FILENO); |
||||
|
execve (BASH.c_str (), command, envp); |
||||
|
perror ("execve"); |
||||
|
break; |
||||
|
default: |
||||
|
close (clientSocket); |
||||
|
break; |
||||
|
} |
||||
|
} |
||||
|
// XXX condition de sortie ?
|
||||
|
close (serverSocket); |
||||
|
return 0; |
||||
|
} |
||||
|
|
||||
|
// ================================================================================
|
@ -0,0 +1,118 @@ |
|||||
|
////////////////////////////////////////////////////////////////////////////
|
||||
|
// Copyright KAZ 2021 //
|
||||
|
// //
|
||||
|
// contact (at) kaz.bzh //
|
||||
|
// //
|
||||
|
// This software is a filter to shrink email by attachment extraction. //
|
||||
|
// //
|
||||
|
// This software is governed by the CeCILL-B license under French law and //
|
||||
|
// abiding by the rules of distribution of free software. You can use, //
|
||||
|
// modify and/or redistribute the software under the terms of the //
|
||||
|
// CeCILL-B license as circulated by CEA, CNRS and INRIA at the following //
|
||||
|
// URL "http://www.cecill.info". //
|
||||
|
// //
|
||||
|
// As a counterpart to the access to the source code and rights to copy, //
|
||||
|
// modify and redistribute granted by the license, users are provided //
|
||||
|
// only with a limited warranty and the software's author, the holder of //
|
||||
|
// the economic rights, and the successive licensors have only limited //
|
||||
|
// liability. //
|
||||
|
// //
|
||||
|
// In this respect, the user's attention is drawn to the risks associated //
|
||||
|
// with loading, using, modifying and/or developing or reproducing the //
|
||||
|
// software by the user in light of its specific status of free software, //
|
||||
|
// that may mean that it is complicated to manipulate, and that also //
|
||||
|
// therefore means that it is reserved for developers and experienced //
|
||||
|
// professionals having in-depth computer knowledge. Users are therefore //
|
||||
|
// encouraged to load and test the software's suitability as regards //
|
||||
|
// their requirements in conditions enabling the security of their //
|
||||
|
// systems and/or data to be ensured and, more generally, to use and //
|
||||
|
// operate it in the same conditions as regards security. //
|
||||
|
// //
|
||||
|
// The fact that you are presently reading this means that you have had //
|
||||
|
// knowledge of the CeCILL-B license and that you accept its terms. //
|
||||
|
////////////////////////////////////////////////////////////////////////////
|
||||
|
|
||||
|
#include <arpa/inet.h> |
||||
|
#include <iostream> |
||||
|
#include <stdio.h> |
||||
|
#include <string> |
||||
|
#include <sys/socket.h> |
||||
|
#include <unistd.h> |
||||
|
|
||||
|
#include "kazDebug.hpp" |
||||
|
|
||||
|
using namespace std; |
||||
|
using namespace kaz; |
||||
|
|
||||
|
const string LAST_VERSION_NUM ("3.0"); |
||||
|
const string LAST_VERSION_DATE ("2024-01-01"); |
||||
|
const string LAST_VERSION (LAST_VERSION_NUM+" "+LAST_VERSION_DATE+" testServerRW"); |
||||
|
|
||||
|
#define PORT 8080 |
||||
|
|
||||
|
int |
||||
|
main (int argc, char const* argv[]) { |
||||
|
Log::debug = true; |
||||
|
DEF_LOG ("main:", LAST_VERSION); |
||||
|
|
||||
|
int clientSocket; |
||||
|
struct sockaddr_in serv_addr; |
||||
|
LOG ("create socket"); |
||||
|
if ((clientSocket = socket (AF_INET, SOCK_STREAM, 0)) < 0) { |
||||
|
cerr << endl << "Socket creation error" << endl; |
||||
|
perror ("socket failed"); |
||||
|
return -1; |
||||
|
} |
||||
|
serv_addr.sin_family = AF_INET; |
||||
|
serv_addr.sin_port = htons (PORT); |
||||
|
|
||||
|
LOG ("check address"); |
||||
|
if (inet_pton (AF_INET, "127.0.0.1", &serv_addr.sin_addr) <= 0) { |
||||
|
cerr << endl << "Invalid address / Address not supported" << endl; |
||||
|
perror ("socket failed"); |
||||
|
return -1; |
||||
|
} |
||||
|
|
||||
|
LOG ("connect on " << PORT); |
||||
|
if (connect (clientSocket, (struct sockaddr *) &serv_addr, sizeof (serv_addr)) < 0) { |
||||
|
cerr << endl << "Connection Failed" << endl; |
||||
|
perror ("socket failed"); |
||||
|
return -1; |
||||
|
} |
||||
|
|
||||
|
bool end (false); |
||||
|
LOG ("send original email (end with QUIT)"); |
||||
|
for (;;) { |
||||
|
if (!end) { |
||||
|
string hello; |
||||
|
cin >> hello; |
||||
|
if (hello == "QUIT") { |
||||
|
shutdown (clientSocket, SHUT_WR); |
||||
|
LOG ("shutdown send"); |
||||
|
break; |
||||
|
} |
||||
|
LOG ("avant"); |
||||
|
hello.push_back ('\n'); |
||||
|
send (clientSocket, hello.c_str (), hello.size (), 0); |
||||
|
LOG ("apres"); |
||||
|
} |
||||
|
} |
||||
|
LOG ("receive..."); |
||||
|
for (;;) { |
||||
|
char buffer[1024] = { 0 }; |
||||
|
ssize_t msgSize (recv (clientSocket, buffer, 1024 - 1, 0)); |
||||
|
switch (msgSize) { |
||||
|
case -1 : |
||||
|
perror ("socket failed"); |
||||
|
return -1; |
||||
|
case 0 : |
||||
|
LOG ("shutdown receive"); |
||||
|
close (clientSocket); |
||||
|
return 0; |
||||
|
break; |
||||
|
default: |
||||
|
//cout.write (buffer, msgSize);
|
||||
|
printf ("%s\n", buffer); |
||||
|
} |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue