diff options
author | rsiddharth <s@ricketyspace.net> | 2020-04-17 21:02:35 -0400 |
---|---|---|
committer | rsiddharth <s@ricketyspace.net> | 2020-04-17 21:02:35 -0400 |
commit | b924fc2f66d46ee10aa3b800a6521d3940919f9f (patch) | |
tree | 130a19d8211874e3ba01203af0d2332506106be4 /bin | |
parent | 1bab8e87d3875f672e7c36d10aea9e05f657c664 (diff) |
nserver/ -> ./
Diffstat (limited to 'bin')
-rw-r--r-- | bin/statserve.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/bin/statserve.c b/bin/statserve.c new file mode 100644 index 0000000..fa6d488 --- /dev/null +++ b/bin/statserve.c @@ -0,0 +1,54 @@ +/* SPDX-License-Identifier: BSD-3-Clause */ +/* + * Copyright © 2020 rsiddharth <s@ricketyspace.net> + */ + +#include <nserve.h> +#include <nsocket.h> + +#define BACKLOG 10 + +int main(void) +{ + int rc = 0; + int sockfd_s = 0, sockfd_c = 0; + struct sockaddr sockaddr_c; + socklen_t sockaddr_c_len; + pid_t pidc; + + sockfd_s = get_socket(); + check(sockfd_s > 0, "stateserv: unable to get socket"); + + rc = listen(sockfd_s, BACKLOG); + check(rc == 0, "statserve: listen failed"); + + do { + printf("Waiting for connection...\n"); + sockfd_c = accept(sockfd_s, &sockaddr_c, &sockaddr_c_len); + + pidc = fork(); + check(pidc != -1, "statserve: fork failed"); + + if (pidc == 0) { + nserve(sockfd_c); + } + + rc = close(sockfd_c); + check(rc == 0, "statserv: close failed"); + } while(1); + + rc = close(sockfd_s); + check(rc == 0, "statserv: close failed"); + + return 0; + + error: + if (sockfd_s) { + rc = close(sockfd_s); + } + if (sockfd_c) { + rc = close(sockfd_c); + } + + return -1; +} |