Obsolete
/
libipc-old
Archived
3
0
Fork 0
This repository has been archived on 2024-06-18. You can view files and clone it, but cannot push or open issues/pull-requests.
libipc-old/examples/wsserver.c

123 lines
2.9 KiB
C
Raw Normal View History

2019-07-27 15:48:10 +02:00
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include "../src/ipc.h"
#include "../src/utils.h"
#define WEBSOCKETD_BULLSHIT
void chomp (char *str, ssize_t len)
{
if (str[len - 1] == '\n') {
str[len - 1] = '\0';
2019-07-27 15:48:10 +02:00
}
if (str[len - 2] == '\n') {
str[len - 2] = '\0';
2019-07-27 15:48:10 +02:00
}
}
struct ipc_connection_info *srv;
void interactive (char *env[])
{
long timer = 10;
2019-07-27 15:48:10 +02:00
SECURE_BUFFER_DECLARATION (char, service_name, 100);
char *sn = getenv ("PATH_TRANSLATED");
2019-07-27 15:48:10 +02:00
if (sn != NULL) {
memcpy (service_name, sn, strlen (sn));
} else {
2019-07-27 15:48:10 +02:00
fprintf (stderr, "cannot see PATH_TRANSLATED variable\n");
exit (EXIT_FAILURE);
}
// init service
TEST_IPC_Q (ipc_connection (env, srv, service_name), EXIT_FAILURE);
2019-07-27 15:48:10 +02:00
SECURE_DECLARATION (struct ipc_event, event);
2020-06-27 19:16:07 +02:00
SECURE_DECLARATION (struct ipc_ctx, services);
2019-07-27 15:48:10 +02:00
ipc_add (&services, srv);
ipc_add_fd (&services, 0); // add STDIN
2019-07-27 15:48:10 +02:00
while (1) {
TEST_IPC_WAIT_EVENT_Q (ipc_wait_event (&services, NULL, &event, &timer), EXIT_FAILURE);
2019-07-27 15:48:10 +02:00
switch (event.type) {
case IPC_EVENT_TYPE_TIMER:{
fprintf (stderr, "time up!\n");
timer = 10;
};
break;
case IPC_EVENT_TYPE_EXTRA_SOCKET:
{
// structure not read, should read the message here
SECURE_BUFFER_DECLARATION (char, buf, 4096);
ssize_t len;
2019-07-27 15:48:10 +02:00
len = read (event.origin->fd, buf, 4096);
2019-07-27 15:48:10 +02:00
// in case we want to quit the program
if (len == 0 || strncmp (buf, "quit", 4) == 0 || strncmp (buf, "exit", 4) == 0) {
2019-07-27 15:48:10 +02:00
TEST_IPC_Q (ipc_close (srv), EXIT_FAILURE);
2019-07-27 15:48:10 +02:00
ipc_connections_free (&services);
2019-07-27 15:48:10 +02:00
exit (EXIT_SUCCESS);
}
// send the message read on STDIN
ssize_t len_sent = write (srv->fd, buf, len);
if (len_sent != len) {
fprintf (stderr, "cannot send the message %lu-byte message, sent %lu bytes",
len, len_sent);
exit (EXIT_FAILURE);
2019-07-27 15:48:10 +02:00
}
}
break;
case IPC_EVENT_TYPE_MESSAGE:
{
struct ipc_message *m = event.m;
SECURE_BUFFER_DECLARATION (char, buf, 4096);
uint32_t size;
size = ipc_message_raw_serialize (buf, m->type, m->user_type, m->payload, m->length);
write (1, buf, size);
2019-07-27 15:48:10 +02:00
#ifdef WEBSOCKETD_BULLSHIT
printf ("\n");
2019-07-27 15:48:10 +02:00
#endif
fflush (stdout);
};
break;
ERROR_CASE (IPC_EVENT_TYPE_DISCONNECTION, "main loop", "disconnection: should not happen");
ERROR_CASE (IPC_EVENT_TYPE_NOT_SET , "main loop", "not set: should not happen");
ERROR_CASE (IPC_EVENT_TYPE_CONNECTION , "main loop", "connection: should not happen");
// ERROR_CASE (IPC_EVENT_TYPE_ERROR , "main loop", "error");
default:
fprintf (stderr, "event type error: should not happen, event type %d\n", event.type);
2019-07-27 15:48:10 +02:00
}
}
2019-07-27 15:48:10 +02:00
}
int main (int argc, char *argv[], char *env[])
{
argc = argc; // warnings
argv = argv; // warnings
2019-07-27 15:48:10 +02:00
srv = malloc (sizeof (struct ipc_connection_info));
memset (srv, 0, sizeof (struct ipc_connection_info));
// index and version should be filled
srv->index = 0;
srv->version = 0;
interactive (env);
return EXIT_SUCCESS;
}