]> granicus.if.org Git - sudo/log
sudo
7 years agoQuiet a clang analyzer false positive.
Todd C. Miller [Mon, 29 Jan 2018 18:50:56 +0000 (11:50 -0700)]
Quiet a clang analyzer false positive.

7 years agoQuote special characters when creating the cn as per RFC2253
Todd C. Miller [Mon, 29 Jan 2018 18:00:43 +0000 (11:00 -0700)]
Quote special characters when creating the cn as per RFC2253

7 years agoSudo 1.8.23
Todd C. Miller [Mon, 29 Jan 2018 16:40:12 +0000 (09:40 -0700)]
Sudo 1.8.23

7 years agoRemove the C-style comment charactes from the getopt_long.c and
Todd C. Miller [Mon, 29 Jan 2018 16:31:54 +0000 (09:31 -0700)]
Remove the C-style comment charactes from the getopt_long.c and
inet_pton.c license text as it was inconsistent with the rest of
the file and messed up the html formatting.

7 years agoRemove sudoers2ldif, it has been replaced by cvtsudoers.
Todd C. Miller [Mon, 29 Jan 2018 16:18:48 +0000 (09:18 -0700)]
Remove sudoers2ldif, it has been replaced by cvtsudoers.

7 years agoAdd -b option to specify the base dn.
Todd C. Miller [Mon, 29 Jan 2018 02:58:10 +0000 (19:58 -0700)]
Add -b option to specify the base dn.

7 years agoDocument limitations of LDIF conversion.
Todd C. Miller [Mon, 29 Jan 2018 02:38:00 +0000 (19:38 -0700)]
Document limitations of LDIF conversion.

7 years agoSwitch the default output format to LDIF
Todd C. Miller [Mon, 29 Jan 2018 02:36:16 +0000 (19:36 -0700)]
Switch the default output format to LDIF

7 years agoExecute cvtsudoers if the user runs "visudo -x" but also emit a
Todd C. Miller [Sun, 28 Jan 2018 23:34:16 +0000 (16:34 -0700)]
Execute cvtsudoers if the user runs "visudo -x" but also emit a
warning.

7 years agoRevert 04ec05108b2b, change the default input source back to stdin.
Todd C. Miller [Sun, 28 Jan 2018 23:11:02 +0000 (16:11 -0700)]
Revert 04ec05108b2b, change the default input source back to stdin.

7 years agoAdd LDIF conversion to sudoers tests
Todd C. Miller [Sun, 28 Jan 2018 17:07:15 +0000 (10:07 -0700)]
Add LDIF conversion to sudoers tests

7 years agoAdd notbefore and notafter support to the backends.
Todd C. Miller [Sun, 28 Jan 2018 14:09:22 +0000 (07:09 -0700)]
Add notbefore and notafter support to the backends.

7 years agocvtsudoers instead of sudoers2ldif
Todd C. Miller [Sun, 28 Jan 2018 03:12:34 +0000 (20:12 -0700)]
cvtsudoers instead of sudoers2ldif

7 years agoAdd ldif backend to cvtsudoers, to replace sudoers2ldif
Todd C. Miller [Sun, 28 Jan 2018 03:08:02 +0000 (20:08 -0700)]
Add ldif backend to cvtsudoers, to replace sudoers2ldif

7 years agofix make check
Todd C. Miller [Sun, 28 Jan 2018 02:52:20 +0000 (19:52 -0700)]
fix make check

7 years agoParse sudoers in the front end, not the back end.
Todd C. Miller [Sat, 27 Jan 2018 00:29:56 +0000 (17:29 -0700)]
Parse sudoers in the front end, not the back end.

7 years agoinstall the cvtsudoers manual
Todd C. Miller [Fri, 26 Jan 2018 20:19:03 +0000 (13:19 -0700)]
install the cvtsudoers manual

7 years agoUse the built-in sudoers file location as the default sudoers file
Todd C. Miller [Fri, 26 Jan 2018 20:15:10 +0000 (13:15 -0700)]
Use the built-in sudoers file location as the default sudoers file
for cvtsudoers and move parse_sudoers_options() to stubs.c since
it is shared between visudo.c and cvtsudoers.c.

