From ce0f41da41a2d97d4a8e7159747464ecef72de4c Mon Sep 17 00:00:00 2001 From: Nakidai Date: Wed, 4 Feb 2026 12:21:47 +0300 Subject: Add WHOIS and config parsing Now users can query each other Plus, server info and creation date can be changed without recompiling using configuration file in IRC message format which is loaded on startup TODO: since readcfg uses IRC logic, handle() now should be able to deal with commands ending with simply \n --- config.c | 73 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 config.c (limited to 'config.c') diff --git a/config.c b/config.c new file mode 100644 index 0000000..9d945eb --- /dev/null +++ b/config.c @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2026 Nakidai Perumenei + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include "ircd.h" + +#include + +#include +#include +#include +#include + +#include +#include + +char creation[CREATION_MAX] = CREATION_DATE; +char info[INFO_MAX] = INFO; + +int +readcfg(const char *path) +{ + struct Peer peer; + ssize_t recvd; + int fd, ret; + + fd = open(path, O_RDONLY); + ensure(fd != -1, warn("open(%s)", path), 0); + + peer = (struct Peer){ + .fd = STDERR_FILENO, + .type = CONFIG, + }; + strlcpy(peer.nick, path, sizeof(peer.nick)); + + for (ret = 0;;) + { + recvd = read( + fd, + peer.buf + peer.recvd, + sizeof(peer.buf) - peer.recvd + ); + peer.recvd += recvd; + if (recvd == -1) + { + warn("read(%s)", path); + ++ret; + goto end; + } else if (!recvd) + { + goto end; + } else if (handle(&peer)) + { + ++ret; + goto end; + } + } +end: + close(fd); + return ret; +} -- cgit 1.4.1