]> granicus.if.org Git - sudo/log
sudo
9 years agoMention time stamp file locking changes, fix some spelling.
Todd C. Miller [Wed, 9 Sep 2015 15:57:10 +0000 (09:57 -0600)]
Mention time stamp file locking changes, fix some spelling.

9 years agoUpdate with latest changes.
Todd C. Miller [Wed, 9 Sep 2015 12:23:29 +0000 (06:23 -0600)]
Update with latest changes.

9 years agoAvoid touching the time stamp directory for "sudo -k command"
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Avoid touching the time stamp directory for "sudo -k command"

9 years agoBring back the check for time stamp files that predate the boot
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Bring back the check for time stamp files that predate the boot
time.  Instead of truncating we now unlink the file since another
process may be sleeping on the lock.

9 years agoUse pread(2) and pwrite(2) where possible.
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Use pread(2) and pwrite(2) where possible.

9 years agosudo_term_* already restart themselve for all but SIGTTOU so we
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
sudo_term_* already restart themselve for all but SIGTTOU so we
don't need to use our own restart loops.

9 years agoSet errno to EINVAL if sudo_lock_* is called with a bad type.
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Set errno to EINVAL if sudo_lock_* is called with a bad type.

9 years agoAdjust new locking to work when tty_tickets is disabled. We need
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Adjust new locking to work when tty_tickets is disabled.  We need
to use per-tty/ppid locking to gain exclusive access to the tty
for the password prompt but use a separate (short term) lock
that is shared among all sudo processes for the user.

9 years agoAllow the time stamp lock to be interrupted by signals.
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Allow the time stamp lock to be interrupted by signals.

9 years agoImplement suspend/resume callbacks for the conversation function.
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Implement suspend/resume callbacks for the conversation function.
If suspended, close the timestamp file (dropping all locks).  On
resume, lock the record before reading the password.

For this to work properly we need to be able to run th callback
when tsetattr() suspends us, not just when the user does.  To
accomplish this the term_* functions now return EINTR if SIGTTOU
would be generated.  The caller now has to restart the term_*
function (and send itself SIGTTOU) instead of it being done
automatically.

9 years agoLock individual records in the timestamp file instead of the entire
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Lock individual records in the timestamp file instead of the entire
file.  This will make it possible for multiple sudo processes using
the same tty to serialize their timestamp lookups.

9 years agoAdd a struct sudo_conv_callback that contains on_suspend and on_resume
Todd C. Miller [Mon, 7 Sep 2015 12:06:08 +0000 (06:06 -0600)]
Add a struct sudo_conv_callback that contains on_suspend and on_resume
function pointer args plus a closure pointer and at it to the
conversation function.

9 years agoMake hook_version and hook_type unsigned.
Todd C. Miller [Wed, 2 Sep 2015 14:00:27 +0000 (08:00 -0600)]
Make hook_version and hook_type unsigned.

9 years agoWhen decoding base64, avoid using '=' in the decoded temporary array
Todd C. Miller [Tue, 1 Sep 2015 16:24:59 +0000 (10:24 -0600)]
When decoding base64, avoid using '=' in the decoded temporary array
as a sentinel as it can legitimately be present.  Instead, just use
the count of bytes stored in the temp array to determine which bytes
to fold into the destination.

9 years agoWhen parsing def_editor, break out of the loop when we find the
Todd C. Miller [Fri, 21 Aug 2015 17:25:02 +0000 (11:25 -0600)]
When parsing def_editor, break out of the loop when we find the
first valid editor.  Bug #714

9 years agoThe condition for adding a missing newline at the end of sudoers
Todd C. Miller [Tue, 18 Aug 2015 14:57:53 +0000 (08:57 -0600)]
The condition for adding a missing newline at the end of sudoers
was never reached.  Keep track of the last character and write a
newline character if when copying to the temp file.  Found by Radovan
Sroka.

9 years agoRemove extraneous while() from botched do {} while() loop
Todd C. Miller [Tue, 18 Aug 2015 14:34:10 +0000 (08:34 -0600)]
Remove extraneous while() from botched do {} while() loop
conversion to use sudo_strsplit.  Noticed by Radovan Sroka.