7 years agoMove common stub functions required by the parser out of visudo.c
Todd C. Miller [Fri, 26 Jan 2018 19:51:24 +0000 (12:51 -0700)]
Move common stub functions required by the parser out of visudo.c
and cvtsudoers.c and into stubs.c.

7 years agoRename export_sudoers() to convert_sudoers_json() and move the
Todd C. Miller [Fri, 26 Jan 2018 19:28:49 +0000 (12:28 -0700)]
Rename export_sudoers() to convert_sudoers_json() and move the
check for the same input and output file to the front-end.

7 years agoadd cvtsudoers
Todd C. Miller [Fri, 26 Jan 2018 19:26:59 +0000 (12:26 -0700)]
add cvtsudoers

7 years agoMove sudoers JSON conversion to cvtsudoers which will eventually
Todd C. Miller [Fri, 26 Jan 2018 18:20:37 +0000 (11:20 -0700)]
Move sudoers JSON conversion to cvtsudoers which will eventually
output to other formats too.

7 years agoConvert from time in minutes to timespec directly instead of
Todd C. Miller [Fri, 26 Jan 2018 17:17:47 +0000 (10:17 -0700)]
Convert from time in minutes to timespec directly instead of
converting to double via strtod().  This makes it easier to catch
overflow.

7 years agodocument that kernel tty timestamps don't support negative timeouts
Todd C. Miller [Wed, 24 Jan 2018 12:27:54 +0000 (05:27 -0700)]
document that kernel tty timestamps don't support negative timeouts

7 years agoFall back to ppid time stamps if timestamp_type == kernel and no
Todd C. Miller [Tue, 23 Jan 2018 18:18:18 +0000 (11:18 -0700)]
Fall back to ppid time stamps if timestamp_type == kernel and no
tty is present.  This is consistent with timestamp_type == tty.

7 years agoDo not call the TIOCSETVERAUTH ioctl with a negative number of seconds.
Todd C. Miller [Tue, 23 Jan 2018 18:05:41 +0000 (11:05 -0700)]
Do not call the TIOCSETVERAUTH ioctl with a negative number of seconds.
Also cap the max number of seconds at 3600 to avoid getting EINVAL
from TIOCSETVERAUTH.

7 years agoBetter conversion from double to nanoseconds.
Todd C. Miller [Tue, 23 Jan 2018 00:27:25 +0000 (17:27 -0700)]
Better conversion from double to nanoseconds.

7 years agoStore passwd_timeout and timestamp_timeout as a struct timespec
Todd C. Miller [Mon, 22 Jan 2018 19:18:48 +0000 (12:18 -0700)]
Store passwd_timeout and timestamp_timeout as a struct timespec
instead of as a float.  Remove timeout argument to auth_getpass()
as it was never used.

7 years agoDon't rely on perl being installed in /usr/local/bin
Todd C. Miller [Sun, 21 Jan 2018 23:08:22 +0000 (16:08 -0700)]
Don't rely on perl being installed in /usr/local/bin

7 years agoRemove use of AC_HEADER_TIME, only obsolete platforms actually
Todd C. Miller [Wed, 17 Jan 2018 16:52:15 +0000 (09:52 -0700)]
Remove use of AC_HEADER_TIME, only obsolete platforms actually
need this.  Also stop removing sys/time.h unless the source file
uses struct timeval.

7 years agoRemove duplicate options %type
Todd C. Miller [Wed, 17 Jan 2018 16:52:09 +0000 (09:52 -0700)]
Remove duplicate options %type

7 years agoAdd an approval function to the sudo auth API which is run after
Todd C. Miller [Tue, 16 Jan 2018 17:27:58 +0000 (10:27 -0700)]
Add an approval function to the sudo auth API which is run after
the user's password has been verified.  The approval function is
run even if no password is required.  This is currently only used
for PAM (use pam_acct_mgmt) and BSD auth (auth_approval).

7 years agotreat uid as unsigned in error message
Todd C. Miller [Mon, 15 Jan 2018 17:29:38 +0000 (10:29 -0700)]
treat uid as unsigned in error message

7 years agoAdd missing plugins/sudoers/po/fur.mo file to repo.
Todd C. Miller [Mon, 15 Jan 2018 17:24:13 +0000 (10:24 -0700)]
Add missing plugins/sudoers/po/fur.mo file to repo.

