2014-06-07 11:52:30 +00:00
|
|
|
|
2014-09-14 16:16:41 +00:00
|
|
|
#include "ntk-console.h"
|
2014-06-07 11:52:30 +00:00
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
#include <unistd.h>
|
2014-06-07 11:52:30 +00:00
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
|
|
|
const struct supported_commands {
|
|
|
|
command_t id;
|
|
|
|
const char* command;
|
|
|
|
const char* help;
|
|
|
|
int arguments;
|
|
|
|
} kSupportedCommands[] = {
|
|
|
|
{COMMAND_HELP, "help", "Shows console help", 0},
|
|
|
|
{COMMAND_UPTIME, "uptime", "Returns the time when ntkd finished the hooking", 0},
|
|
|
|
{COMMAND_KILL, "kill", "Kills the running instance of netsukuku with SIGINT", 0},
|
|
|
|
{COMMAND_VERSION, "version", "Shows the running version of the ntk-console, and ntkd.", 0},
|
|
|
|
{COMMAND_INETCONN, "inet_connected", "Query if Ntkd is connected to the internet", 0},
|
|
|
|
{COMMAND_CURIFS, "cur_ifs", "Lists all of the interfaces in cur_ifs", 0},
|
|
|
|
{COMMAND_CURIFSCT, "cur_ifs_n", "Lists the number of interfaces present in `cur_ifs`", 0},
|
|
|
|
{COMMAND_CURQSPNID, "cur_qspn_id", "The current qspn_id we are processing. It is cur_qspn_id[levels] big", 0},
|
|
|
|
{COMMAND_CURIP, "cur_ip", "Current IP address", 0},
|
|
|
|
{COMMAND_CURNODE, "cur_node", "Current node", 0},
|
|
|
|
{COMMAND_IFS, "ifs", "List all the interfaces in server_opt.ifs", 0},
|
|
|
|
{COMMAND_IFSCT, "ifs_n", "List the number of interfaces present in server_opt.ifs", 0},
|
|
|
|
{COMMAND_QUIT, "quit", "Exit the console", 0},
|
|
|
|
{COMMAND_CONSUPTIME,"console_uptime", "Get the uptime of this console", 0},
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
command_t
|
|
|
|
command_parse(char *request)
|
|
|
|
{
|
|
|
|
if (strlen(request) > BUFFER_LENGTH) {
|
|
|
|
printf("Error: Command longer than 250 bytes.\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < sizeof(kSupportedCommands)
|
|
|
|
/ sizeof(kSupportedCommands[0]); i++) {
|
|
|
|
if (strncmp(request, kSupportedCommands[i].command,
|
|
|
|
(int)strlen(request) - 1) == 0) {
|
|
|
|
return kSupportedCommands[i].id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("Incorrect or unreadable command, Please correct it.\n");
|
|
|
|
return -1;
|
2014-06-02 07:14:19 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
static int
|
|
|
|
request_receive(int sock, char message[], int max)
|
2014-09-14 01:13:49 +00:00
|
|
|
{
|
2014-09-14 14:50:08 +00:00
|
|
|
int total = 0;
|
|
|
|
const int bsize = 1024;
|
|
|
|
char buffer[bsize+1];
|
|
|
|
int read = bsize;
|
|
|
|
|
|
|
|
message[0] = 0; // initialize for strcat()
|
|
|
|
|
|
|
|
while(read == bsize) {
|
|
|
|
read = recv(sock, buffer, bsize, 0);
|
|
|
|
if(read < 0)
|
|
|
|
return -1; // error, bail out
|
|
|
|
total += read;
|
|
|
|
if(total > max)
|
|
|
|
return -2; // overflow
|
|
|
|
buffer[read] = 0;
|
|
|
|
strcat(message, buffer);
|
2014-09-14 01:13:49 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
return total;
|
2014-08-16 05:51:54 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
2014-08-04 07:04:46 +00:00
|
|
|
/* Sends and receives to ntkd */
|
2014-09-14 01:13:49 +00:00
|
|
|
void
|
|
|
|
ntkd_request(char *request)
|
|
|
|
{
|
2014-09-14 14:50:08 +00:00
|
|
|
if (sockfd <= 0) {
|
|
|
|
perror("ntkd connection closed unexpectedly!\n");
|
2014-09-14 01:13:49 +00:00
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
int request_length = strlen(request) - 1;
|
|
|
|
request[request_length] = '\0';
|
|
|
|
|
|
|
|
printf("request: '%s'\n", request);
|
|
|
|
rc = send(sockfd, request, request_length, 0);
|
2014-09-14 01:13:49 +00:00
|
|
|
if (rc < 0) {
|
|
|
|
perror("send() failed");
|
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
|
2014-09-14 15:40:39 +00:00
|
|
|
char response[BUFFER_LENGTH];
|
2014-09-14 14:50:08 +00:00
|
|
|
request_receive(sockfd, response, BUFFER_LENGTH);
|
|
|
|
if (rc < 0) {
|
|
|
|
perror("recv() failed");
|
2014-09-14 01:13:49 +00:00
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
|
2014-09-14 15:40:39 +00:00
|
|
|
printf("Response: %s\n", response);
|
2014-06-03 05:06:48 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
opensocket(void)
|
|
|
|
{
|
|
|
|
sockfd = socket(AF_UNIX, SOCK_STREAM, 0);
|
|
|
|
if (sockfd < 0) {
|
|
|
|
perror("socket creation failed");
|
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
memset(&serveraddr, 0, sizeof(serveraddr));
|
|
|
|
serveraddr.sun_family = AF_UNIX;
|
|
|
|
strcpy(serveraddr.sun_path, SERVER_PATH);
|
2014-09-14 14:50:08 +00:00
|
|
|
|
|
|
|
rc = connect(sockfd, (struct sockaddr *)&serveraddr, sizeof(serveraddr));
|
|
|
|
if (rc < 0) {
|
|
|
|
perror("connect() failed");
|
2014-09-14 15:40:39 +00:00
|
|
|
printf("Unable to connect to ntk daemon console.\n");
|
2014-09-14 14:50:08 +00:00
|
|
|
exit(-1);
|
|
|
|
}
|
|
|
|
printf("ntkd console connection opened successfully.\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
closesocket(void)
|
|
|
|
{
|
|
|
|
const int optVal = 1;
|
|
|
|
const socklen_t optLen = sizeof(optVal);
|
|
|
|
|
|
|
|
setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (void*) &optVal, optLen);
|
|
|
|
|
|
|
|
if (sockfd >= 0)
|
|
|
|
close(sockfd);
|
|
|
|
|
|
|
|
printf("ntkd console connection closed.\n");
|
2014-06-02 07:14:19 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
console_uptime(void)
|
|
|
|
{
|
|
|
|
int uptime_sec1;
|
|
|
|
int uptime_min1;
|
|
|
|
int uptime_hour1;
|
|
|
|
|
|
|
|
int uptime_day1;
|
|
|
|
int uptime_month1;
|
|
|
|
int uptime_year1;
|
|
|
|
|
|
|
|
time(&rawtime);
|
|
|
|
|
|
|
|
timeinfo = localtime(&rawtime);
|
|
|
|
|
|
|
|
uptime_sec1 = timeinfo->tm_sec;
|
|
|
|
uptime_min1 = timeinfo->tm_min;
|
|
|
|
uptime_hour1 = timeinfo->tm_hour;
|
|
|
|
|
|
|
|
uptime_day1 = timeinfo->tm_mday;
|
|
|
|
uptime_month1 = timeinfo->tm_mon;
|
|
|
|
uptime_year1 = timeinfo->tm_year;
|
|
|
|
|
|
|
|
uptime_sec1 -= uptime_sec;
|
|
|
|
uptime_min1 -= uptime_min;
|
|
|
|
uptime_hour1 -= uptime_hour;
|
|
|
|
|
|
|
|
uptime_day1 -= uptime_day;
|
|
|
|
uptime_month1 -= uptime_month;
|
|
|
|
uptime_year1 -= uptime_year;
|
|
|
|
|
|
|
|
printf("Total Uptime is: %i Year(s), %i Month(s), %i Day(s), %i Hour(s), %i Minute(s), %i Second(s)\n",uptime_year1, uptime_month1, uptime_day1, uptime_hour1, uptime_min1, uptime_sec1);
|
Wow! I've done A LOT of work on the netsukuku console recently! I still haven't set up any way for ntkd to receive the commands, Or done much of anything in netsukuku itself recently except change some stuff in the exclude function to prevent possible errors if an interface had the same name up until the end of the one specified. I.E if it had tunl012, It wouldn't work because it had tunl0 in the beginning. Now, It will read from the entire length of the variable, And if it doesn't match it entirely, Then it is okay.
Anyway! The netsukuku console is almost ready! I just keep getting this weird issue around fgets() not working at all in console(). It causes the program to spam the > symbol. It functions in main()! However, After that, It has a segmentation fault. I've been trying everything I can think of, One thing made it not do a segmentation fault, However! The fgets() inside of console() still didn't work, So, It just spammed endlessly. Anyone who can, Please help! I've been working on this for a while! :/
2014-06-04 10:47:49 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
static void
|
2014-09-14 01:13:49 +00:00
|
|
|
millisleep(unsigned ms)
|
2014-08-17 15:27:29 +00:00
|
|
|
{
|
2014-09-14 14:50:08 +00:00
|
|
|
usleep(1000 * ms);
|
2014-08-17 15:27:29 +00:00
|
|
|
}
|
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
console(char* request)
|
|
|
|
{
|
|
|
|
command_t commandID = command_parse(request);
|
|
|
|
|
|
|
|
switch (commandID) {
|
|
|
|
case COMMAND_QUIT:
|
2014-09-14 14:50:08 +00:00
|
|
|
closesocket();
|
2014-09-14 01:13:49 +00:00
|
|
|
exit(0);
|
2014-09-14 15:40:39 +00:00
|
|
|
break;
|
2014-09-14 01:13:49 +00:00
|
|
|
case COMMAND_UPTIME:
|
|
|
|
case COMMAND_INETCONN:
|
|
|
|
case COMMAND_CURIFS:
|
|
|
|
case COMMAND_CURIFSCT:
|
|
|
|
case COMMAND_CURQSPNID:
|
|
|
|
case COMMAND_CURIP:
|
|
|
|
case COMMAND_CURNODE:
|
|
|
|
case COMMAND_IFS:
|
|
|
|
case COMMAND_IFSCT:
|
|
|
|
ntkd_request(request);
|
|
|
|
millisleep(200);
|
|
|
|
break;
|
|
|
|
case COMMAND_VERSION:
|
|
|
|
printf("Ntk-Console Version: %s\n", VERSION_STR);
|
|
|
|
ntkd_request(request);
|
|
|
|
break;
|
|
|
|
case COMMAND_CONSUPTIME:
|
|
|
|
console_uptime();
|
|
|
|
break;
|
|
|
|
case COMMAND_KILL:
|
2014-09-14 14:50:08 +00:00
|
|
|
closesocket();
|
2014-09-14 01:13:49 +00:00
|
|
|
system("ntkd -k");
|
|
|
|
break;
|
|
|
|
case COMMAND_HELP:
|
|
|
|
default:
|
|
|
|
usage();
|
|
|
|
}
|
2014-06-03 05:06:48 +00:00
|
|
|
}
|
2014-06-02 07:14:19 +00:00
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
time(&rawtime);
|
|
|
|
|
|
|
|
timeinfo = localtime(&rawtime);
|
|
|
|
|
|
|
|
uptime_sec = timeinfo->tm_sec;
|
|
|
|
uptime_min = timeinfo->tm_min;
|
|
|
|
uptime_hour = timeinfo->tm_hour;
|
|
|
|
uptime_day = timeinfo->tm_mday;
|
|
|
|
uptime_month = timeinfo->tm_mon;
|
|
|
|
uptime_year = timeinfo->tm_year;
|
|
|
|
|
2014-09-14 14:50:08 +00:00
|
|
|
opensocket();
|
2014-09-14 15:40:39 +00:00
|
|
|
|
|
|
|
printf("This is the Netsukuku Console. Please type 'help' for more information.\n");
|
|
|
|
for(;;) {
|
|
|
|
char* request = (char*)malloc(BUFFER_LENGTH);
|
2014-09-14 14:50:08 +00:00
|
|
|
printf("\n> ");
|
2014-09-14 01:13:49 +00:00
|
|
|
fgets(request, 16, stdin);
|
|
|
|
fflush(stdin);
|
|
|
|
console(request);
|
2014-09-14 15:40:39 +00:00
|
|
|
free(request);
|
|
|
|
}
|
2014-09-14 14:50:08 +00:00
|
|
|
closesocket();
|
2014-09-14 15:40:39 +00:00
|
|
|
|
2014-09-14 01:13:49 +00:00
|
|
|
return 0;
|
2014-06-03 05:06:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void usage(void) {
|
2014-09-14 14:50:08 +00:00
|
|
|
printf("Usage:\n");
|
|
|
|
for (int i = 0; i < sizeof(kSupportedCommands)
|
|
|
|
/ sizeof(kSupportedCommands[0]); i++) {
|
|
|
|
printf(" %16s - %s\n", kSupportedCommands[i].command, kSupportedCommands[i].help);
|
|
|
|
}
|
2014-09-14 01:13:49 +00:00
|
|
|
}
|