diff options
Diffstat (limited to 'daemon')
-rw-r--r-- | daemon/config.c | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/daemon/config.c b/daemon/config.c index a47b5f2..4245279 100644 --- a/daemon/config.c +++ b/daemon/config.c @@ -75,7 +75,10 @@ config_ctx; #define CONFIG_INTERVAL "interval" #define CONFIG_TIMEOUT "timeout" #define CONFIG_SOURCE "source" + #define CONFIG_SNMP "snmp" +#define CONFIG_SNMP2 "snmp2" +#define CONFIG_SNMP2C "snmp2c" #define FIELD_VALID "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-0123456789." @@ -205,6 +208,7 @@ parse_item(const char* field, char* uri, config_ctx *ctx) rb_host *rhost; int r; + enum snmp_version version; const char *msg; char* copy; char* scheme; @@ -221,10 +225,14 @@ parse_item(const char* field, char* uri, config_ctx *ctx) ASSERT(host && path); - /* TODO: SNMP version support */ - /* Currently we only support SNMP pollers */ - if(strcmp(scheme, CONFIG_SNMP) != 0) + if(strcmp(scheme, CONFIG_SNMP) == 0) + version = SNMP_V1; + else if(strcmp(scheme, CONFIG_SNMP2) == 0) + version = SNMP_V2c; + else if(strcmp(scheme, CONFIG_SNMP2C) == 0) + version = SNMP_V2c; + else errx(2, "%s: invalid poll scheme: %s", ctx->confname, scheme); /* TODO: THis code assumes all hosts have the same community @@ -239,8 +247,7 @@ parse_item(const char* field, char* uri, config_ctx *ctx) if(!hsh_set(g_state.host_by_name, host, -1, rhost)) errx(1, "out of memory"); - /* TODO: Version support */ - rhost->version = 1; + rhost->version = version; rhost->name = host; rhost->community = user ? user : "public"; rhost->is_resolved = 1; |