7 years agoMention new sudoers_timestamp manual.
Todd C. Miller [Mon, 15 Jan 2018 17:12:40 +0000 (10:12 -0700)]
Mention new sudoers_timestamp manual.

7 years agoignore tsdump
Todd C. Miller [Fri, 12 Jan 2018 18:43:02 +0000 (11:43 -0700)]
ignore tsdump

7 years agoConvert from mono time to real time before displaying time stamps.
Todd C. Miller [Fri, 12 Jan 2018 18:03:22 +0000 (11:03 -0700)]
Convert from mono time to real time before displaying time stamps.

7 years agoUse PATH_MAX, not MAXPATHLEN.
Todd C. Miller [Thu, 11 Jan 2018 21:55:11 +0000 (14:55 -0700)]
Use PATH_MAX, not MAXPATHLEN.

7 years agoAdd tsdump, a simple utility to dump a timestamp file. To build,
Todd C. Miller [Thu, 11 Jan 2018 17:49:20 +0000 (10:49 -0700)]
Add tsdump, a simple utility to dump a timestamp file.  To build,
run "make tsdump" in the plugins/sudoers directory (it is not built
by default).  In order to map the tty device number to a name,
sudo_ttyname_dev() has been moved into libsudo_util.

7 years agosync with translationproject.org
Todd C. Miller [Fri, 5 Jan 2018 04:35:47 +0000 (21:35 -0700)]
sync with translationproject.org

7 years agoWelcome to 2018
Todd C. Miller [Fri, 5 Jan 2018 04:35:17 +0000 (21:35 -0700)]
Welcome to 2018

7 years agosync with translationproject.org
Todd C. Miller [Thu, 28 Dec 2017 15:09:53 +0000 (08:09 -0700)]
sync with translationproject.org

7 years agoSilence a clang analyzer false positive.
Todd C. Miller [Fri, 22 Dec 2017 20:27:08 +0000 (13:27 -0700)]
Silence a clang analyzer false positive.

7 years agoRemove extra $(srcdir)/sudoreplay.man.in target added by mistake.
Todd C. Miller [Fri, 22 Dec 2017 19:55:41 +0000 (12:55 -0700)]
Remove extra $(srcdir)/sudoreplay.man.in target added by mistake.

7 years agosync with translationproject.org
Todd C. Miller [Fri, 22 Dec 2017 19:47:07 +0000 (12:47 -0700)]
sync with translationproject.org

7 years agoUse a tty lock even for kernel time stamps so we can avoid simultaneous
Todd C. Miller [Fri, 22 Dec 2017 18:10:22 +0000 (11:10 -0700)]
Use a tty lock even for kernel time stamps so we can avoid simultaneous
password prompts.

7 years agovisudo changes
Todd C. Miller [Fri, 22 Dec 2017 17:39:57 +0000 (10:39 -0700)]
visudo changes

7 years agoAlso honor SUDO_EDITOR in visudo. Previously is was only used
Todd C. Miller [Fri, 22 Dec 2017 17:22:33 +0000 (10:22 -0700)]
Also honor SUDO_EDITOR in visudo.  Previously is was only used
by sudoedit.

7 years agoStop looking for an editor as soon as we find one.
Todd C. Miller [Thu, 21 Dec 2017 23:31:42 +0000 (16:31 -0700)]
Stop looking for an editor as soon as we find one.
A similar fix was made to visudo some time ago.

7 years agoThe session ID was added in 1.8.6p7 to prevent a user in another
Todd C. Miller [Thu, 21 Dec 2017 21:37:13 +0000 (14:37 -0700)]
The session ID was added in 1.8.6p7 to prevent a user in another
session from re-using the time stamp file.
Other minor cleanups.

7 years ago"time stamp" not "timestamp"
Todd C. Miller [Thu, 21 Dec 2017 21:21:48 +0000 (14:21 -0700)]
"time stamp" not "timestamp"

7 years agoAdd "kernel" as a possible value of timestamp_type.
Todd C. Miller [Wed, 20 Dec 2017 23:19:54 +0000 (16:19 -0700)]
Add "kernel" as a possible value of timestamp_type.
Currently only supported on OpenBSD.

