mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-26 16:48:28 +00:00
Added support for APC UPS daemon monitoring.
This commit is contained in:
parent
7268dd3cc6
commit
cf2c61b588
@ -1,3 +1,6 @@
|
||||
2009-05-10
|
||||
* Added support for APC UPS daemon monitoring
|
||||
|
||||
2009-05-09
|
||||
* Allow the use of '#' for comments within text area (can be escaped with
|
||||
'\#'
|
||||
|
@ -213,6 +213,26 @@ dnl
|
||||
dnl Math
|
||||
dnl
|
||||
|
||||
|
||||
dnl
|
||||
dnl Apcupsd
|
||||
dnl
|
||||
|
||||
AC_ARG_ENABLE([apcupsd],
|
||||
AC_HELP_STRING([--disable-apcupsd],
|
||||
[disable if you do not want apcupsd support @<:@default=yes@:>@]),
|
||||
[want_apcupsd="$enableval"], [want_apcupsd=yes])
|
||||
|
||||
AM_CONDITIONAL(BUILD_APCUPSD, test x$want_apcupsd = xyes)
|
||||
if test x$want_apcupsd = xyes; then
|
||||
if test x"$uname" != xLinux; then
|
||||
AC_MSG_NOTICE([apcupsd not supported on $uname... disabling])
|
||||
want_apcupsd=no
|
||||
else
|
||||
AC_DEFINE(APCUPSD, 1, [Define if you want apcupsd support])
|
||||
fi
|
||||
fi
|
||||
|
||||
AC_ARG_ENABLE([math],
|
||||
AC_HELP_STRING([--disable-math], [disable if you do not want math support @<:@default=yes@:>@]),
|
||||
[want_math="$enableval"], [want_math=yes])
|
||||
@ -767,4 +787,5 @@ $PACKAGE $VERSION configured successfully:
|
||||
eve-online: $want_eve
|
||||
config-output: $want_config_output
|
||||
ALSA mixer: $want_alsa
|
||||
apcupsd: $want_apcupsd
|
||||
EOF
|
||||
|
@ -85,6 +85,134 @@
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd</option></command>
|
||||
<option>host</option>
|
||||
<option>port</option>
|
||||
</term>
|
||||
<listitem>
|
||||
Sets up the connection to apcupsd daemon. Prints nothing, defaults to localhost:3551
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_name</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Prints the UPS user-defined name.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_model</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Prints the model of the UPS.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_upsmode</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Prints the UPS mode (e.g. standalone).
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_cable</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Prints the UPS connection type.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_status</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Prints current status (on-line, on-battery).
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_linev</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Nominal input voltage.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_load</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Current load in percent.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_loadbar</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Bar showing current load.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_loadgraph</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
History graph of current load.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_charge</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Current battery capacity in percent.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_timeleft</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Time left to run on battery.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_temp</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Current internal temperature.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apcupsd_lastxfer</option></command>
|
||||
</term>
|
||||
<listitem>
|
||||
Reason for last transfer from line to battery.
|
||||
<para></para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
<varlistentry>
|
||||
<term>
|
||||
<command><option>apm_adapter</option></command>
|
||||
|
@ -111,6 +111,10 @@ if BUILD_NVIDIA
|
||||
nvidia = nvidia.c nvidia.h
|
||||
endif
|
||||
|
||||
if BUILD_APCUPSD
|
||||
apcupsd = apcupsd.c apcupsd.h
|
||||
endif
|
||||
|
||||
conky_SOURCES = \
|
||||
$(config_output) \
|
||||
$(config_cookie) \
|
||||
@ -124,6 +128,7 @@ conky_SOURCES = \
|
||||
$(freebsd) \
|
||||
fs.c \
|
||||
$(hddtemp) \
|
||||
$(apcupsd) \
|
||||
$(linux) \
|
||||
logging.h \
|
||||
$(nvidia) \
|
||||
@ -175,6 +180,8 @@ EXTRA_DIST = \
|
||||
fs.h \
|
||||
hddtemp.c \
|
||||
hddtemp.h \
|
||||
apcupsd.c \
|
||||
apcupsd.h \
|
||||
linux.c \
|
||||
linux.h \
|
||||
libmpdclient.c \
|
||||
|
@ -323,7 +323,7 @@ static double last_fs_update;
|
||||
unsigned long long need_mask;
|
||||
int no_buffers;
|
||||
|
||||
#define NEED(a) ((need_mask & (1 << a)) && ((info.mask & (1 << a)) == 0))
|
||||
#define NEED(a) ((need_mask & (1ULL << a)) && ((info.mask & (1ULL << a)) == 0))
|
||||
|
||||
void update_stuff(void)
|
||||
{
|
||||
@ -456,6 +456,11 @@ void update_stuff(void)
|
||||
if (NEED(INFO_DNS)) {
|
||||
update_dns_data();
|
||||
}
|
||||
#ifdef APCUPSD
|
||||
if (NEED(INFO_APCUPSD)) {
|
||||
update_apcupsd();
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
int round_to_int(float f)
|
||||
|
119
src/conky.c
119
src/conky.c
@ -214,6 +214,9 @@ static void print_version(void)
|
||||
#ifdef MIXER_IS_ALSA
|
||||
" * ALSA mixer support\n"
|
||||
#endif /* MIXER_IS_ALSA */
|
||||
#ifdef APCUPSD
|
||||
" * apcupsd\n"
|
||||
#endif /* APCUPSD */
|
||||
);
|
||||
|
||||
exit(0);
|
||||
@ -969,6 +972,23 @@ static void free_text_objects(struct text_object *root)
|
||||
free_text_objects(obj->sub);
|
||||
free(obj->sub);
|
||||
break;
|
||||
#ifdef APCUPSD
|
||||
case OBJ_apcupsd:
|
||||
case OBJ_apcupsd_name:
|
||||
case OBJ_apcupsd_model:
|
||||
case OBJ_apcupsd_upsmode:
|
||||
case OBJ_apcupsd_cable:
|
||||
case OBJ_apcupsd_status:
|
||||
case OBJ_apcupsd_linev:
|
||||
case OBJ_apcupsd_load:
|
||||
case OBJ_apcupsd_loadbar:
|
||||
case OBJ_apcupsd_loadgraph:
|
||||
case OBJ_apcupsd_charge:
|
||||
case OBJ_apcupsd_timeleft:
|
||||
case OBJ_apcupsd_temp:
|
||||
case OBJ_apcupsd_lastxfer:
|
||||
break;
|
||||
#endif /* APCUPSD */
|
||||
}
|
||||
free(obj);
|
||||
}
|
||||
@ -1022,12 +1042,12 @@ static struct text_object *construct_text_object(const char *s,
|
||||
obj->line = line;
|
||||
|
||||
#define OBJ(a, n) if (strcmp(s, #a) == 0) { \
|
||||
obj->type = OBJ_##a; need_mask |= (1 << n); {
|
||||
obj->type = OBJ_##a; need_mask |= (1ULL << n); {
|
||||
#define OBJ_IF(a, n) if (strcmp(s, #a) == 0) { \
|
||||
obj->type = OBJ_##a; need_mask |= (1 << n); \
|
||||
obj->type = OBJ_##a; need_mask |= (1ULL << n); \
|
||||
obj_be_ifblock_if(ifblock_opaque, obj); {
|
||||
#define OBJ_THREAD(a, n) if (strcmp(s, #a) == 0 && allow_threaded) { \
|
||||
obj->type = OBJ_##a; need_mask |= (1 << n); {
|
||||
obj->type = OBJ_##a; need_mask |= (1ULL << n); {
|
||||
#define END } } else
|
||||
|
||||
#ifdef X11
|
||||
@ -2578,6 +2598,38 @@ static struct text_object *construct_text_object(const char *s,
|
||||
" specified: '%s'\n", arg);
|
||||
}
|
||||
#endif /* NVIDIA */
|
||||
#ifdef APCUPSD
|
||||
init_apcupsd();
|
||||
END OBJ(apcupsd, INFO_APCUPSD)
|
||||
if (arg) {
|
||||
char host[64];
|
||||
int port;
|
||||
if (sscanf(arg, "%63s %d", host, &port) != 2) {
|
||||
CRIT_ERR("apcupsd needs arguments: <host> <port>");
|
||||
} else {
|
||||
info.apcupsd.port = htons(port);
|
||||
strncpy(info.apcupsd.host, host, sizeof(info.apcupsd.host));
|
||||
}
|
||||
} else {
|
||||
CRIT_ERR("apcupsd needs arguments: <host> <port>");
|
||||
}
|
||||
END OBJ(apcupsd_name, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_model, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_upsmode, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_cable, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_status, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_linev, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_load, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_loadbar, INFO_APCUPSD)
|
||||
scan_bar(arg, &obj->a, &obj->b);
|
||||
END OBJ(apcupsd_loadgraph, INFO_APCUPSD)
|
||||
char* buf = scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e, &obj->showaslog);
|
||||
if (buf) free(buf);
|
||||
END OBJ(apcupsd_charge, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_timeleft, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_temp, INFO_APCUPSD)
|
||||
END OBJ(apcupsd_lastxfer, INFO_APCUPSD)
|
||||
#endif /* APCUPSD */
|
||||
END {
|
||||
char buf[256];
|
||||
|
||||
@ -5019,7 +5071,66 @@ static void generate_text_internal(char *p, int p_max_size,
|
||||
snprintf(p, p_max_size, "%d", value);
|
||||
}
|
||||
#endif /* NVIDIA */
|
||||
|
||||
#ifdef APCUPSD
|
||||
OBJ(apcupsd) {
|
||||
/* This is just a meta-object to set host:port */
|
||||
}
|
||||
OBJ(apcupsd_name) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_NAME]);
|
||||
}
|
||||
OBJ(apcupsd_model) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_MODEL]);
|
||||
}
|
||||
OBJ(apcupsd_upsmode) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_UPSMODE]);
|
||||
}
|
||||
OBJ(apcupsd_cable) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_CABLE]);
|
||||
}
|
||||
OBJ(apcupsd_status) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_STATUS]);
|
||||
}
|
||||
OBJ(apcupsd_linev) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_LINEV]);
|
||||
}
|
||||
OBJ(apcupsd_load) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_LOAD]);
|
||||
}
|
||||
OBJ(apcupsd_loadbar) {
|
||||
double progress;
|
||||
progress = atof(cur->apcupsd.items[APCUPSD_LOAD]) / 100.0 * 255.0;
|
||||
new_bar(p, obj->a, obj->b, (int)progress);
|
||||
}
|
||||
OBJ(apcupsd_loadgraph) {
|
||||
double progress;
|
||||
progress = atof(cur->apcupsd.items[APCUPSD_LOAD]);
|
||||
new_graph(p, obj->a, obj->b, obj->c, obj->d,
|
||||
(int)progress, 100, 1, obj->showaslog);
|
||||
}
|
||||
OBJ(apcupsd_charge) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_CHARGE]);
|
||||
}
|
||||
OBJ(apcupsd_timeleft) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_TIMELEFT]);
|
||||
}
|
||||
OBJ(apcupsd_temp) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_TEMP]);
|
||||
}
|
||||
OBJ(apcupsd_lastxfer) {
|
||||
snprintf(p, p_max_size, "%s",
|
||||
cur->apcupsd.items[APCUPSD_LASTXFER]);
|
||||
}
|
||||
#endif /* APCUPSD */
|
||||
break;
|
||||
}
|
||||
#undef DO_JUMP
|
||||
|
13
src/conky.h
13
src/conky.h
@ -103,6 +103,10 @@ char *strndup(const char *s, size_t n);
|
||||
#include "smapi.h"
|
||||
#endif
|
||||
|
||||
#ifdef APCUPSD
|
||||
#include "apcupsd.h"
|
||||
#endif
|
||||
|
||||
/* sony support */
|
||||
#include "sony.h"
|
||||
|
||||
@ -190,7 +194,10 @@ enum {
|
||||
#endif
|
||||
INFO_DNS = 30,
|
||||
#ifdef MOC
|
||||
INFO_MOC = 31
|
||||
INFO_MOC = 31,
|
||||
#endif
|
||||
#ifdef APCUPSD
|
||||
INFO_APCUPSD = 32,
|
||||
#endif
|
||||
};
|
||||
|
||||
@ -262,6 +269,10 @@ struct information {
|
||||
struct x11_info x11;
|
||||
#endif
|
||||
|
||||
#ifdef APCUPSD
|
||||
APCUPSD_S apcupsd;
|
||||
#endif
|
||||
|
||||
short kflags; /* kernel settings, see enum KFLAG */
|
||||
};
|
||||
|
||||
|
@ -364,7 +364,23 @@ enum text_object_type {
|
||||
OBJ_combine,
|
||||
OBJ_entropy_avail,
|
||||
OBJ_entropy_poolsize,
|
||||
OBJ_entropy_bar
|
||||
OBJ_entropy_bar,
|
||||
#ifdef APCUPSD
|
||||
OBJ_apcupsd,
|
||||
OBJ_apcupsd_name,
|
||||
OBJ_apcupsd_model,
|
||||
OBJ_apcupsd_upsmode,
|
||||
OBJ_apcupsd_cable,
|
||||
OBJ_apcupsd_status,
|
||||
OBJ_apcupsd_linev,
|
||||
OBJ_apcupsd_load,
|
||||
OBJ_apcupsd_loadbar,
|
||||
OBJ_apcupsd_loadgraph,
|
||||
OBJ_apcupsd_charge,
|
||||
OBJ_apcupsd_timeleft,
|
||||
OBJ_apcupsd_temp,
|
||||
OBJ_apcupsd_lastxfer,
|
||||
#endif
|
||||
};
|
||||
|
||||
struct text_object {
|
||||
|
Loading…
x
Reference in New Issue
Block a user