Added IPv6 address function
- Renamed "ip" function to "ipv4" - Added "ipv6" function - Adjusted README and config.def.h accordingly
This commit is contained in:
parent
fcc5c683a6
commit
8f5219b6da
3 changed files with 39 additions and 6 deletions
2
README
2
README
|
@ -15,7 +15,7 @@ Features
|
||||||
- Available entropy
|
- Available entropy
|
||||||
- Username/GID/UID
|
- Username/GID/UID
|
||||||
- Hostname
|
- Hostname
|
||||||
- IP address
|
- IP address (IPv4 and IPv6)
|
||||||
- Kernel version
|
- Kernel version
|
||||||
- Keyboard indicators
|
- Keyboard indicators
|
||||||
- Load average
|
- Load average
|
||||||
|
|
|
@ -25,7 +25,8 @@ static const char unknown_str[] = "n/a";
|
||||||
* entropy available entropy NULL
|
* entropy available entropy NULL
|
||||||
* gid GID of current user NULL
|
* gid GID of current user NULL
|
||||||
* hostname hostname NULL
|
* hostname hostname NULL
|
||||||
* ip IPv4 address interface name
|
* ipv4 IPv4 address interface name
|
||||||
|
* ipv6 IPv6 address interface name
|
||||||
* kernel_release `uname -r` NULL
|
* kernel_release `uname -r` NULL
|
||||||
* keyboard_indicators caps/num lock indicators NULL
|
* keyboard_indicators caps/num lock indicators NULL
|
||||||
* load_avg load average NULL
|
* load_avg load average NULL
|
||||||
|
|
40
slstatus.c
40
slstatus.c
|
@ -48,7 +48,8 @@ static const char *disk_used(const char *mnt);
|
||||||
static const char *entropy(void);
|
static const char *entropy(void);
|
||||||
static const char *gid(void);
|
static const char *gid(void);
|
||||||
static const char *hostname(void);
|
static const char *hostname(void);
|
||||||
static const char *ip(const char *iface);
|
static const char *ipv4(const char *iface);
|
||||||
|
static const char *ipv6(const char *iface);
|
||||||
static const char *kernel_release(void);
|
static const char *kernel_release(void);
|
||||||
static const char *keyboard_indicators(void);
|
static const char *keyboard_indicators(void);
|
||||||
static const char *load_avg(void);
|
static const char *load_avg(void);
|
||||||
|
@ -294,14 +295,14 @@ hostname(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
ip(const char *iface)
|
ipv4(const char *iface)
|
||||||
{
|
{
|
||||||
struct ifaddrs *ifaddr, *ifa;
|
struct ifaddrs *ifaddr, *ifa;
|
||||||
int s;
|
int s;
|
||||||
char host[NI_MAXHOST];
|
char host[NI_MAXHOST];
|
||||||
|
|
||||||
if (getifaddrs(&ifaddr) == -1) {
|
if (getifaddrs(&ifaddr) == -1) {
|
||||||
warn("Failed to get IP address for interface %s", iface);
|
warn("Failed to get IPv4 address for interface %s", iface);
|
||||||
return unknown_str;
|
return unknown_str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -312,7 +313,38 @@ ip(const char *iface)
|
||||||
s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in), host, NI_MAXHOST, NULL, 0, NI_NUMERICHOST);
|
s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in), host, NI_MAXHOST, NULL, 0, NI_NUMERICHOST);
|
||||||
if ((strcmp(ifa->ifa_name, iface) == 0) && (ifa->ifa_addr->sa_family == AF_INET)) {
|
if ((strcmp(ifa->ifa_name, iface) == 0) && (ifa->ifa_addr->sa_family == AF_INET)) {
|
||||||
if (s != 0) {
|
if (s != 0) {
|
||||||
warnx("Failed to get IP address for interface %s", iface);
|
warnx("Failed to get IPv4 address for interface %s", iface);
|
||||||
|
return unknown_str;
|
||||||
|
}
|
||||||
|
return bprintf("%s", host);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
freeifaddrs(ifaddr);
|
||||||
|
|
||||||
|
return unknown_str;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
ipv6(const char *iface)
|
||||||
|
{
|
||||||
|
struct ifaddrs *ifaddr, *ifa;
|
||||||
|
int s;
|
||||||
|
char host[NI_MAXHOST];
|
||||||
|
|
||||||
|
if (getifaddrs(&ifaddr) == -1) {
|
||||||
|
warn("Failed to get IPv6 address for interface %s", iface);
|
||||||
|
return unknown_str;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (ifa = ifaddr; ifa != NULL; ifa = ifa->ifa_next) {
|
||||||
|
if (ifa->ifa_addr == NULL) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
s = getnameinfo(ifa->ifa_addr, sizeof(struct sockaddr_in6), host, NI_MAXHOST, NULL, 0, NI_NUMERICHOST);
|
||||||
|
if ((strcmp(ifa->ifa_name, iface) == 0) && (ifa->ifa_addr->sa_family == AF_INET6)) {
|
||||||
|
if (s != 0) {
|
||||||
|
warnx("Failed to get IPv6 address for interface %s", iface);
|
||||||
return unknown_str;
|
return unknown_str;
|
||||||
}
|
}
|
||||||
return bprintf("%s", host);
|
return bprintf("%s", host);
|
||||||
|
|
Loading…
Reference in a new issue