7 years agoDocument the sudoers time stamp file format.
Todd C. Miller [Wed, 20 Dec 2017 20:01:06 +0000 (13:01 -0700)]
Document the sudoers time stamp file format.

7 years agoVerify start time of the current process, allowing for some clock
Todd C. Miller [Tue, 19 Dec 2017 17:10:54 +0000 (10:10 -0700)]
Verify start time of the current process, allowing for some clock
drift.  For Linux, process start time is relative to boot time, not
wallclock time.

7 years agosync
Todd C. Miller [Mon, 18 Dec 2017 18:34:59 +0000 (11:34 -0700)]
sync

7 years agoregen
Todd C. Miller [Mon, 18 Dec 2017 17:52:45 +0000 (10:52 -0700)]
regen

7 years agoTrivial test for process start time. We don't try to check the
Todd C. Miller [Mon, 18 Dec 2017 17:35:37 +0000 (10:35 -0700)]
Trivial test for process start time.  We don't try to check the
resulting timespec as it differs by platform.  On most it is wallclock
time, on others it is relative to boot time (Linux).

7 years agoregen
Todd C. Miller [Mon, 18 Dec 2017 16:39:06 +0000 (09:39 -0700)]
regen

7 years agoSupport start time on macOS and 4.4BSD
Todd C. Miller [Sun, 17 Dec 2017 14:40:21 +0000 (07:40 -0700)]
Support start time on macOS and 4.4BSD

7 years agoInclude sys/types.h for mode_t used in sudoers.h.
Todd C. Miller [Sun, 17 Dec 2017 03:55:01 +0000 (20:55 -0700)]
Include sys/types.h for mode_t used in sudoers.h.

7 years agoFix compilation error on FreeBSD
Todd C. Miller [Sun, 17 Dec 2017 03:46:58 +0000 (20:46 -0700)]
Fix compilation error on FreeBSD

7 years agoFix debug_decl(), it should be SUDOERS_DEBUG_UTIL
Todd C. Miller [Sat, 16 Dec 2017 21:50:14 +0000 (14:50 -0700)]
Fix debug_decl(), it should be SUDOERS_DEBUG_UTIL
Add debugging for the successful case
For Linux, don't NUL out *ep before parsing with strtoull().
* * *
Add missing debug info for the System V /proc version.

7 years agoIn the timestamp record, include the start time of the terminal
Todd C. Miller [Sat, 16 Dec 2017 12:53:05 +0000 (05:53 -0700)]
In the timestamp record, include the start time of the terminal
session leader for tty-based timestamps or the start time of the
parent process for ppid-based timestamps.  Idea from Duncan Overbruck.

7 years agoIf the lock record doesn't match the expected record size we need
Todd C. Miller [Sat, 16 Dec 2017 04:08:38 +0000 (21:08 -0700)]
If the lock record doesn't match the expected record size we need
to seek to the end of the record as we otherwise may have gone too
far (or not far enough).  Fixes interop problems when the time stamp
record changes size.

7 years agoNo need for a loop around the recv() now that we don't have to worry
Todd C. Miller [Wed, 13 Dec 2017 04:44:23 +0000 (21:44 -0700)]
No need for a loop around the recv() now that we don't have to worry
about EINTR.  CID 180697

7 years agoTry to be clearer about sudo's exit value when the -l option is used.
Todd C. Miller [Tue, 12 Dec 2017 22:42:21 +0000 (15:42 -0700)]
Try to be clearer about sudo's exit value when the -l option is used.

7 years agosync
Todd C. Miller [Tue, 12 Dec 2017 22:13:52 +0000 (15:13 -0700)]
sync

7 years agoAn empty RunAsUser means run as the invoking user, similar to how
Todd C. Miller [Tue, 12 Dec 2017 21:20:56 +0000 (14:20 -0700)]
An empty RunAsUser means run as the invoking user, similar to how
the sudoers files works.

7 years agoregen
Todd C. Miller [Tue, 12 Dec 2017 21:19:13 +0000 (14:19 -0700)]
regen