9 years agoIn sudo_pam_begin_session() and sudo_pam_end_session() return
Todd C. Miller [Tue, 11 Aug 2015 02:17:02 +0000 (20:17 -0600)]
In sudo_pam_begin_session() and sudo_pam_end_session() return
AUTH_FATAL on error, not AUTH_FAILURE.  In sudo_auth_begin_session()
treat anything other than AUTH_SUCCESS as a fatal error.

9 years agoLinux sets si_pid in struct siginfo to 0 when the process that sent
Todd C. Miller [Mon, 10 Aug 2015 21:13:37 +0000 (15:13 -0600)]
Linux sets si_pid in struct siginfo to 0 when the process that sent
the signal is in a different container since the PID namespaces in
different conatiners are separate.  Avoid looking up the process
group by id when si_pid is 0 since getpgid(0) returns the process
group of the current process.  Since sudo ignores signals sent
by processes in its own process group, this had the effect of
ignoring signals sent from other containers.  From Maarten de Vries

9 years agoSprinkle some debugging.
Todd C. Miller [Mon, 10 Aug 2015 16:56:47 +0000 (10:56 -0600)]
Sprinkle some debugging.

9 years agoDocument that sudo uses the real uid to map from uid to passwd file
Todd C. Miller [Sun, 9 Aug 2015 22:22:16 +0000 (16:22 -0600)]
Document that sudo uses the real uid to map from uid to passwd file
user name.

9 years agodisable_coredump can be set to no on modern OSes without
Todd C. Miller [Sun, 9 Aug 2015 22:12:00 +0000 (16:12 -0600)]
disable_coredump can be set to no on modern OSes without
security consequences.

9 years agoEmphasis on the never.
Todd C. Miller [Fri, 7 Aug 2015 23:05:50 +0000 (17:05 -0600)]
Emphasis on the never.

9 years agoExplicitly tell people not to grant sudoedit to directories the
Todd C. Miller [Fri, 7 Aug 2015 23:01:15 +0000 (17:01 -0600)]
Explicitly tell people not to grant sudoedit to directories the
user can write to.  While sudoedit will no longer open symbolic
links, hard links are still an issue.

9 years agoAdd warning about writable directories and sudo/sudoedit.
Todd C. Miller [Fri, 7 Aug 2015 23:00:42 +0000 (17:00 -0600)]
Add warning about writable directories and sudo/sudoedit.

9 years agoEmphasize that wildcards are not regexps. Bug #692
Todd C. Miller [Fri, 7 Aug 2015 18:37:15 +0000 (12:37 -0600)]
Emphasize that wildcards are not regexps.  Bug #692

9 years agoEmphasize that wildcards in command line arguments are dangerous.
Todd C. Miller [Fri, 7 Aug 2015 18:21:37 +0000 (12:21 -0600)]
Emphasize that wildcards in command line arguments are dangerous.
Document the failings of the passwd example on GNU systems.
Bug #691

9 years agoEscape the colons in [[:alpha:]] as required by sudoers.
Todd C. Miller [Fri, 7 Aug 2015 18:00:12 +0000 (12:00 -0600)]
Escape the colons in [[:alpha:]] as required by sudoers.

9 years agoChange warning when user tries to sudoedit a symbolic link.
Todd C. Miller [Fri, 7 Aug 2015 13:09:01 +0000 (07:09 -0600)]
Change warning when user tries to sudoedit a symbolic link.

9 years agoregen
Todd C. Miller [Thu, 6 Aug 2015 19:21:37 +0000 (13:21 -0600)]
regen

9 years agoregen
Todd C. Miller [Thu, 6 Aug 2015 19:20:36 +0000 (13:20 -0600)]
regen

9 years agoDo not follow symbolic links in sudoedit by default. This behavior
Todd C. Miller [Thu, 6 Aug 2015 19:20:01 +0000 (13:20 -0600)]
Do not follow symbolic links in sudoedit by default.  This behavior
can be controlled by the sudoedit_follow Defaults flag as well as
the FOLLOW/NOFOLLOW tags.

