clear scrollback buffer before locking linux terminal (#683733)
parent
1a18be266a
commit
3f891b1869
@ -0,0 +1,62 @@
|
||||
commit 0aec2900f63820c3405ba38a4d1cd67cc22f0715
|
||||
Author: Miroslav Lichvar <mlichvar@redhat.com>
|
||||
Date: Mon Jul 18 17:26:47 2011 +0200
|
||||
|
||||
Clear scrollback buffer when locking terminal
|
||||
|
||||
Linux kernel 3.0 adds a new command to clear the scrollback buffer in
|
||||
the linux console. It's available in the ncurses terminfo entry as
|
||||
extended capability E3. This is useful to prevent an attacker to read
|
||||
content of a locked terminal via Shift-PgUp key.
|
||||
|
||||
diff --git a/src/display.c b/src/display.c
|
||||
index 5fa11cb..038c435 100644
|
||||
--- a/src/display.c
|
||||
+++ b/src/display.c
|
||||
@@ -3779,4 +3779,10 @@ char **cmdv;
|
||||
|
||||
#endif /* BLANKER_PRG */
|
||||
|
||||
+void
|
||||
+ClearScrollbackBuffer()
|
||||
+{
|
||||
+ if (D_CE3)
|
||||
+ AddCStr(D_CE3);
|
||||
+}
|
||||
|
||||
diff --git a/src/extern.h b/src/extern.h
|
||||
index c787d99..d3fecf0 100644
|
||||
--- a/src/extern.h
|
||||
+++ b/src/extern.h
|
||||
@@ -316,6 +316,7 @@ extern int color256to88 __P((int));
|
||||
extern void ResetIdle __P((void));
|
||||
extern void KillBlanker __P((void));
|
||||
extern void DisplaySleep1000 __P((int, int));
|
||||
+extern void ClearScrollbackBuffer __P((void));
|
||||
|
||||
/* resize.c */
|
||||
extern int ChangeWindowSize __P((struct win *, int, int, int));
|
||||
diff --git a/src/screen.c b/src/screen.c
|
||||
index cc8f565..3efb67b 100644
|
||||
--- a/src/screen.c
|
||||
+++ b/src/screen.c
|
||||
@@ -1967,6 +1967,7 @@ int mode;
|
||||
#endif
|
||||
case D_LOCK:
|
||||
ClearAll();
|
||||
+ ClearScrollbackBuffer();
|
||||
sign = SIG_LOCK;
|
||||
/* tell attacher to lock terminal with a lockprg. */
|
||||
break;
|
||||
diff --git a/src/term.c b/src/term.c
|
||||
index 991de1b..7485900 100644
|
||||
--- a/src/term.c
|
||||
+++ b/src/term.c
|
||||
@@ -83,6 +83,7 @@ struct term term[T_N] =
|
||||
{ "CD", T_STR },
|
||||
{ "ce", T_STR },
|
||||
{ "cb", T_STR },
|
||||
+ { "E3", T_STR },
|
||||
|
||||
/* initialise */
|
||||
{ "is", T_STR },
|
Loading…
Reference in new issue