7 years agoAdd authfail_message sudoers option to allow the user to override
Todd C. Miller [Mon, 11 Dec 2017 19:43:58 +0000 (12:43 -0700)]
Add authfail_message sudoers option to allow the user to override
the default message of %d incorrect password attempt(s).

7 years agoAllow the plugin to determine whether or not an empty timeout is
Todd C. Miller [Mon, 11 Dec 2017 16:20:41 +0000 (09:20 -0700)]
Allow the plugin to determine whether or not an empty timeout is
allowed.  For sudoers, an error will be returned for an empty timeout.

7 years agoReturn an error for an empty timeout string. Just use strtol() for
Todd C. Miller [Mon, 11 Dec 2017 16:19:42 +0000 (09:19 -0700)]
Return an error for an empty timeout string.  Just use strtol() for
syntax checking instead of scanning with strspn().

7 years agoChange some _() into U_() since they are used for warn/fatal.
Todd C. Miller [Mon, 11 Dec 2017 15:07:01 +0000 (08:07 -0700)]
Change some _() into U_() since they are used for warn/fatal.
We always want to issue warnings in the user's locale.

7 years agoupdate my email address
Todd C. Miller [Mon, 11 Dec 2017 13:02:52 +0000 (06:02 -0700)]
update my email address

7 years agoDon't print mercurial branch info for merges.
Todd C. Miller [Mon, 11 Dec 2017 02:45:52 +0000 (19:45 -0700)]
Don't print mercurial branch info for merges.

7 years agoUse log size instead of using a separator between the log entry and
Todd C. Miller [Sun, 10 Dec 2017 20:39:41 +0000 (13:39 -0700)]
Use log size instead of using a separator between the log entry and
the file names.

7 years agoPrint usage and return an error when an empty argument is given for
Todd C. Miller [Sun, 10 Dec 2017 14:53:09 +0000 (07:53 -0700)]
Print usage and return an error when an empty argument is given for
all command line arguments other than -p and -E.  Bug #817

7 years agoBetter input validation of settings passed by the sudo front-end.
Todd C. Miller [Sun, 10 Dec 2017 14:45:49 +0000 (07:45 -0700)]
Better input validation of settings passed by the sudo front-end.
Instead of ignoring an empty setting, throw an error.

7 years agoTreat a blank line in a commit message as a line break. There
Todd C. Miller [Sun, 10 Dec 2017 12:56:22 +0000 (05:56 -0700)]
Treat a blank line in a commit message as a line break.  There
doesn't appear to be a way to make perl's format use a blank field
but at least the line break happens now.

7 years agoAdd script to generate ChangeLog from git log output.
Todd C. Miller [Sun, 10 Dec 2017 03:40:28 +0000 (20:40 -0700)]
Add script to generate ChangeLog from git log output.

7 years agoDon't include syslog.h from logging.h, just include it in the two
Todd C. Miller [Fri, 8 Dec 2017 22:00:41 +0000 (15:00 -0700)]
Don't include syslog.h from logging.h, just include it in the two
.c files it is actually needed.

7 years agoDocument that in check mode, visudo does not check the owner/mode
Todd C. Miller [Wed, 6 Dec 2017 17:17:33 +0000 (10:17 -0700)]
Document that in check mode, visudo does not check the owner/mode
on files specified with the -f flag.

7 years agoupdate my email to Todd.Miller@sudo.ws
Todd C. Miller [Mon, 4 Dec 2017 00:53:40 +0000 (17:53 -0700)]
update my email to Todd.Miller@sudo.ws

7 years agoAdd missing carriage return before prompt when replay is done.
Todd C. Miller [Sun, 3 Dec 2017 04:32:24 +0000 (21:32 -0700)]
Add missing carriage return before prompt when replay is done.

7 years agoTrack window size changes that happen while sudo is suspended
Todd C. Miller [Sun, 3 Dec 2017 04:30:11 +0000 (21:30 -0700)]
Track window size changes that happen while sudo is suspended

7 years agoregen
Todd C. Miller [Fri, 1 Dec 2017 22:43:04 +0000 (15:43 -0700)]
regen

7 years agoregen for sudo 1.8.22
Todd C. Miller [Fri, 1 Dec 2017 21:37:16 +0000 (14:37 -0700)]
regen for sudo 1.8.22