9 years agoSudo 1.8.15
Todd C. Miller [Thu, 6 Aug 2015 19:15:00 +0000 (13:15 -0600)]
Sudo 1.8.15

9 years agoadd .json regress files to MANIFEST
Todd C. Miller [Thu, 6 Aug 2015 19:39:59 +0000 (13:39 -0600)]
add .json regress files to MANIFEST

9 years agoCheck JSON output of sudoers test files too.
Todd C. Miller [Thu, 6 Aug 2015 16:57:42 +0000 (10:57 -0600)]
Check JSON output of sudoers test files too.

9 years agoMove comment to match moved code.
Todd C. Miller [Tue, 4 Aug 2015 22:15:11 +0000 (16:15 -0600)]
Move comment to match moved code.

9 years agomaxseq is an int not a string
Todd C. Miller [Tue, 4 Aug 2015 17:28:43 +0000 (11:28 -0600)]
maxseq is an int not a string

9 years agoInclude sys/types.h for id_t. Bug #711
Todd C. Miller [Mon, 3 Aug 2015 01:59:32 +0000 (19:59 -0600)]
Include sys/types.h for id_t.  Bug #711

9 years agoAvoid a potential out of bounds read found by enh while fuzzing
Todd C. Miller [Fri, 31 Jul 2015 22:10:03 +0000 (16:10 -0600)]
Avoid a potential out of bounds read found by enh while fuzzing
with address sanitizer enabled.

9 years agoSet sssd lib location to /usr/lib64 on 64-bit RHEL/Centos.
Todd C. Miller [Mon, 27 Jul 2015 13:07:38 +0000 (07:07 -0600)]
Set sssd lib location to /usr/lib64 on 64-bit RHEL/Centos.
Bug #710

9 years agoAdd Jakub Wilk
Todd C. Miller [Wed, 8 Jul 2015 21:14:55 +0000 (15:14 -0600)]
Add Jakub Wilk

9 years agoThe init.d files are generated from a .in file so we need to install
Todd C. Miller [Fri, 24 Jul 2015 19:38:03 +0000 (13:38 -0600)]
The init.d files are generated from a .in file so we need to install
from top_builddir not top_srcdir.  From Ross Burton.  Bug #708

9 years agoReplace two "return 0" with debug_return_bool(false).
Todd C. Miller [Thu, 23 Jul 2015 01:11:32 +0000 (19:11 -0600)]
Replace two "return 0" with debug_return_bool(false).

9 years agofix typo in previous commit
Todd C. Miller [Wed, 22 Jul 2015 12:21:21 +0000 (06:21 -0600)]
fix typo in previous commit

9 years agoSudo 1.8.14p3
Todd C. Miller [Wed, 22 Jul 2015 12:09:14 +0000 (06:09 -0600)]
Sudo 1.8.14p3

9 years agoFix errno value from get_process_ttyname() when no tty is present.
Todd C. Miller [Tue, 21 Jul 2015 21:20:49 +0000 (15:20 -0600)]
Fix errno value from get_process_ttyname() when no tty is present.

9 years agoOn AIX, only convert the tty device number from dev64_t to dev32_t
Todd C. Miller [Tue, 21 Jul 2015 21:02:56 +0000 (15:02 -0600)]
On AIX, only convert the tty device number from dev64_t to dev32_t
if dev_t is 32-bits.

9 years agoSudo 1.8.14p2
Todd C. Miller [Tue, 21 Jul 2015 02:27:40 +0000 (20:27 -0600)]
Sudo 1.8.14p2

9 years agoFix creation of the timestamp file; bug #704
Todd C. Miller [Tue, 21 Jul 2015 02:16:14 +0000 (20:16 -0600)]
Fix creation of the timestamp file; bug #704

9 years agoAvoid needless memory allocation when resolving the tty name.
Todd C. Miller [Mon, 20 Jul 2015 02:19:22 +0000 (20:19 -0600)]
Avoid needless memory allocation when resolving the tty name.

