|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
--- a/CMakeLists.txt
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+++ b/CMakeLists.txt
|
|
Michel Lind |
ef745b |
@@ -121,6 +121,7 @@ set(FISH_SRCS
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
src/tokenizer.cpp src/topic_monitor.cpp src/trace.cpp src/utf8.cpp src/util.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
src/wait_handle.cpp src/wcstringutil.cpp src/wgetopt.cpp src/wildcard.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
src/wutil.cpp src/fds.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ src/syslog.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
)
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
# Header files are just globbed.
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
--- a/src/reader.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+++ b/src/reader.cpp
|
|
Michel Lind |
ef745b |
@@ -76,6 +76,7 @@
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
#include "reader.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
#include "screen.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
#include "signal.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include "syslog.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
#include "termsize.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
#include "tokenizer.h"
|
|
Michel Lind |
ef745b |
#include "wcstringutil.h"
|
|
Michel Lind |
ef745b |
@@ -4355,6 +4356,7 @@ void reader_data_t::add_to_history() con
|
|
Michel Lind |
ef745b |
} else {
|
|
Michel Lind |
ef745b |
mode = history_persistence_mode_t::disk;
|
|
Michel Lind |
ef745b |
}
|
|
Michel Lind |
ef745b |
+ fish_syslog_history(text);
|
|
Michel Lind |
ef745b |
history_t::add_pending_with_file_detection(history, text, this->vars().snapshot(), mode);
|
|
Michel Lind |
ef745b |
}
|
|
Michel Lind |
ef745b |
}
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
--- /dev/null
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+++ b/src/syslog.cpp
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
@@ -0,0 +1,24 @@
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+// Syslogging utilities.
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include <stdlib.h>
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include <unistd.h>
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include "syslog.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include "wcstringutil.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+void fish_syslog_history(const wcstring &str) {
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ char cmd[SYSLOG_MAXLEN+1];
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ static int first = 1;
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ if (first) {
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ openlog(SYSLOG_SHELLNAME, OPENLOG_OPTS, SYSLOG_FACILITY);
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ first = 0;
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ }
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ int rc = wcstombs(cmd, str.c_str(), SYSLOG_MAXLEN);
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ if (rc < SYSLOG_MAXLEN) {
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ syslog(SYSLOG_FACILITY|SYSLOG_LEVEL, "HISTORY: PID=%d UID=%d %s", getpid(), getuid(), cmd);
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ } else {
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ syslog(SYSLOG_FACILITY|SYSLOG_LEVEL, "HISTORY (TRUNCATED): PID=%d UID=%d %s", getpid(), getuid(), cmd);
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+ }
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+}
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
--- /dev/null
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+++ b/src/syslog.h
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
@@ -0,0 +1,17 @@
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+// Syslogging utilities.
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#ifndef FISH_SYSLOG_H
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define FISH_SYSLOG_H
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include <syslog.h>
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#include "common.h"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define SYSLOG_SHELLNAME "fish"
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define SYSLOG_MAXLEN 600
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define SYSLOG_FACILITY LOG_AUTHPRIV
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define SYSLOG_LEVEL LOG_INFO
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#define OPENLOG_OPTS LOG_PID
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+void fish_syslog_history(const wcstring &str);
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+
|
|
data:image/s3,"s3://crabby-images/4dd95/4dd95902ed67425de09f026cf63f59147f84609b" alt="" |
430b2d |
+#endif
|