7 years agoSudo 1.8.22
Todd C. Miller [Fri, 1 Dec 2017 21:35:34 +0000 (14:35 -0700)]
Sudo 1.8.22

7 years agoBackground processes started by the command will no longer receive
Todd C. Miller [Fri, 1 Dec 2017 20:53:09 +0000 (13:53 -0700)]
Background processes started by the command will no longer receive
SIGHUP.

7 years agoWhen the command completes, make the monitor the foreground process
Todd C. Miller [Fri, 1 Dec 2017 20:43:06 +0000 (13:43 -0700)]
When the command completes, make the monitor the foreground process
group before informing the main sudo process of the command's exit
status.  This will prevent processes started by the command (which
runs in a different process group) from receiving SIGHUP since the
kernel sends SIGHUP to the foreground process group associated with
the terminal session.  The monitor has a SIGHUP handler installed
so the signal is effectively ignored.

7 years agoAdd debug printfs around group list retrieval.
Todd C. Miller [Fri, 1 Dec 2017 19:58:37 +0000 (12:58 -0700)]
Add debug printfs around group list retrieval.

7 years agoMove call to sudo_ev_loopcontinue() into schedule_signal() itself.
Todd C. Miller [Thu, 30 Nov 2017 17:02:15 +0000 (10:02 -0700)]
Move call to sudo_ev_loopcontinue() into schedule_signal() itself.
We always want to prioritize signal forwarding.

7 years agoDon't loop over read/write, recv/send or tcgetpgrp/tcsetpgrp trying
Todd C. Miller [Thu, 30 Nov 2017 16:53:21 +0000 (09:53 -0700)]
Don't loop over read/write, recv/send or tcgetpgrp/tcsetpgrp trying
to handle EINTR.  We now use SA_RESTART with signals so this is not
needed and is potentially dangerous if it is possible to receive
SIGTTIN or SIGTTOU (which it currently is not).

7 years agoBetter describe things when a command is run in a pty.
Todd C. Miller [Tue, 21 Nov 2017 23:59:54 +0000 (16:59 -0700)]
Better describe things when a command is run in a pty.

7 years agoSprinkle some extra debugging printfs
Todd C. Miller [Wed, 29 Nov 2017 20:13:33 +0000 (13:13 -0700)]
Sprinkle some extra debugging printfs

7 years agoHandle receipt of SIGTTIN/SIGTTOU when reading/writing from/to the tty.
Todd C. Miller [Wed, 29 Nov 2017 19:06:12 +0000 (12:06 -0700)]
Handle receipt of SIGTTIN/SIGTTOU when reading/writing from/to the tty.
We can't use a signal event for these since that would restart the
system call after the signal was handled and the callback would not
get a chance to run.  Fixes running a command in the background that
write to the tty when the TOSTOP terminal flag is set.

7 years agoWe don't need to be the foreground process to be able to write to
Todd C. Miller [Wed, 29 Nov 2017 19:06:12 +0000 (12:06 -0700)]
We don't need to be the foreground process to be able to write to
the terminal in most cases.  If the background process tries to
modify the terminal flags it will receive SIGTTOU which is relayed
to the sudo front-end.  This currently mishandles terminals with
the TOSTOP local flag set.

7 years agoAvoid a double free when ipa_hostname is set in sssd.conf and it
Todd C. Miller [Tue, 28 Nov 2017 18:28:44 +0000 (11:28 -0700)]
Avoid a double free when ipa_hostname is set in sssd.conf and it
is an unqualified host name.  From Daniel Kopecek.

Also move the "unable to allocate memory" warning into get_ipa_hostname()
itself to make it easier to see where the allocation failed in the
debug log.

7 years agoWhen running a command as the invoking user we cannot use the gid
Todd C. Miller [Tue, 28 Nov 2017 16:48:43 +0000 (09:48 -0700)]
When running a command as the invoking user we cannot use the gid
list from the front-end since it may not correspond to the user's
aux group vector as defined by the group database.

7 years agoAdd missing initprogname() calls.
Todd C. Miller [Tue, 28 Nov 2017 16:06:44 +0000 (09:06 -0700)]
Add missing initprogname() calls.