9 years agoSudo 1.8.14p1
Todd C. Miller [Fri, 17 Jul 2015 21:28:26 +0000 (15:28 -0600)]
Sudo 1.8.14p1

9 years agoFix typo in sudo_sss_attrcpy() that caused a memory allocation error.
Todd C. Miller [Fri, 17 Jul 2015 19:58:26 +0000 (13:58 -0600)]
Fix typo in sudo_sss_attrcpy() that caused a memory allocation error.

9 years agorebuild
Todd C. Miller [Wed, 15 Jul 2015 18:36:02 +0000 (12:36 -0600)]
rebuild

9 years agoAdd some debugging printfs when malloc fails and we don't have an
Todd C. Miller [Tue, 14 Jul 2015 21:28:01 +0000 (15:28 -0600)]
Add some debugging printfs when malloc fails and we don't have an
explicit call to sudo_warnx().

9 years agoAdd missing warnings for memory allocation failure.
Todd C. Miller [Tue, 14 Jul 2015 20:50:36 +0000 (14:50 -0600)]
Add missing warnings for memory allocation failure.
Add function name to memory allocation warnings.

9 years agoReturn -1 if realloc() fails.
Todd C. Miller [Tue, 14 Jul 2015 20:48:04 +0000 (14:48 -0600)]
Return -1 if realloc() fails.

9 years agoAdd line number to debug log for memory allocation errors.
Todd C. Miller [Tue, 14 Jul 2015 20:47:12 +0000 (14:47 -0600)]
Add line number to debug log for memory allocation errors.

9 years agoAdd warning if calloc() fails.
Todd C. Miller [Tue, 14 Jul 2015 20:00:18 +0000 (14:00 -0600)]
Add warning if calloc() fails.
Add debugging for other unexpected errors.

9 years agoAdd missing check for calloc(3) return value.
Todd C. Miller [Tue, 14 Jul 2015 19:56:29 +0000 (13:56 -0600)]
Add missing check for calloc(3) return value.

9 years agoDocument that the values printed by "sudo -V" are affected by
Todd C. Miller [Mon, 13 Jul 2015 18:58:25 +0000 (12:58 -0600)]
Document that the values printed by "sudo -V" are affected by
Defaults settings in sudoers.

9 years agoAvoid calling dlerror() multiple times since it clear the error
Todd C. Miller [Fri, 10 Jul 2015 16:31:21 +0000 (10:31 -0600)]
Avoid calling dlerror() multiple times since it clear the error
status after printing the error.
Problem caused by sudo_warn/sudo_fatal being macros...

9 years agoAttempt to clarify the conditions under which MAIL and HOME are
Todd C. Miller [Fri, 10 Jul 2015 16:02:38 +0000 (10:02 -0600)]
Attempt to clarify the conditions under which MAIL and HOME are
set to the target user.

9 years agoBetter checks for the libaudit package for Debian and error out
Todd C. Miller [Thu, 9 Jul 2015 19:01:43 +0000 (13:01 -0600)]
Better checks for the libaudit package for Debian and error out
if we can't figure it out.

9 years agoFix linux_audit setting on non-multiarch Debian.
Todd C. Miller [Thu, 9 Jul 2015 17:36:51 +0000 (11:36 -0600)]
Fix linux_audit setting on non-multiarch Debian.

9 years agoFix typo that broke the linux_audit dependency on Debian.
Todd C. Miller [Thu, 9 Jul 2015 17:06:03 +0000 (11:06 -0600)]
Fix typo that broke the linux_audit dependency on Debian.

9 years agoMention /proc/stat btime fix.
Todd C. Miller [Thu, 9 Jul 2015 16:45:33 +0000 (10:45 -0600)]
Mention /proc/stat btime fix.

9 years agoSolaris 2.6 has the prototypes for inet_pton() and inet_ntop() in
Todd C. Miller [Thu, 9 Jul 2015 16:11:25 +0000 (10:11 -0600)]
Solaris 2.6 has the prototypes for inet_pton() and inet_ntop() in
resolv.h.

