diff options
author | Mark Johnston <markj@FreeBSD.org> | 2020-09-01 15:15:09 +0000 |
---|---|---|
committer | Mark Johnston <markj@FreeBSD.org> | 2020-09-01 15:15:09 +0000 |
commit | fe76c1eca570a230b52f242deb1789a78fc38b19 (patch) | |
tree | ceb8a6d909b31aec6c5c9612b3d1008796ac8eae /pw | |
parent | d4b748de1e50121f9ffaad1dc9486df0144a1d0e (diff) | |
download | pw-darwin-fe76c1eca570a230b52f242deb1789a78fc38b19.tar.gz pw-darwin-fe76c1eca570a230b52f242deb1789a78fc38b19.tar.zst pw-darwin-fe76c1eca570a230b52f242deb1789a78fc38b19.zip |
pw: Handle errors from ftell() when removing records from /etc/opiekeys.
Reported by: Coverity
MFC after: 1 week
Sponsored by: NetApp, Inc.
Sponsored by: Klara, Inc.
Diffstat (limited to 'pw')
-rw-r--r-- | pw/pw_user.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/pw/pw_user.c b/pw/pw_user.c index cb95d45..2eec317 100644 --- a/pw/pw_user.c +++ b/pw/pw_user.c @@ -712,24 +712,24 @@ rmopie(char const * name) { char tmp[1014]; FILE *fp; - int fd; size_t len; - off_t atofs = 0; - + long atofs; + int fd; + if ((fd = openat(conf.rootfd, "etc/opiekeys", O_RDWR)) == -1) return; fp = fdopen(fd, "r+"); len = strlen(name); - while (fgets(tmp, sizeof(tmp), fp) != NULL) { + for (atofs = 0; fgets(tmp, sizeof(tmp), fp) != NULL && atofs >= 0; + atofs = ftell(fp)) { if (strncmp(name, tmp, len) == 0 && tmp[len]==' ') { /* Comment username out */ if (fseek(fp, atofs, SEEK_SET) == 0) fwrite("#", 1, 1, fp); break; } - atofs = ftell(fp); } /* * If we got an error of any sort, don't update! |