diff options
author | Bmo <35866749+XWwalker@users.noreply.github.com> | 2023-03-18 06:20:43 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-18 09:20:43 +1100 |
commit | 883a65eee0ea9de6aa843614bc2a97bc1dd3ccd2 (patch) | |
tree | 7ba25f9d556e11dcfd8a9fdbc663220e36de3f87 /pppd/plugins/radius/config.c | |
parent | 1fe5196b10fc30b1dfb8b4b0ac5bf2b6fa49c297 (diff) | |
download | ppp-883a65eee0ea9de6aa843614bc2a97bc1dd3ccd2.tar.gz |
radius plugin: add fclose operation to fix file pointer not closed after use (#401)
Signed-off-by: Wei Xing <skyxwwalker@gmail.com>
Co-authored-by: Wei Xing <skyxwwalker@gmail.com>
Diffstat (limited to 'pppd/plugins/radius/config.c')
-rw-r--r-- | pppd/plugins/radius/config.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/pppd/plugins/radius/config.c b/pppd/plugins/radius/config.c index 47c172c..39744fc 100644 --- a/pppd/plugins/radius/config.c +++ b/pppd/plugins/radius/config.c @@ -212,6 +212,7 @@ int rc_read_config(char *filename) if ((pos = strcspn(p, "\t ")) == 0) { error("%s: line %d: bogus format: %s", filename, line, p); + fclose(configfd); return (-1); } @@ -224,6 +225,7 @@ int rc_read_config(char *filename) if (option->status != ST_UNDEF) { error("%s: line %d: duplicate option line: %s", filename, line, p); + fclose(configfd); return (-1); } @@ -234,18 +236,22 @@ int rc_read_config(char *filename) switch (option->type) { case OT_STR: if (set_option_str(filename, line, option, p) < 0) + fclose(configfd); return (-1); break; case OT_INT: if (set_option_int(filename, line, option, p) < 0) + fclose(configfd); return (-1); break; case OT_SRV: if (set_option_srv(filename, line, option, p) < 0) + fclose(configfd); return (-1); break; case OT_AUO: if (set_option_auo(filename, line, option, p) < 0) + fclose(configfd); return (-1); break; default: |