9 years agoSprinkle debugging for boottime.
Todd C. Miller [Thu, 9 Jul 2015 16:10:34 +0000 (10:10 -0600)]
Sprinkle debugging for boottime.

9 years agoThe old Solaris /bin/sh doesn't support POSIX $( .. ) syntax,
Todd C. Miller [Thu, 9 Jul 2015 15:34:22 +0000 (09:34 -0600)]
The old Solaris /bin/sh doesn't support POSIX $( .. ) syntax,
use backquotes instead.

9 years agoOnly use --with-sssd-lib on Debian/Ubuntu w/ multipackage.
Todd C. Miller [Thu, 9 Jul 2015 00:13:39 +0000 (18:13 -0600)]
Only use --with-sssd-lib on Debian/Ubuntu w/ multipackage.
Use dpkg-query to determine the name of the audit package
for proper dependencies.

9 years agoUpdate Debian/Ubuntu packages to be more like the vendor ones. One
Todd C. Miller [Wed, 8 Jul 2015 22:15:53 +0000 (16:15 -0600)]
Update Debian/Ubuntu packages to be more like the vendor ones.  One
notable exception is that sudo.ws packages use /var/run, not /var/lib
for timestamp files.

9 years agoStrip newline from /proc/stat btime line to avoid a strtonum() failure.
Todd C. Miller [Wed, 8 Jul 2015 21:13:14 +0000 (15:13 -0600)]
Strip newline from /proc/stat btime line to avoid a strtonum() failure.
From Jakub Wilk.

9 years agoIn io_callback() service writes before reads. That way, if both
Todd C. Miller [Wed, 8 Jul 2015 16:12:15 +0000 (10:12 -0600)]
In io_callback() service writes before reads.  That way, if both
SUDO_EV_READ and SUDO_EV_WRITE are set and read() returns 0 (EOF)
we don't close the fd before the write() is performed.

If the write() returns EPIPE, ENXIO, EIO or EBADF, clear SUDO_EV_READ
before we close the fd to avoid calling read() on a closed fd.

