X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;ds=sidebyside;f=networking%2Fudhcp%2Fdumpleases.c;h=c98005f138cb2e9e55d40c4c2dd4f2797637e869;hb=32dcc53b7162406148203b8222c3f5c5056f70f2;hp=2b19d976829353a1c95714d5c692794ca84f7f60;hpb=61fb48930f45aa536584b2047f9e703186e8f69f;p=oweals%2Fbusybox.git diff --git a/networking/udhcp/dumpleases.c b/networking/udhcp/dumpleases.c index 2b19d9768..c98005f13 100644 --- a/networking/udhcp/dumpleases.c +++ b/networking/udhcp/dumpleases.c @@ -1,112 +1,66 @@ -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include +/* vi: set sw=4 ts=4: */ +/* + * Licensed under the GPL v2 or later, see the file LICENSE in this tarball. + */ -#include "libbb_udhcp.h" +#include "common.h" +#include "dhcpd.h" -#define REMAINING 0 -#define ABSOLUTE 1 - -struct lease_t { - unsigned char chaddr[16]; - u_int32_t yiaddr; - u_int32_t expires; -}; - -#ifdef BB_VER -int dumpleases_main(int argc, char *argv[]) -#else -int main(int argc, char *argv[]) -#endif +int dumpleases_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; +int dumpleases_main(int argc ATTRIBUTE_UNUSED, char **argv) { - FILE *fp; - int i, c, mode = REMAINING; - long expires; - char file[255] = "/var/lib/misc/udhcpd.leases"; - struct lease_t lease; + int fd; + int i; + unsigned opt; + time_t expires; + const char *file = LEASES_FILE; + struct dhcpOfferedAddr lease; struct in_addr addr; - - static struct option options[] = { - {"absolute", 0, 0, 'a'}, - {"remaining", 0, 0, 'r'}, - {"file", 1, 0, 'f'}, - {"help", 0, 0, 'h'}, - {0, 0, 0, 0} + + enum { + OPT_a = 0x1, // -a + OPT_r = 0x2, // -r + OPT_f = 0x4, // -f }; +#if ENABLE_GETOPT_LONG + static const char dumpleases_longopts[] ALIGN1 = + "absolute\0" No_argument "a" + "remaining\0" No_argument "r" + "file\0" Required_argument "f" + ; - while (1) { - int option_index = 0; - c = getopt_long(argc, argv, "arf:h", options, &option_index); - if (c == -1) break; - - switch (c) { - case 'a': mode = ABSOLUTE; break; - case 'r': mode = REMAINING; break; - case 'f': - strncpy(file, optarg, 255); - file[254] = '\0'; - break; - case 'h': - printf("Usage: dumpleases -f -[r|a]\n\n"); - printf(" -f, --file=FILENAME Leases file to load\n"); - printf(" -r, --remaining Interepret lease times as time remaing\n"); - printf(" -a, --absolute Interepret lease times as expire time\n"); - break; - } - } - - if (!(fp = fopen(file, "r"))) { - perror("could not open input file"); - return 0; - } + applet_long_options = dumpleases_longopts; +#endif + opt_complementary = "=0:a--r:r--a"; + opt = getopt32(argv, "arf:", &file); - printf("Mac Address IP-Address Expires %s\n", mode == REMAINING ? "in" : "at"); - /* "00:00:00:00:00:00 255.255.255.255 Wed Jun 30 21:49:08 1993" */ - while (fread(&lease, sizeof(lease), 1, fp)) { + fd = xopen(file, O_RDONLY); - for (i = 0; i < 6; i++) { - printf("%02x", lease.chaddr[i]); - if (i != 5) printf(":"); + printf("Mac Address IP-Address Expires %s\n", (opt & OPT_a) ? "at" : "in"); + /* "00:00:00:00:00:00 255.255.255.255 Wed Jun 30 21:49:08 1993" */ + while (full_read(fd, &lease, sizeof(lease)) == sizeof(lease)) { + printf(":%02x"+1, lease.chaddr[0]); + for (i = 1; i < 6; i++) { + printf(":%02x", lease.chaddr[i]); } addr.s_addr = lease.yiaddr; - printf(" %-15s", inet_ntoa(addr)); + printf(" %-15s ", inet_ntoa(addr)); expires = ntohl(lease.expires); - printf(" "); - if (mode == REMAINING) { - if (!expires) printf("expired\n"); + if (!(opt & OPT_a)) { /* no -a */ + if (!expires) + puts("expired"); else { - if (expires > 60*60*24) { - printf("%ld days, ", expires / (60*60*24)); - expires %= 60*60*24; - } - if (expires > 60*60) { - printf("%ld hours, ", expires / (60*60)); - expires %= 60*60; - } - if (expires > 60) { - printf("%ld minutes, ", expires / 60); - expires %= 60; - } - printf("%ld seconds\n", expires); + unsigned d, h, m; + d = expires / (24*60*60); expires %= (24*60*60); + h = expires / (60*60); expires %= (60*60); + m = expires / 60; expires %= 60; + if (d) printf("%u days ", d); + printf("%02u:%02u:%02u\n", h, m, (unsigned)expires); } - } else printf("%s", ctime(&expires)); + } else /* -a */ + fputs(ctime(&expires), stdout); } - fclose(fp); - + /* close(fd); */ + return 0; }