Add tty size to user info
This commit is contained in:
@@ -73,7 +73,7 @@ PROGS = sudo
|
|||||||
# sudo_edit.o
|
# sudo_edit.o
|
||||||
OBJS = sudo.o parse_args.o lbuf.o alloc.o error.o zero_bytes.o \
|
OBJS = sudo.o parse_args.o lbuf.o alloc.o error.o zero_bytes.o \
|
||||||
load_plugins.o conversation.o list.o fmt_string.o tgetpass.o \
|
load_plugins.o conversation.o list.o fmt_string.o tgetpass.o \
|
||||||
fileops.o term.o atobool.o script.o pty.o @SUDO_OBJS@ $(LIBOBJS)
|
fileops.o term.o ttysize.o atobool.o script.o pty.o @SUDO_OBJS@ $(LIBOBJS)
|
||||||
|
|
||||||
LIBOBJDIR = $(top_srcdir)/@ac_config_libobj_dir@/
|
LIBOBJDIR = $(top_srcdir)/@ac_config_libobj_dir@/
|
||||||
|
|
||||||
@@ -149,6 +149,8 @@ term.o: $(srcdir)/term.c $(SUDODEP)
|
|||||||
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/term.c
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/term.c
|
||||||
tgetpass.o: $(srcdir)/tgetpass.c $(SUDODEP)
|
tgetpass.o: $(srcdir)/tgetpass.c $(SUDODEP)
|
||||||
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/tgetpass.c
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/tgetpass.c
|
||||||
|
ttysize.o: $(srcdir)/ttysize.c $(incdir)/compat.h $(top_builddir)/config.h
|
||||||
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/ttysize.c
|
||||||
zero_bytes.o: $(srcdir)/zero_bytes.c $(incdir)/compat.h $(top_builddir)/config.h
|
zero_bytes.o: $(srcdir)/zero_bytes.c $(incdir)/compat.h $(top_builddir)/config.h
|
||||||
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/zero_bytes.c
|
$(CC) -c $(CPPFLAGS) $(CFLAGS) $(DEFS) $(OPTIONS) $(srcdir)/zero_bytes.c
|
||||||
|
|
||||||
|
@@ -364,6 +364,10 @@ get_user_info(struct user_details *ud)
|
|||||||
errorx(1, "unable to allocate memory");
|
errorx(1, "unable to allocate memory");
|
||||||
ud->host = user_info[i] + sizeof("host=") - 1;
|
ud->host = user_info[i] + sizeof("host=") - 1;
|
||||||
|
|
||||||
|
get_ttysize(&ud->ts_lines, &ud->ts_cols);
|
||||||
|
easprintf(&user_info[++i], "lines=%d", ud->ts_lines);
|
||||||
|
easprintf(&user_info[++i], "cols=%d", ud->ts_cols);
|
||||||
|
|
||||||
user_info[++i] = NULL;
|
user_info[++i] = NULL;
|
||||||
|
|
||||||
return user_info;
|
return user_info;
|
||||||
|
@@ -119,6 +119,8 @@ struct user_details {
|
|||||||
const char *host;
|
const char *host;
|
||||||
GETGROUPS_T *groups;
|
GETGROUPS_T *groups;
|
||||||
int ngroups;
|
int ngroups;
|
||||||
|
int ts_cols;
|
||||||
|
int ts_lines;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define CD_SET_UID 0x0001
|
#define CD_SET_UID 0x0001
|
||||||
@@ -200,6 +202,9 @@ int parse_args(int argc, char **argv, int *nargc, char ***nargv,
|
|||||||
/* pty.c */
|
/* pty.c */
|
||||||
int get_pty(int *master, int *slave, char *name, size_t namesz, uid_t uid);
|
int get_pty(int *master, int *slave, char *name, size_t namesz, uid_t uid);
|
||||||
|
|
||||||
|
/* ttysize.c */
|
||||||
|
void get_ttysize(int *linep, int *colp);
|
||||||
|
|
||||||
/* sudo.c */
|
/* sudo.c */
|
||||||
int exec_setup(struct command_details *details);
|
int exec_setup(struct command_details *details);
|
||||||
extern int debug_level;
|
extern int debug_level;
|
||||||
|
70
src/ttysize.c
Normal file
70
src/ttysize.c
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2010 Todd C. Miller <Todd.Miller@courtesan.com>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and distribute this software for any
|
||||||
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
|
* copyright notice and this permission notice appear in all copies.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#ifdef STDC_HEADERS
|
||||||
|
# include <stdlib.h>
|
||||||
|
# include <stddef.h>
|
||||||
|
#else
|
||||||
|
# ifdef HAVE_STDLIB_H
|
||||||
|
# include <stdlib.h>
|
||||||
|
# endif
|
||||||
|
#endif /* STDC_HEADERS */
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
# include <unistd.h>
|
||||||
|
#endif /* HAVE_UNISTD_H */
|
||||||
|
#ifdef HAVE_TERMIOS_H
|
||||||
|
# include <termios.h>
|
||||||
|
#else
|
||||||
|
# include <termio.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "compat.h"
|
||||||
|
|
||||||
|
#if !defined(TIOCGSIZE) && defined(TIOCGWINSZ)
|
||||||
|
# define TIOCGSIZE TIOCGWINSZ
|
||||||
|
# define ttysize winsize
|
||||||
|
# define ts_cols ws_col
|
||||||
|
# define ts_lines ws_row
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void
|
||||||
|
get_ttysize(int *linep, int *colp)
|
||||||
|
{
|
||||||
|
char *p;
|
||||||
|
#ifdef TIOCGSIZE
|
||||||
|
struct ttysize win;
|
||||||
|
|
||||||
|
if (ioctl(STDERR_FILENO, TIOCGSIZE, &win) == 0 &&
|
||||||
|
win.ts_lines != 0 && win.ts_cols != 0) {
|
||||||
|
*linep = win.ts_lines;
|
||||||
|
*colp = win.ts_cols;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Fall back on $LINES and $COLUMNS. */
|
||||||
|
if ((p = getenv("LINES")) == NULL || (*linep = atoi(p)) <= 0)
|
||||||
|
*linep = 24;
|
||||||
|
if ((p = getenv("COLUMNS")) == NULL || (*colp = atoi(p)) <= 0)
|
||||||
|
*colp = 80;
|
||||||
|
}
|
Reference in New Issue
Block a user