9 years agoCheck sudo_conf_read() return value and exit on fatal error (a
Todd C. Miller [Tue, 7 Jul 2015 19:17:50 +0000 (13:17 -0600)]
Check sudo_conf_read() return value and exit on fatal error (a
warning was already printed by sudo_conf_read()).

9 years agoMention double-quoted sudoOption value support.
Todd C. Miller [Tue, 7 Jul 2015 17:28:49 +0000 (11:28 -0600)]
Mention double-quoted sudoOption value support.

9 years agoAdd support for parsing quoted strings in a sudoOption just like
Todd C. Miller [Tue, 7 Jul 2015 16:58:05 +0000 (10:58 -0600)]
Add support for parsing quoted strings in a sudoOption just like
sudoers Defaults settings.

9 years agoSync with translationproject.org
Todd C. Miller [Tue, 7 Jul 2015 16:34:37 +0000 (10:34 -0600)]
Sync with translationproject.org

9 years agoUpdate year.
Todd C. Miller [Mon, 6 Jul 2015 22:45:33 +0000 (16:45 -0600)]
Update year.

9 years agoSync with translationproject.org
Todd C. Miller [Mon, 6 Jul 2015 22:44:23 +0000 (16:44 -0600)]
Sync with translationproject.org

9 years agoFix utmp setup broken by commit be0ca60facf8
Todd C. Miller [Mon, 6 Jul 2015 19:56:39 +0000 (13:56 -0600)]
Fix utmp setup broken by commit be0ca60facf8

9 years agoSync with translationproject.org
Todd C. Miller [Fri, 3 Jul 2015 13:28:00 +0000 (07:28 -0600)]
Sync with translationproject.org

9 years agoregen
Todd C. Miller [Fri, 3 Jul 2015 13:12:30 +0000 (07:12 -0600)]
regen

9 years agoFix typo in error message.
Todd C. Miller [Fri, 3 Jul 2015 13:06:29 +0000 (07:06 -0600)]
Fix typo in error message.

9 years agoBug #702 is the AIX timespec issue.
Todd C. Miller [Thu, 2 Jul 2015 20:06:16 +0000 (14:06 -0600)]
Bug #702 is the AIX timespec issue.

9 years agoWe require POSIX so no need to conditionally include dirent.h.
Todd C. Miller [Thu, 2 Jul 2015 15:24:48 +0000 (09:24 -0600)]
We require POSIX so no need to conditionally include dirent.h.
Add a check for d_namlen and use the result in the NAMLEN macro.

9 years agoThere's no need to conditionalize the #include <unistd.h>, we require
Todd C. Miller [Thu, 2 Jul 2015 15:08:28 +0000 (09:08 -0600)]
There's no need to conditionalize the #include <unistd.h>, we require
a POSIX system.

9 years agoRemove some compatibilty defines that should no longer be needed.
Todd C. Miller [Thu, 2 Jul 2015 15:07:15 +0000 (09:07 -0600)]
Remove some compatibilty defines that should no longer be needed.

9 years agoFinal changes in 1.8.14
Todd C. Miller [Tue, 30 Jun 2015 20:29:39 +0000 (14:29 -0600)]
Final changes in 1.8.14

9 years agoNeed to include stddef.h to get rsize_t on Mac OS X for sudo_memset_s()
Todd C. Miller [Tue, 30 Jun 2015 20:11:53 +0000 (14:11 -0600)]
Need to include stddef.h to get rsize_t on Mac OS X for sudo_memset_s()
prototype.

9 years agoAdd missing exit value.
Todd C. Miller [Tue, 30 Jun 2015 18:19:24 +0000 (12:19 -0600)]
Add missing exit value.

9 years agoAdd missing fcntl.h include.
Todd C. Miller [Tue, 30 Jun 2015 18:19:17 +0000 (12:19 -0600)]
Add missing fcntl.h include.

9 years agoDo check for inet_pton before inet_ntop since we may need to record
Todd C. Miller [Tue, 30 Jun 2015 16:57:42 +0000 (10:57 -0600)]
Do check for inet_pton before inet_ntop since we may need to record
dependent libraries for inet_pton when linking our getaddrinfo
replacement.

9 years agoFix build on compilers w/o __func__ or __FUNCTION__
Todd C. Miller [Tue, 30 Jun 2015 16:41:14 +0000 (10:41 -0600)]
Fix build on compilers w/o __func__ or __FUNCTION__

9 years agoRemove sudo_evasprintf_v1, missed during alloc.c removal.
Todd C. Miller [Tue, 30 Jun 2015 16:37:06 +0000 (10:37 -0600)]
Remove sudo_evasprintf_v1, missed during alloc.c removal.

9 years agoAdd missing fcntl.h include.
Todd C. Miller [Tue, 30 Jun 2015 16:32:42 +0000 (10:32 -0600)]
Add missing fcntl.h include.

9 years agoAdd check for inline support.
Todd C. Miller [Tue, 30 Jun 2015 16:16:56 +0000 (10:16 -0600)]
Add check for inline support.

9 years agoAdd reallocarray.c license.
Todd C. Miller [Mon, 29 Jun 2015 14:16:43 +0000 (08:16 -0600)]
Add reallocarray.c license.

9 years agoFix entry for Joel Pelaez Jorge.
Todd C. Miller [Sat, 27 Jun 2015 20:01:09 +0000 (14:01 -0600)]
Fix entry for Joel Pelaez Jorge.

9 years agoAdd an error flag to the lbuf struct to simplify error checking.
Todd C. Miller [Fri, 26 Jun 2015 21:58:04 +0000 (15:58 -0600)]
Add an error flag to the lbuf struct to simplify error checking.
Callers of the lbuf functions now check the error flag to tell if
a memory allocation error ocurred.

9 years agodisplay_privs() and display_cmnd() may need to return -1 on error.
Todd C. Miller [Fri, 26 Jun 2015 16:33:28 +0000 (10:33 -0600)]
display_privs() and display_cmnd() may need to return -1 on error.