From e7d1fd9965b42ea8b17a38821140daeac1373d9a Mon Sep 17 00:00:00 2001 From: netblue30 Date: Fri, 25 Mar 2016 08:47:17 -0400 Subject: added firecfg utility --- Makefile.in | 21 +- RELNOTES | 1 + configure | 3 +- configure.ac | 2 +- src/bash_completion/firecfg.bash_completion | 39 ++++ src/firecfg/Makefile.in | 38 ++++ src/firecfg/firecfg.config | 7 + src/firecfg/main.c | 300 ++++++++++++++++++++++++++++ src/man/firecfg.txt | 70 +++++++ src/man/firejail-config.txt | 1 + src/man/firejail-login.txt | 1 + src/man/firejail-profile.txt | 1 + src/man/firejail.txt | 1 + src/man/firemon.txt | 1 + 14 files changed, 480 insertions(+), 6 deletions(-) create mode 100644 src/bash_completion/firecfg.bash_completion create mode 100644 src/firecfg/Makefile.in create mode 100644 src/firecfg/firecfg.config create mode 100644 src/firecfg/main.c create mode 100644 src/man/firecfg.txt diff --git a/Makefile.in b/Makefile.in index 90b238752..85df261aa 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,6 +1,6 @@ -all: apps firejail.1 firemon.1 firejail-profile.5 firejail-login.5 firejail-config.5 +all: apps firejail.1 firemon.1 firecfg.1 firejail-profile.5 firejail-login.5 firejail-config.5 MYLIBS = src/lib -APPS = src/firejail src/firemon src/libtrace src/libtracelog src/ftee +APPS = src/firejail src/firemon src/firecfg src/libtrace src/libtracelog src/ftee prefix=@prefix@ exec_prefix=@exec_prefix@ @@ -29,6 +29,8 @@ firemon.1: src/man/firemon.txt ./mkman.sh $(VERSION) src/man/firemon.txt firemon.1 firejail.1: src/man/firejail.txt ./mkman.sh $(VERSION) src/man/firejail.txt firejail.1 +firecfg.1: src/man/firecfg.txt + ./mkman.sh $(VERSION) src/man/firecfg.txt firecfg.1 firejail-profile.5: src/man/firejail-profile.txt ./mkman.sh $(VERSION) src/man/firejail-profile.txt firejail-profile.5 firejail-login.5: src/man/firejail-login.txt @@ -43,7 +45,7 @@ clean: for dir in $(MYLIBS); do \ $(MAKE) -C $$dir clean; \ done - rm -f firejail.1 firejail.1.gz firemon.1 firemon.1.gz firejail-profile.5 firejail-profile.5.gz firejail-login.5 firejail-login.5.gz firejail-config.5 firejail-config.5.gz firejail*.rpm + rm -f firejail.1 firejail.1.gz firemon.1 firemon.1.gz firecfg.1 firecfg.gz firejail-profile.5 firejail-profile.5.gz firejail-login.5 firejail-login.5.gz firejail-config.5 firejail-config.5.gz firejail*.rpm distclean: clean for dir in $(APPS); do \ @@ -61,12 +63,15 @@ realinstall: chmod u+s $(DESTDIR)/$(bindir)/firejail # firemon executable install -c -m 0755 src/firemon/firemon $(DESTDIR)/$(bindir)/. + # firecfg executable + install -c -m 0755 src/firecfg/firecfg $(DESTDIR)/$(bindir)/. # libraries and plugins install -m 0755 -d $(DESTDIR)/$(libdir)/firejail install -c -m 0644 src/libtrace/libtrace.so $(DESTDIR)/$(libdir)/firejail/. install -c -m 0644 src/libtracelog/libtracelog.so $(DESTDIR)/$(libdir)/firejail/. install -c -m 0755 src/ftee/ftee $(DESTDIR)/$(libdir)/firejail/. install -c -m 0755 src/fshaper/fshaper.sh $(DESTDIR)/$(libdir)/firejail/. + install -c -m 0644 src/firecfg/firecfg.config $(DESTDIR)/$(libdir)/firejail/. # documents install -m 0755 -d $(DESTDIR)/$(DOCDIR) install -c -m 0644 COPYING $(DESTDIR)/$(DOCDIR)/. @@ -159,6 +164,8 @@ realinstall: gzip -9n firejail.1 rm -f firemon.1.gz gzip -9n firemon.1 + rm -f firecfg.1.gz + gzip -9n firecfg.1 rm -f firejail-profile.5.gz gzip -9n firejail-profile.5 rm -f firejail-login.5.gz @@ -168,15 +175,17 @@ realinstall: install -m 0755 -d $(DESTDIR)/$(mandir)/man1 install -c -m 0644 firejail.1.gz $(DESTDIR)/$(mandir)/man1/. install -c -m 0644 firemon.1.gz $(DESTDIR)/$(mandir)/man1/. + install -c -m 0644 firecfg.1.gz $(DESTDIR)/$(mandir)/man1/. install -m 0755 -d $(DESTDIR)/$(mandir)/man5 install -c -m 0644 firejail-profile.5.gz $(DESTDIR)/$(mandir)/man5/. install -c -m 0644 firejail-login.5.gz $(DESTDIR)/$(mandir)/man5/. install -c -m 0644 firejail-config.5.gz $(DESTDIR)/$(mandir)/man5/. - rm -f firejail.1.gz firemon.1.gz firejail-profile.5.gz firejail-login.5.gz firejail-config.5.gz + rm -f firejail.1.gz firemon.1.gz firecfg.1.gz firejail-profile.5.gz firejail-login.5.gz firejail-config.5.gz # bash completion install -m 0755 -d $(DESTDIR)/$(datarootdir)/bash-completion/completions install -c -m 0644 src/bash_completion/firejail.bash_completion $(DESTDIR)/$(datarootdir)/bash-completion/completions/firejail install -c -m 0644 src/bash_completion/firemon.bash_completion $(DESTDIR)/$(datarootdir)/bash-completion/completions/firemon + install -c -m 0644 src/bash_completion/firecfg.bash_completion $(DESTDIR)/$(datarootdir)/bash-completion/completions/firecfg install: all @@ -185,6 +194,7 @@ install: all install-strip: all strip src/firejail/firejail strip src/firemon/firemon + strip src/firecfg/firecfg strip src/libtrace/libtrace.so strip src/libtracelog/libtracelog.so strip src/ftee/ftee @@ -193,15 +203,18 @@ install-strip: all uninstall: rm -f $(DESTDIR)/$(bindir)/firejail rm -f $(DESTDIR)/$(bindir)/firemon + rm -f $(DESTDIR)/$(bindir)/firecfg rm -fr $(DESTDIR)/$(libdir)/firejail rm -fr $(DESTDIR)/$(datarootdir)/doc/firejail rm -f $(DESTDIR)/$(mandir)/man1/firejail.1* rm -f $(DESTDIR)/$(mandir)/man1/firemon.1* + rm -f $(DESTDIR)/$(mandir)/man1/firecfg.1* rm -f $(DESTDIR)/$(mandir)/man5/firejail-profile.5* rm -f $(DESTDIR)/$(mandir)/man5/firejail-login.5* rm -f $(DESTDIR)/$(mandir)/man5/firejail-config.5* rm -f $(DESTDIR)/$(datarootdir)/bash-completion/completions/firejail rm -f $(DESTDIR)/$(datarootdir)/bash-completion/completions/firemon + rm -f $(DESTDIR)/$(datarootdir)/bash-completion/completions/firecfg dist: make distclean diff --git a/RELNOTES b/RELNOTES index 03261ddf7..754866813 100644 --- a/RELNOTES +++ b/RELNOTES @@ -8,6 +8,7 @@ firejail (0.9.39) baseline; urgency=low * --version also prints compile options * added compile-time option to restrict --net= to root only * run time config support, man firejail-config + * added firecfg utility * build rpm packages using "make rpms" * new profiles: lxterminal, Epiphany, cherrytree, Polari, Vivaldi, Atril * new profiles: qutebrowser, SlimJet diff --git a/configure b/configure index 937ab8445..703df1b7d 100755 --- a/configure +++ b/configure @@ -3640,7 +3640,7 @@ if test "$prefix" = /usr; then sysconfdir="/etc" fi -ac_config_files="$ac_config_files Makefile src/lib/Makefile src/firejail/Makefile src/firemon/Makefile src/libtrace/Makefile src/libtracelog/Makefile src/ftee/Makefile" +ac_config_files="$ac_config_files Makefile src/lib/Makefile src/firejail/Makefile src/firemon/Makefile src/libtrace/Makefile src/libtracelog/Makefile src/firecfg/Makefile src/ftee/Makefile" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure @@ -4355,6 +4355,7 @@ do "src/firemon/Makefile") CONFIG_FILES="$CONFIG_FILES src/firemon/Makefile" ;; "src/libtrace/Makefile") CONFIG_FILES="$CONFIG_FILES src/libtrace/Makefile" ;; "src/libtracelog/Makefile") CONFIG_FILES="$CONFIG_FILES src/libtracelog/Makefile" ;; + "src/firecfg/Makefile") CONFIG_FILES="$CONFIG_FILES src/firecfg/Makefile" ;; "src/ftee/Makefile") CONFIG_FILES="$CONFIG_FILES src/ftee/Makefile" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; diff --git a/configure.ac b/configure.ac index c59f5a28b..c2beb0cc1 100644 --- a/configure.ac +++ b/configure.ac @@ -90,7 +90,7 @@ if test "$prefix" = /usr; then sysconfdir="/etc" fi -AC_OUTPUT(Makefile src/lib/Makefile src/firejail/Makefile src/firemon/Makefile src/libtrace/Makefile src/libtracelog/Makefile src/ftee/Makefile) +AC_OUTPUT(Makefile src/lib/Makefile src/firejail/Makefile src/firemon/Makefile src/libtrace/Makefile src/libtracelog/Makefile src/firecfg/Makefile src/ftee/Makefile) echo echo "Configuration options:" diff --git a/src/bash_completion/firecfg.bash_completion b/src/bash_completion/firecfg.bash_completion new file mode 100644 index 000000000..79b74e49d --- /dev/null +++ b/src/bash_completion/firecfg.bash_completion @@ -0,0 +1,39 @@ +# bash completion for firecfg -*- shell-script -*- +#******************************************************************** +# Script based on completions/configure script in bash-completion package in +# Debian. The original package is release under GPL v2 license, the webpage is +# http://bash-completion.alioth.debian.org +#******************************************************************* + +_firecfg() +{ + local cur prev words cword split + _init_completion -s || return + + case $prev in + --help|--version) + return + ;; + esac + + $split && return 0 + + # if $COMP_CONFIGURE_HINTS is not null, then completions of the form + # --option=SETTING will include 'SETTING' as a contextual hint + [[ "$cur" != -* ]] && return 0 + + if [[ -n $COMP_CONFIGURE_HINTS ]]; then + COMPREPLY=( $( compgen -W "$( $1 --help 2>&1 | \ + awk '/^ --[A-Za-z]/ { print $1; \ + if ($2 ~ /--[A-Za-z]/) print $2 }' | sed -e 's/[[,].*//g' )" \ + -- "$cur" ) ) + [[ $COMPREPLY == *=* ]] && compopt -o nospace + else + COMPREPLY=( $( compgen -W '$( _parse_help "$1" )' -- "$cur" ) ) + [[ $COMPREPLY == *= ]] && compopt -o nospace + fi +} && +complete -F _firecfg firecfg + + + diff --git a/src/firecfg/Makefile.in b/src/firecfg/Makefile.in new file mode 100644 index 000000000..11f8b1e8d --- /dev/null +++ b/src/firecfg/Makefile.in @@ -0,0 +1,38 @@ +all: firecfg + +prefix=@prefix@ +exec_prefix=@exec_prefix@ +libdir=@libdir@ +sysconfdir=@sysconfdir@ + +VERSION=@PACKAGE_VERSION@ +NAME=@PACKAGE_NAME@ +HAVE_SECCOMP_H=@HAVE_SECCOMP_H@ +HAVE_SECCOMP=@HAVE_SECCOMP@ +HAVE_CHROOT=@HAVE_CHROOT@ +HAVE_BIND=@HAVE_BIND@ +HAVE_FATAL_WARNINGS=@HAVE_FATAL_WARNINGS@ +HAVE_NETWORK=@HAVE_NETWORK@ +HAVE_USERNS=@HAVE_USERNS@ +HAVE_X11=@HAVE_X11@ +HAVE_FILE_TRANSFER=@HAVE_FILE_TRANSFER@ + + +H_FILE_LIST = $(sort $(wildcard *.[h])) +C_FILE_LIST = $(sort $(wildcard *.c)) +OBJS = $(C_FILE_LIST:.c=.o) +BINOBJS = $(foreach file, $(OBJS), $file) +CFLAGS += -ggdb $(HAVE_FATAL_WARNINGS) -O2 -DVERSION='"$(VERSION)"' -DPREFIX='"$(prefix)"' -DSYSCONFDIR='"$(sysconfdir)/firejail"' -DLIBDIR='"$(libdir)"' $(HAVE_X11) $(HAVE_SECCOMP) $(HAVE_SECCOMP_H) $(HAVE_CHROOT) $(HAVE_NETWORK) $(HAVE_USERNS) $(HAVE_BIND) $(HAVE_FILE_TRANSFER) -fstack-protector-all -D_FORTIFY_SOURCE=2 -fPIE -pie -Wformat -Wformat-security +LDFLAGS += -pie -Wl,-z,relro -Wl,-z,now -lpthread + +%.o : %.c $(H_FILE_LIST) ../include/common.h ../include/euid_common.h ../include/libnetlink.h ../include/pid.h + $(CC) $(CFLAGS) $(INCLUDE) -c $< -o $@ + +firecfg: $(OBJS) ../lib/common.o + $(CC) $(LDFLAGS) -o $@ $(OBJS) ../lib/common.o $(LIBS) + +clean:; rm -f *.o firecfg firecfg.1 firecfg.1.gz + +distclean: clean + rm -fr Makefile + diff --git a/src/firecfg/firecfg.config b/src/firecfg/firecfg.config new file mode 100644 index 000000000..fb996966f --- /dev/null +++ b/src/firecfg/firecfg.config @@ -0,0 +1,7 @@ +# /etc/firejail/firecfg.config - firecfg utility configuration file +# This is the list of programs handled by firecfg utility +# +firefox +iceweasel +thunderbird +vlc diff --git a/src/firecfg/main.c b/src/firecfg/main.c new file mode 100644 index 000000000..7465f2d3e --- /dev/null +++ b/src/firecfg/main.c @@ -0,0 +1,300 @@ +/* + * Copyright (C) 2014-2016 netblue30 (netblue30@yahoo.com) + * + * This file is part of firejail project + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +*/ + +#include +#include +#include +#include +#include +#include "../include/common.h" + +static void usage(void) { + printf("firecfg - version %s\n\n", VERSION); + printf("Firecfg is the desktop configuration utility for Firejail software. The utility\n"); + printf("creates several symbolic links to firejail executable. This allows the user to\n"); + printf("sandbox applications automatically, just by clicking on a regular desktop\n"); + printf("menues and icons.\n\n"); + printf("The symbolic links are placed in /usr/local/bin. For more information, see\n"); + printf("DESKTOP INTEGRATION section in man 1 firejail.\n\n"); + printf("Usage: firecfg [OPTIONS]\n\n"); + printf(" --clear - clear all firejail symbolic links\n\n"); + printf(" --help, -? - this help screen.\n\n"); + printf(" --list - list all firejail symbolic links\n\n"); + printf(" --version - print program version and exit.\n\n"); + printf("Example:\n\n"); + printf(" $ sudo firecfg\n"); + printf(" /usr/local/bin/firefox created\n"); + printf(" /usr/local/bin/vlc created\n"); + printf(" [...]\n"); + printf(" $ firecfg --list\n"); + printf(" /usr/local/bin/firefox\n"); + printf(" /usr/local/bin/vlc\n"); + printf(" [...]\n"); + printf(" $ sudo firecfg --clear\n"); + printf(" /usr/local/bin/firefox removed\n"); + printf(" /usr/local/bin/vlc removed\n"); + printf(" [...]\n"); + printf("\n"); + printf("License GPL version 2 or later\n"); + printf("Homepage: http://firejail.wordpress.com\n\n"); +} + +// return 1 if the program is found +static int find(const char *program, const char *directory) { + int retval = 0; + + char *fname; + if (asprintf(&fname, "/%s/%s", directory, program) == -1) + errExit("asprintf"); + + struct stat s; + if (stat(fname, &s) == 0) + retval = 1; + + free(fname); + return retval; +} + + +// return 1 if program is installed on the system +static int which(const char *program) { + // check some well-known paths + if (find(program, "/bin") || find(program, "/usr/bin") || + find(program, "/sbin") || find(program, "/usr/sbin")) + return 1; + + // check environment + char *path1 = getenv("PATH"); + if (path1) { + char *path2 = strdup(path1); + if (!path2) + errExit("strdup"); + + // use path2 to count the entries + char *ptr = strtok(path2, ":"); + while (ptr) { + if (find(program, ptr)) { + free(path2); + return 1; + } + ptr = strtok(NULL, ":"); + } + free(path2); + } + + return 0; +} + +// return 1 if the file is a link +static int is_link(const char *fname) { + assert(fname); + if (*fname == '\0') + return 0; + + struct stat s; + if (lstat(fname, &s) == 0) { + if (S_ISLNK(s.st_mode)) + return 1; + } + + return 0; +} + +static void list(void) { + DIR *dir = opendir("/usr/local/bin"); + if (!dir) { + fprintf(stderr, "Error: cannot open /usr/local/bin directory\n"); + exit(1); + } + + char *firejail_exec; + if (asprintf(&firejail_exec, "%s/bin/firejail", PREFIX) == -1) + errExit("asprintf"); + + struct dirent *entry; + while ((entry = readdir(dir)) != NULL) { + if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) + continue; + + char *fullname; + if (asprintf(&fullname, "/usr/local/bin/%s", entry->d_name) == -1) + errExit("asprintf"); + + if (is_link(fullname)) { + char* fname = realpath(fullname, NULL); + if (fname) { + if (strcmp(fname, firejail_exec) == 0) + printf("%s\n", fullname); + free(fname); + } + } + free(fullname); + } + + closedir(dir); + free(firejail_exec); +} + +static void clear(void) { + if (getuid() != 0) { + fprintf(stderr, "Error: you need to be root to run this command\n"); + exit(1); + } + + DIR *dir = opendir("/usr/local/bin"); + if (!dir) { + fprintf(stderr, "Error: cannot open /usr/local/bin directory\n"); + exit(1); + } + + char *firejail_exec; + if (asprintf(&firejail_exec, "%s/bin/firejail", PREFIX) == -1) + errExit("asprintf"); + + struct dirent *entry; + while ((entry = readdir(dir)) != NULL) { + if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) + continue; + + char *fullname; + if (asprintf(&fullname, "/usr/local/bin/%s", entry->d_name) == -1) + errExit("asprintf"); + + if (is_link(fullname)) { + char* fname = realpath(fullname, NULL); + if (fname) { + if (strcmp(fname, firejail_exec) == 0) { + printf("%s removed\n", fullname); + unlink(fullname); + } + free(fname); + } + } + free(fullname); + } + + closedir(dir); + free(firejail_exec); +} + +static void set_file(const char *name, const char *firejail_exec) { + if (which(name) == 0) + return; + + char *fname; + if (asprintf(&fname, "/usr/local/bin/%s", name) == -1) + errExit("asprintf"); + + struct stat s; + if (stat(fname, &s) == 0) + ; //printf("%s already present\n", fname); + else { + int rv = symlink(firejail_exec, fname); + if (rv) { + fprintf(stderr, "Error: cannot create %s symbolic link\n", fname); + perror("symlink"); + } + else + printf("%s created\n", fname); + } + + free(fname); +} + +#define MAX_BUF 1024 +static void set(void) { + if (getuid() != 0) { + fprintf(stderr, "Error: you need to be root to run this command\n"); + exit(1); + } + + char *cfgfile; + if (asprintf(&cfgfile, "%s/firejail/firecfg.config", LIBDIR) == -1) + errExit("asprintf"); + + char *firejail_exec; + if (asprintf(&firejail_exec, "%s/bin/firejail", PREFIX) == -1) + errExit("asprintf"); + + FILE *fp = fopen(cfgfile, "r"); + if (!fp) { + fprintf(stderr, "Error: cannot open %s\n", cfgfile); + exit(1); + } + + char buf[MAX_BUF]; + int lineno = 0; + while (fgets(buf, MAX_BUF,fp)) { + lineno++; + if (*buf == '#') // comments + continue; + + // remove \n + char *ptr = strchr(buf, '\n'); + if (ptr) + *ptr = '\0'; + + // do not accept .. and/or / in file name + if (strstr(buf, "..") || strchr(buf, '/')) { + fprintf(stderr, "Error: invalid line %d in %s\n", lineno, cfgfile); + exit(1); + } + + set_file(buf, firejail_exec); + } + + free(cfgfile); + free(firejail_exec); +} + +int main(int argc, char **argv) { + int i; + + for (i = 1; i < argc; i++) { + // default options + if (strcmp(argv[i], "--help") == 0 || + strcmp(argv[i], "-?") == 0) { + usage(); + return 0; + } + else if (strcmp(argv[i], "--version") == 0) { + printf("firecfg version %s\n\n", VERSION); + return 0; + } + else if (strcmp(argv[i], "--clear") == 0) { + clear(); + return 0; + } + else if (strcmp(argv[i], "--list") == 0) { + list(); + return 0; + } + else { + fprintf(stderr, "Error: invalid command line option\n"); + usage(); + return 1; + } + } + + set(); + + return 0; +} + diff --git a/src/man/firecfg.txt b/src/man/firecfg.txt new file mode 100644 index 000000000..7d95892a4 --- /dev/null +++ b/src/man/firecfg.txt @@ -0,0 +1,70 @@ +.TH FIREMON 1 "MONTH YEAR" "VERSION" "firecfg man page" +.SH NAME +Firecfg \- Desktop configuration program for Firejail software. +.SH SYNOPSIS +firecfg [OPTIONS] +.SH DESCRIPTION +Firecfg is the desktop configuration utility for Firejail software. The utility +creates several symbolic links to firejail executable. This allows the user to +sandbox applications automatically, just by clicking on a regular desktop +menues and icons. + +The symbolic links are placed in /usr/local/bin. For more information, see +DESKTOP INTEGRATION section in man 1 firejail. + +.SH OPTIONS +.TP +\fB\-\-clear +Clear all firejail symbolic links +.TP +\fB\-?\fR, \fB\-\-help\fR +Print options end exit. +.TP +\fB\-\-list +List all firejail symbolic links +.TP +\fB\-\-version +Print program version and exit. + + +.PP +Example: +.br + +.br +$ sudo firecfg +.br +/usr/local/bin/firefox created +.br +/usr/local/bin/vlc created +.br +[...] +.br +$ firecfg --list +.br +/usr/local/bin/firefox +.br +/usr/local/bin/vlc +.br +[...] +.br +$ sudo firecfg --clear +.br +/usr/local/bin/firefox removed +.br +/usr/local/bin/vlc removed +.br +[...] + +.SH LICENSE +This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. +.PP +Homepage: http://firejail.wordpress.com +.SH SEE ALSO +\&\flfirejail\fR\|(1), +\&\flfiremon\fR\|(1), +\&\flfirejail-profile\fR\|(5), +\&\flfirejail-login\fR\|(5) +\&\flfirejail-config\fR\|(5) + + diff --git a/src/man/firejail-config.txt b/src/man/firejail-config.txt index 55c35181a..687aedf59 100644 --- a/src/man/firejail-config.txt +++ b/src/man/firejail-config.txt @@ -58,6 +58,7 @@ Homepage: http://firejail.wordpress.com .SH SEE ALSO \&\flfirejail\fR\|(1), \&\flfiremon\fR\|(1), +\&\flfirecfg\fR\|(1), \&\flfirejail-profile\fR\|(5) \&\flfirejail-login\fR\|(5) diff --git a/src/man/firejail-login.txt b/src/man/firejail-login.txt index 13d045ee4..2825ca4cf 100644 --- a/src/man/firejail-login.txt +++ b/src/man/firejail-login.txt @@ -32,6 +32,7 @@ Homepage: http://firejail.wordpress.com .SH SEE ALSO \&\flfirejail\fR\|(1), \&\flfiremon\fR\|(1), +\&\flfirecfg\fR\|(1), \&\flfirejail-profile\fR\|(5) \&\flfirejail-config\fR\|(5) diff --git a/src/man/firejail-profile.txt b/src/man/firejail-profile.txt index 82a0d2503..b135ee615 100644 --- a/src/man/firejail-profile.txt +++ b/src/man/firejail-profile.txt @@ -351,6 +351,7 @@ Homepage: http://firejail.wordpress.com .SH SEE ALSO \&\flfirejail\fR\|(1), \&\flfiremon\fR\|(1), +\&\flfirecfg\fR\|(1), \&\flfirejail-login\fR\|(5) \&\flfirejail-config\fR\|(5) diff --git a/src/man/firejail.txt b/src/man/firejail.txt index 99a9429c7..806a68c3c 100644 --- a/src/man/firejail.txt +++ b/src/man/firejail.txt @@ -1838,6 +1838,7 @@ This program is free software; you can redistribute it and/or modify it under th Homepage: http://firejail.wordpress.com .SH SEE ALSO \&\flfiremon\fR\|(1), +\&\flfirecfg\fR\|(1), \&\flfirejail-profile\fR\|(5), \&\flfirejail-login\fR\|(5) \&\flfirejail-config\fR\|(5) diff --git a/src/man/firemon.txt b/src/man/firemon.txt index 78a6dd5ea..906b5cd9a 100644 --- a/src/man/firemon.txt +++ b/src/man/firemon.txt @@ -105,6 +105,7 @@ This program is free software; you can redistribute it and/or modify it under th Homepage: http://firejail.wordpress.com .SH SEE ALSO \&\flfirejail\fR\|(1), +\&\flfirecfg\fR\|(1), \&\flfirejail-profile\fR\|(5), \&\flfirejail-login\fR\|(5) \&\flfirejail-config\fR\|(5) -- cgit v1.2.3-70-g09d2