|
|
06486d |
From 42c35440205e0174af21315277dedac76fb9c8ae Mon Sep 17 00:00:00 2001
|
|
|
06486d |
From: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
06486d |
Date: Fri, 24 Apr 2015 15:37:15 +0200
|
|
|
06486d |
Subject: [PATCH] abrt-auto-reporting: require rhtsupport.conf file only on
|
|
|
06486d |
RHEL
|
|
|
06486d |
|
|
|
06486d |
abrt-auto-reporting required the rhtsupport.conf on Fedora and CentOS but the conf
|
|
|
06486d |
file do not exists in those systems.
|
|
|
06486d |
|
|
|
06486d |
Resolves abrt/abrt#957
|
|
|
06486d |
|
|
|
06486d |
Signed-off-by: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
06486d |
---
|
|
|
06486d |
configure.ac | 11 +++
|
|
|
06486d |
doc/Makefile.am | 13 +++-
|
|
|
06486d |
doc/abrt-auto-reporting-authenticated.txt | 106 ++++++++++++++++++++++++++++
|
|
|
06486d |
doc/abrt-auto-reporting-unauthenticated.txt | 71 +++++++++++++++++++
|
|
|
06486d |
doc/abrt-auto-reporting.txt | 106 ----------------------------
|
|
|
06486d |
src/daemon/abrt-auto-reporting.c | 71 ++++++++++++++-----
|
|
|
06486d |
6 files changed, 254 insertions(+), 124 deletions(-)
|
|
|
06486d |
create mode 100644 doc/abrt-auto-reporting-authenticated.txt
|
|
|
06486d |
create mode 100644 doc/abrt-auto-reporting-unauthenticated.txt
|
|
|
06486d |
delete mode 100644 doc/abrt-auto-reporting.txt
|
|
|
06486d |
|
|
|
06486d |
diff --git a/configure.ac b/configure.ac
|
|
|
06486d |
index d95fc4a..d65bf54 100644
|
|
|
06486d |
--- a/configure.ac
|
|
|
06486d |
+++ b/configure.ac
|
|
|
06486d |
@@ -207,6 +207,17 @@ AC_ARG_ENABLE(suggest-autoreporting,
|
|
|
06486d |
|
|
|
06486d |
AM_CONDITIONAL(SUGGEST_AUTOREPORTING, test "$enable_suggest_autoreporting" = "yes")
|
|
|
06486d |
|
|
|
06486d |
+# Authenticated autoreporting
|
|
|
06486d |
+
|
|
|
06486d |
+AC_ARG_ENABLE(authenticated-autoreporting,
|
|
|
06486d |
+ AS_HELP_STRING([--enable-authenticated-autoreporting],
|
|
|
06486d |
+ [enable authenticated autoreporting]),
|
|
|
06486d |
+ [enable_authenticated_autoreporting=$enableval],
|
|
|
06486d |
+ [enable_authenticated_autoreporting=no]
|
|
|
06486d |
+)
|
|
|
06486d |
+
|
|
|
06486d |
+AM_CONDITIONAL(AUTHENTICATED_AUTOREPORTING, test "$enable_authenticated_autoreporting" = "yes")
|
|
|
06486d |
+
|
|
|
06486d |
# Make satyr use GDB or elfutils/libunwind for unwinding?
|
|
|
06486d |
|
|
|
06486d |
AC_ARG_ENABLE([native-unwinder],
|
|
|
06486d |
diff --git a/doc/Makefile.am b/doc/Makefile.am
|
|
|
06486d |
index 0480114..309a330 100644
|
|
|
06486d |
--- a/doc/Makefile.am
|
|
|
06486d |
+++ b/doc/Makefile.am
|
|
|
06486d |
@@ -71,6 +71,17 @@ man1_MANS = ${MAN1_TXT:%.txt=%.1}
|
|
|
06486d |
man5_MANS = ${MAN5_TXT:%.txt=%.5} ${MAN5_PREFORMATTED}
|
|
|
06486d |
man8_MANS = ${MAN8_TXT:%.txt=%.8}
|
|
|
06486d |
|
|
|
06486d |
+MAN_SOURCE =
|
|
|
06486d |
+MAN_SOURCE = abrt-auto-reporting-authenticated.txt
|
|
|
06486d |
+MAN_SOURCE = abrt-auto-reporting-unauthenticated.txt
|
|
|
06486d |
+
|
|
|
06486d |
+if AUTHENTICATED_AUTOREPORTING
|
|
|
06486d |
+abrt-auto-reporting.txt: abrt-auto-reporting-authenticated.txt
|
|
|
06486d |
+else
|
|
|
06486d |
+abrt-auto-reporting.txt: abrt-auto-reporting-unauthenticated.txt
|
|
|
06486d |
+endif
|
|
|
06486d |
+ cp $< $@
|
|
|
06486d |
+
|
|
|
06486d |
%.1 %.5 %.8: %.xml
|
|
|
06486d |
$(XMLTO_SILENT) xmlto man $< 2>&1 | sed '/Note/d'
|
|
|
06486d |
|
|
|
06486d |
@@ -79,6 +90,6 @@ man8_MANS = ${MAN8_TXT:%.txt=%.8}
|
|
|
06486d |
--conf-file ../asciidoc.conf \
|
|
|
06486d |
-aabrt_version=$(PACKAGE_VERSION) -o $@ $<
|
|
|
06486d |
|
|
|
06486d |
-EXTRA_DIST = $(MAN1_TXT) $(MAN5_TXT) $(MAN8_TXT) $(MAN5_PREFORMATTED)
|
|
|
06486d |
+EXTRA_DIST = $(MAN1_TXT) $(MAN5_TXT) $(MAN8_TXT) $(MAN5_PREFORMATTED) $(MAN_SOURCE)
|
|
|
06486d |
|
|
|
06486d |
CLEANFILES = ${MAN1_TXT:%.txt=%.1} ${MAN5_TXT:%.txt=%.5} ${MAN8_TXT:%.txt=%.8}
|
|
|
06486d |
diff --git a/doc/abrt-auto-reporting-authenticated.txt b/doc/abrt-auto-reporting-authenticated.txt
|
|
|
06486d |
new file mode 100644
|
|
|
06486d |
index 0000000..2a27945
|
|
|
06486d |
--- /dev/null
|
|
|
06486d |
+++ b/doc/abrt-auto-reporting-authenticated.txt
|
|
|
06486d |
@@ -0,0 +1,106 @@
|
|
|
06486d |
+abrt-auto-reporting(1)
|
|
|
06486d |
+======================
|
|
|
06486d |
+
|
|
|
06486d |
+NAME
|
|
|
06486d |
+----
|
|
|
06486d |
+abrt-auto-reporting - Get or modify the auto reporting option values
|
|
|
06486d |
+
|
|
|
06486d |
+SYNOPSIS
|
|
|
06486d |
+--------
|
|
|
06486d |
+'abrt-auto-reporting' [-v] [ enabled | yes | 1 | on | disabled | no | 0 | off ]
|
|
|
06486d |
+ [ [--anonymous] |
|
|
|
06486d |
+ [--username USERNAME [--password PASSWORD] ] |
|
|
|
06486d |
+ [--certificate SOURCE] ]
|
|
|
06486d |
+
|
|
|
06486d |
+DESCRIPTION
|
|
|
06486d |
+-----------
|
|
|
06486d |
+Reads the configuration from abrt.conf and saves the changes to the same file.
|
|
|
06486d |
+
|
|
|
06486d |
+The changes will take effect immediately without necessity to restart any ABRT
|
|
|
06486d |
+process and will be persistent.
|
|
|
06486d |
+
|
|
|
06486d |
+'disabled'::
|
|
|
06486d |
+ User have to report the detect problems manually
|
|
|
06486d |
+
|
|
|
06486d |
+'enabled'::
|
|
|
06486d |
+ ABRT uploads an uReport which was generated for a detected problem
|
|
|
06486d |
+ immediately after the detection phase.
|
|
|
06486d |
+
|
|
|
06486d |
+Reads and saves the authentication configuration options in
|
|
|
06486d |
+/etc/libreport/plugins/ureport.conf and /etc/libreport/plugins/rhtsupport.conf
|
|
|
06486d |
+
|
|
|
06486d |
+uReport description
|
|
|
06486d |
+~~~~~~~~~~~~~~~~~~~
|
|
|
06486d |
+ABRT supports uReports for four types of crashes: crashes of C/C++ programs
|
|
|
06486d |
+that result in a core dump, uncaught Python exceptions, uncaught Java
|
|
|
06486d |
+exceptions and kernel oopses.
|
|
|
06486d |
+
|
|
|
06486d |
+Each uReport generally contains a stack trace, or multiple stack traces in the
|
|
|
06486d |
+case of multi-threaded C/C++ and Java programs. The stack trace only describes
|
|
|
06486d |
+the call stack of the program at the time of the crash and does not contain
|
|
|
06486d |
+contents of any variables.
|
|
|
06486d |
+
|
|
|
06486d |
+Every uReport also contains identification of the operating system, versions of
|
|
|
06486d |
+the RPM packages involved in the crash, and whether the program ran under a
|
|
|
06486d |
+root user.
|
|
|
06486d |
+
|
|
|
06486d |
+There are also items specific to each crash type:
|
|
|
06486d |
+
|
|
|
06486d |
+C/C++ crashes::
|
|
|
06486d |
+ these are path to the executable and signal delivered to the program,
|
|
|
06486d |
+
|
|
|
06486d |
+Python exceptions::
|
|
|
06486d |
+ there is the type of the exception (without the error message, which may
|
|
|
06486d |
+ contain sensitive data),
|
|
|
06486d |
+
|
|
|
06486d |
+for kernel oopses::
|
|
|
06486d |
+ these are list of loaded kernel modules, list of taint flags, and full text
|
|
|
06486d |
+ of the kernel oops.
|
|
|
06486d |
+
|
|
|
06486d |
+The authenticated uReports also contains *hostname* and *machineid* to enable a
|
|
|
06486d |
+server side filtering at https://access.redhat.com/.
|
|
|
06486d |
+
|
|
|
06486d |
+The authenticated uReports have the benefit of rich server replies which may
|
|
|
06486d |
+include a solution for the submitted crash. The authentication is done using
|
|
|
06486d |
+either Red Hat Subscription Certificates or Red Hat Customer Portal
|
|
|
06486d |
+credentials.
|
|
|
06486d |
+
|
|
|
06486d |
+'Warning':
|
|
|
06486d |
+The full text of a kernel oops might contain information like the
|
|
|
06486d |
+identification of the host hardware type. You should disable the autoreporting
|
|
|
06486d |
+feature if you do not want to share this information with Red Hat.
|
|
|
06486d |
+
|
|
|
06486d |
+
|
|
|
06486d |
+OPTIONS
|
|
|
06486d |
+-------
|
|
|
06486d |
+-v, --verbose::
|
|
|
06486d |
+ Be more verbose. Can be given multiple times.
|
|
|
06486d |
+
|
|
|
06486d |
+-a, --anonymous::
|
|
|
06486d |
+ Turns the authentication off by clearing both 'SSLClientAuth' and 'HTTPAuth'
|
|
|
06486d |
+ configuration options in /etc/libreport/plugins/ureport.conf
|
|
|
06486d |
+
|
|
|
06486d |
+-u, --username USERNAME::
|
|
|
06486d |
+ Turns HTTP Authentication on by setting 'HTTPAuth' configuration option to
|
|
|
06486d |
+ *rhts-credentials* in /etc/libreport/plugins/ureport.conf and storing
|
|
|
06486d |
+ USERNAME and PASSWORD in /etc/libreport/plugins/rhtsupport.conf
|
|
|
06486d |
+ Also turns the SSL Client Authentication off, because these methods cannot
|
|
|
06486d |
+ be used together.
|
|
|
06486d |
+
|
|
|
06486d |
+-p, --password PASSWORD::
|
|
|
06486d |
+ Password for HTTP Authentication. If not provided, a prompt asking for it
|
|
|
06486d |
+ will be issued.
|
|
|
06486d |
+
|
|
|
06486d |
+-c, --certificate SOURCE::
|
|
|
06486d |
+ Turns SSL Client Authentication on by setting 'SSLClientAuth' configuration
|
|
|
06486d |
+ option to SOURCE in /etc/libreport/plugins/ureport.conf.
|
|
|
06486d |
+ Also turns the HTTP Authentication off, because these methods cannot
|
|
|
06486d |
+ be used together.
|
|
|
06486d |
+
|
|
|
06486d |
+SEE ALSO
|
|
|
06486d |
+--------
|
|
|
06486d |
+abrt.conf(5), ureport.conf(5), rhtsupport.conf(5)
|
|
|
06486d |
+
|
|
|
06486d |
+AUTHORS
|
|
|
06486d |
+-------
|
|
|
06486d |
+* ABRT team
|
|
|
06486d |
diff --git a/doc/abrt-auto-reporting-unauthenticated.txt b/doc/abrt-auto-reporting-unauthenticated.txt
|
|
|
06486d |
new file mode 100644
|
|
|
06486d |
index 0000000..320c803
|
|
|
06486d |
--- /dev/null
|
|
|
06486d |
+++ b/doc/abrt-auto-reporting-unauthenticated.txt
|
|
|
06486d |
@@ -0,0 +1,71 @@
|
|
|
06486d |
+abrt-auto-reporting(1)
|
|
|
06486d |
+======================
|
|
|
06486d |
+
|
|
|
06486d |
+NAME
|
|
|
06486d |
+----
|
|
|
06486d |
+abrt-auto-reporting - Get or modify the auto reporting option values
|
|
|
06486d |
+
|
|
|
06486d |
+SYNOPSIS
|
|
|
06486d |
+--------
|
|
|
06486d |
+'abrt-auto-reporting' [-v] [ enabled | yes | 1 | on | disabled | no | 0 | off ]
|
|
|
06486d |
+
|
|
|
06486d |
+DESCRIPTION
|
|
|
06486d |
+-----------
|
|
|
06486d |
+Reads the configuration from abrt.conf and saves the changes to the same file.
|
|
|
06486d |
+
|
|
|
06486d |
+The changes will take effect immediately without necessity to restart any ABRT
|
|
|
06486d |
+process and will be persistent.
|
|
|
06486d |
+
|
|
|
06486d |
+'disabled'::
|
|
|
06486d |
+ User have to report the detect problems manually
|
|
|
06486d |
+
|
|
|
06486d |
+'enabled'::
|
|
|
06486d |
+ ABRT uploads an uReport which was generated for a detected problem
|
|
|
06486d |
+ immediately after the detection phase.
|
|
|
06486d |
+
|
|
|
06486d |
+uReport description
|
|
|
06486d |
+~~~~~~~~~~~~~~~~~~~
|
|
|
06486d |
+ABRT supports uReports for four types of crashes: crashes of C/C++ programs
|
|
|
06486d |
+that result in a core dump, uncaught Python exceptions, uncaught Java
|
|
|
06486d |
+exceptions and kernel oopses.
|
|
|
06486d |
+
|
|
|
06486d |
+Each uReport generally contains a stack trace, or multiple stack traces in the
|
|
|
06486d |
+case of multi-threaded C/C++ and Java programs. The stack trace only describes
|
|
|
06486d |
+the call stack of the program at the time of the crash and does not contain
|
|
|
06486d |
+contents of any variables.
|
|
|
06486d |
+
|
|
|
06486d |
+Every uReport also contains identification of the operating system, versions of
|
|
|
06486d |
+the RPM packages involved in the crash, and whether the program ran under a
|
|
|
06486d |
+root user.
|
|
|
06486d |
+
|
|
|
06486d |
+There are also items specific to each crash type:
|
|
|
06486d |
+
|
|
|
06486d |
+C/C++ crashes::
|
|
|
06486d |
+ these are path to the executable and signal delivered to the program,
|
|
|
06486d |
+
|
|
|
06486d |
+Python exceptions::
|
|
|
06486d |
+ there is the type of the exception (without the error message, which may
|
|
|
06486d |
+ contain sensitive data),
|
|
|
06486d |
+
|
|
|
06486d |
+for kernel oopses::
|
|
|
06486d |
+ these are list of loaded kernel modules, list of taint flags, and full text
|
|
|
06486d |
+ of the kernel oops.
|
|
|
06486d |
+
|
|
|
06486d |
+'Warning':
|
|
|
06486d |
+The full text of a kernel oops might contain information like the
|
|
|
06486d |
+identification of the host hardware type. You should disable the autoreporting
|
|
|
06486d |
+feature if you do not want to share this information with Red Hat.
|
|
|
06486d |
+
|
|
|
06486d |
+
|
|
|
06486d |
+OPTIONS
|
|
|
06486d |
+-------
|
|
|
06486d |
+-v, --verbose::
|
|
|
06486d |
+ Be more verbose. Can be given multiple times.
|
|
|
06486d |
+
|
|
|
06486d |
+SEE ALSO
|
|
|
06486d |
+--------
|
|
|
06486d |
+abrt.conf(5)
|
|
|
06486d |
+
|
|
|
06486d |
+AUTHORS
|
|
|
06486d |
+-------
|
|
|
06486d |
+* ABRT team
|
|
|
06486d |
diff --git a/doc/abrt-auto-reporting.txt b/doc/abrt-auto-reporting.txt
|
|
|
06486d |
deleted file mode 100644
|
|
|
06486d |
index 2a27945..0000000
|
|
|
06486d |
--- a/doc/abrt-auto-reporting.txt
|
|
|
06486d |
+++ /dev/null
|
|
|
06486d |
@@ -1,106 +0,0 @@
|
|
|
06486d |
-abrt-auto-reporting(1)
|
|
|
06486d |
-======================
|
|
|
06486d |
-
|
|
|
06486d |
-NAME
|
|
|
06486d |
-----
|
|
|
06486d |
-abrt-auto-reporting - Get or modify the auto reporting option values
|
|
|
06486d |
-
|
|
|
06486d |
-SYNOPSIS
|
|
|
06486d |
---------
|
|
|
06486d |
-'abrt-auto-reporting' [-v] [ enabled | yes | 1 | on | disabled | no | 0 | off ]
|
|
|
06486d |
- [ [--anonymous] |
|
|
|
06486d |
- [--username USERNAME [--password PASSWORD] ] |
|
|
|
06486d |
- [--certificate SOURCE] ]
|
|
|
06486d |
-
|
|
|
06486d |
-DESCRIPTION
|
|
|
06486d |
------------
|
|
|
06486d |
-Reads the configuration from abrt.conf and saves the changes to the same file.
|
|
|
06486d |
-
|
|
|
06486d |
-The changes will take effect immediately without necessity to restart any ABRT
|
|
|
06486d |
-process and will be persistent.
|
|
|
06486d |
-
|
|
|
06486d |
-'disabled'::
|
|
|
06486d |
- User have to report the detect problems manually
|
|
|
06486d |
-
|
|
|
06486d |
-'enabled'::
|
|
|
06486d |
- ABRT uploads an uReport which was generated for a detected problem
|
|
|
06486d |
- immediately after the detection phase.
|
|
|
06486d |
-
|
|
|
06486d |
-Reads and saves the authentication configuration options in
|
|
|
06486d |
-/etc/libreport/plugins/ureport.conf and /etc/libreport/plugins/rhtsupport.conf
|
|
|
06486d |
-
|
|
|
06486d |
-uReport description
|
|
|
06486d |
-~~~~~~~~~~~~~~~~~~~
|
|
|
06486d |
-ABRT supports uReports for four types of crashes: crashes of C/C++ programs
|
|
|
06486d |
-that result in a core dump, uncaught Python exceptions, uncaught Java
|
|
|
06486d |
-exceptions and kernel oopses.
|
|
|
06486d |
-
|
|
|
06486d |
-Each uReport generally contains a stack trace, or multiple stack traces in the
|
|
|
06486d |
-case of multi-threaded C/C++ and Java programs. The stack trace only describes
|
|
|
06486d |
-the call stack of the program at the time of the crash and does not contain
|
|
|
06486d |
-contents of any variables.
|
|
|
06486d |
-
|
|
|
06486d |
-Every uReport also contains identification of the operating system, versions of
|
|
|
06486d |
-the RPM packages involved in the crash, and whether the program ran under a
|
|
|
06486d |
-root user.
|
|
|
06486d |
-
|
|
|
06486d |
-There are also items specific to each crash type:
|
|
|
06486d |
-
|
|
|
06486d |
-C/C++ crashes::
|
|
|
06486d |
- these are path to the executable and signal delivered to the program,
|
|
|
06486d |
-
|
|
|
06486d |
-Python exceptions::
|
|
|
06486d |
- there is the type of the exception (without the error message, which may
|
|
|
06486d |
- contain sensitive data),
|
|
|
06486d |
-
|
|
|
06486d |
-for kernel oopses::
|
|
|
06486d |
- these are list of loaded kernel modules, list of taint flags, and full text
|
|
|
06486d |
- of the kernel oops.
|
|
|
06486d |
-
|
|
|
06486d |
-The authenticated uReports also contains *hostname* and *machineid* to enable a
|
|
|
06486d |
-server side filtering at https://access.redhat.com/.
|
|
|
06486d |
-
|
|
|
06486d |
-The authenticated uReports have the benefit of rich server replies which may
|
|
|
06486d |
-include a solution for the submitted crash. The authentication is done using
|
|
|
06486d |
-either Red Hat Subscription Certificates or Red Hat Customer Portal
|
|
|
06486d |
-credentials.
|
|
|
06486d |
-
|
|
|
06486d |
-'Warning':
|
|
|
06486d |
-The full text of a kernel oops might contain information like the
|
|
|
06486d |
-identification of the host hardware type. You should disable the autoreporting
|
|
|
06486d |
-feature if you do not want to share this information with Red Hat.
|
|
|
06486d |
-
|
|
|
06486d |
-
|
|
|
06486d |
-OPTIONS
|
|
|
06486d |
--------
|
|
|
06486d |
--v, --verbose::
|
|
|
06486d |
- Be more verbose. Can be given multiple times.
|
|
|
06486d |
-
|
|
|
06486d |
--a, --anonymous::
|
|
|
06486d |
- Turns the authentication off by clearing both 'SSLClientAuth' and 'HTTPAuth'
|
|
|
06486d |
- configuration options in /etc/libreport/plugins/ureport.conf
|
|
|
06486d |
-
|
|
|
06486d |
--u, --username USERNAME::
|
|
|
06486d |
- Turns HTTP Authentication on by setting 'HTTPAuth' configuration option to
|
|
|
06486d |
- *rhts-credentials* in /etc/libreport/plugins/ureport.conf and storing
|
|
|
06486d |
- USERNAME and PASSWORD in /etc/libreport/plugins/rhtsupport.conf
|
|
|
06486d |
- Also turns the SSL Client Authentication off, because these methods cannot
|
|
|
06486d |
- be used together.
|
|
|
06486d |
-
|
|
|
06486d |
--p, --password PASSWORD::
|
|
|
06486d |
- Password for HTTP Authentication. If not provided, a prompt asking for it
|
|
|
06486d |
- will be issued.
|
|
|
06486d |
-
|
|
|
06486d |
--c, --certificate SOURCE::
|
|
|
06486d |
- Turns SSL Client Authentication on by setting 'SSLClientAuth' configuration
|
|
|
06486d |
- option to SOURCE in /etc/libreport/plugins/ureport.conf.
|
|
|
06486d |
- Also turns the HTTP Authentication off, because these methods cannot
|
|
|
06486d |
- be used together.
|
|
|
06486d |
-
|
|
|
06486d |
-SEE ALSO
|
|
|
06486d |
---------
|
|
|
06486d |
-abrt.conf(5), ureport.conf(5), rhtsupport.conf(5)
|
|
|
06486d |
-
|
|
|
06486d |
-AUTHORS
|
|
|
06486d |
--------
|
|
|
06486d |
-* ABRT team
|
|
|
06486d |
diff --git a/src/daemon/abrt-auto-reporting.c b/src/daemon/abrt-auto-reporting.c
|
|
|
06486d |
index 573c1ae..46f8923 100644
|
|
|
06486d |
--- a/src/daemon/abrt-auto-reporting.c
|
|
|
06486d |
+++ b/src/daemon/abrt-auto-reporting.c
|
|
|
06486d |
@@ -66,6 +66,7 @@ set_abrt_reporting(map_string_t *conf, const char *opt_value)
|
|
|
06486d |
return 1;
|
|
|
06486d |
}
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
static int
|
|
|
06486d |
set_ureport_http_auth(map_string_t *conf, const char *opt_value)
|
|
|
06486d |
{
|
|
|
06486d |
@@ -136,6 +137,7 @@ set_rhts_credentials(map_string_t *conf, const char *username, const char *passw
|
|
|
06486d |
/* No changes needed -> success */
|
|
|
06486d |
return 1;
|
|
|
06486d |
}
|
|
|
06486d |
+#endif
|
|
|
06486d |
|
|
|
06486d |
static const char *
|
|
|
06486d |
get_abrt_reporting(map_string_t *conf)
|
|
|
06486d |
@@ -145,6 +147,7 @@ get_abrt_reporting(map_string_t *conf)
|
|
|
06486d |
return REPORTING_STATES[index][0];
|
|
|
06486d |
}
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
static const char *
|
|
|
06486d |
get_ureport_http_auth(map_string_t *conf)
|
|
|
06486d |
{
|
|
|
06486d |
@@ -156,6 +159,7 @@ get_ureport_client_auth(map_string_t *conf)
|
|
|
06486d |
{
|
|
|
06486d |
return get_map_string_item_or_NULL(conf, UREPORT_CLIENT_AUTH_OPTION);
|
|
|
06486d |
}
|
|
|
06486d |
+#endif
|
|
|
06486d |
|
|
|
06486d |
int main(int argc, char *argv[])
|
|
|
06486d |
{
|
|
|
06486d |
@@ -173,57 +177,78 @@ int main(int argc, char *argv[])
|
|
|
06486d |
textdomain(PACKAGE);
|
|
|
06486d |
#endif
|
|
|
06486d |
|
|
|
06486d |
+#define PROGRAM_USAGE_MIDDLE_PART \
|
|
|
06486d |
+ "\n" \
|
|
|
06486d |
+ "Get or modify a value of the auto-reporting option. The changes will take\n" \
|
|
|
06486d |
+ "effect immediately and will be persistent.\n" \
|
|
|
06486d |
+ "\n" \
|
|
|
06486d |
+ ""STATE_MANUAL":\n" \
|
|
|
06486d |
+ "User have to report the detect problems manually\n" \
|
|
|
06486d |
+ "\n" \
|
|
|
06486d |
+ ""STATE_AUTO":\n" \
|
|
|
06486d |
+ "ABRT uploads an uReport which was generated for a detected problem\n" \
|
|
|
06486d |
+ "immediately after the detection phase. uReport generally contains a stack\n" \
|
|
|
06486d |
+ "trace which only describes the call stack of the program at the time of the\n" \
|
|
|
06486d |
+ "crash and does not contain contents of any variables. Every uReport also\n" \
|
|
|
06486d |
+ "contains identification of the operating system, versions of the RPM packages\n" \
|
|
|
06486d |
+ "involved in the crash, and whether the program ran under a root user.\n" \
|
|
|
06486d |
+ "\n"
|
|
|
06486d |
+
|
|
|
06486d |
abrt_init(argv);
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
const char *program_usage_string = _(
|
|
|
06486d |
"& [ "STATE_MANUAL" | "STATE_AUTO" | yes | no | 1 | 0 ] \\\n"
|
|
|
06486d |
" [[--anonymous] | [--username USERNAME [--password PASSWORD]] | [--certificate SOURCE]]\n"
|
|
|
06486d |
- "\n"
|
|
|
06486d |
- "Get or modify a value of the auto-reporting option. The changes will take\n"
|
|
|
06486d |
- "effect immediately and will be persistent.\n"
|
|
|
06486d |
- "\n"
|
|
|
06486d |
- ""STATE_MANUAL":\n"
|
|
|
06486d |
- "User have to report the detect problems manually\n"
|
|
|
06486d |
- "\n"
|
|
|
06486d |
- ""STATE_AUTO":\n"
|
|
|
06486d |
- "ABRT uploads an uReport which was generated for a detected problem\n"
|
|
|
06486d |
- "immediately after the detection phase. uReport generally contains a stack\n"
|
|
|
06486d |
- "trace which only describes the call stack of the program at the time of the\n"
|
|
|
06486d |
- "crash and does not contain contents of any variables. Every uReport also\n"
|
|
|
06486d |
- "contains identification of the operating system, versions of the RPM packages\n"
|
|
|
06486d |
- "involved in the crash, and whether the program ran under a root user.\n"
|
|
|
06486d |
- "\n"
|
|
|
06486d |
+ PROGRAM_USAGE_MIDDLE_PART
|
|
|
06486d |
"See abrt-auto-reporting(1), reporter-ureport(1) and reporter-rhtsupport(1)\n"
|
|
|
06486d |
"for more details.\n"
|
|
|
06486d |
);
|
|
|
06486d |
+#else
|
|
|
06486d |
+ const char *program_usage_string = _(
|
|
|
06486d |
+ "& [ "STATE_MANUAL" | "STATE_AUTO" | yes | no | 1 | 0 ]\n"
|
|
|
06486d |
+ PROGRAM_USAGE_MIDDLE_PART
|
|
|
06486d |
+ "See abrt-auto-reporting(1) and reporter-ureport(1) for more details.\n"
|
|
|
06486d |
+ );
|
|
|
06486d |
+#endif
|
|
|
06486d |
|
|
|
06486d |
enum {
|
|
|
06486d |
OPT_v = 1 << 0,
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
OPT_a = 1 << 1,
|
|
|
06486d |
OPT_u = 1 << 2,
|
|
|
06486d |
OPT_p = 1 << 3,
|
|
|
06486d |
OPT_c = 1 << 4,
|
|
|
06486d |
+#endif
|
|
|
06486d |
};
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
int anonymous = 0;
|
|
|
06486d |
const char *username = NULL;
|
|
|
06486d |
const char *password = NULL;
|
|
|
06486d |
const char *certificate = NULL;
|
|
|
06486d |
+#endif
|
|
|
06486d |
|
|
|
06486d |
/* Keep enum above and order of options below in sync! */
|
|
|
06486d |
struct options program_options[] = {
|
|
|
06486d |
OPT__VERBOSE(&g_verbose),
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
OPT_BOOL ( 'a', "anonymous", &anonymous, _("Turns the authentication off")),
|
|
|
06486d |
OPT_STRING( 'u', "username", &username, "USERNAME", _("Red Hat Support user name")),
|
|
|
06486d |
OPT_STRING( 'p', "password", &password, "PASSWORD", _("Red Hat Support password, if not given, a prompt for it will be issued")),
|
|
|
06486d |
OPT_STRING( 'c', "certificate", &certificate, "SOURCE", _("uReport SSL certificate paths or certificate type")),
|
|
|
06486d |
+#endif
|
|
|
06486d |
OPT_END()
|
|
|
06486d |
};
|
|
|
06486d |
|
|
|
06486d |
- const unsigned opts = parse_opts(argc, argv, program_options, program_usage_string);
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
+ const unsigned opts =
|
|
|
06486d |
+#endif
|
|
|
06486d |
+ parse_opts(argc, argv, program_options, program_usage_string);
|
|
|
06486d |
|
|
|
06486d |
argv += optind;
|
|
|
06486d |
argc -= optind;
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
if ((opts & OPT_p) && !(opts & OPT_u))
|
|
|
06486d |
{
|
|
|
06486d |
error_msg(_("You also need to specify --username for --password"));
|
|
|
06486d |
@@ -248,6 +273,7 @@ int main(int argc, char *argv[])
|
|
|
06486d |
show_usage_and_die(program_usage_string, program_options);
|
|
|
06486d |
}
|
|
|
06486d |
|
|
|
06486d |
+#endif
|
|
|
06486d |
if (argc > 1)
|
|
|
06486d |
{
|
|
|
06486d |
error_msg(_("Invalid number of arguments"));
|
|
|
06486d |
@@ -277,20 +303,25 @@ int main(int argc, char *argv[])
|
|
|
06486d |
int exit_code = EXIT_FAILURE;
|
|
|
06486d |
|
|
|
06486d |
map_string_t *conf = new_map_string();
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
map_string_t *rhts_conf = new_map_string();
|
|
|
06486d |
map_string_t *rhts_conf_bck = NULL;
|
|
|
06486d |
+#endif
|
|
|
06486d |
map_string_t *ureport_conf = new_map_string();
|
|
|
06486d |
map_string_t *ureport_conf_bck = NULL;
|
|
|
06486d |
|
|
|
06486d |
if (!load_abrt_conf_file(CONF_NAME, conf))
|
|
|
06486d |
goto finito;
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
if (!load_plugin_conf_file(RHTS_NAME, rhts_conf, false))
|
|
|
06486d |
goto finito;
|
|
|
06486d |
+#endif
|
|
|
06486d |
|
|
|
06486d |
if (!load_plugin_conf_file(UREPORT_NAME, ureport_conf, false))
|
|
|
06486d |
goto finito;
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
if ((opts & OPT_a))
|
|
|
06486d |
{
|
|
|
06486d |
ureport_conf_bck = clone_map_string(ureport_conf);
|
|
|
06486d |
@@ -336,11 +367,13 @@ int main(int argc, char *argv[])
|
|
|
06486d |
goto finito;
|
|
|
06486d |
}
|
|
|
06486d |
|
|
|
06486d |
+#endif
|
|
|
06486d |
if (argc == 0)
|
|
|
06486d |
{
|
|
|
06486d |
printf("%s", get_abrt_reporting(conf));
|
|
|
06486d |
exit_code = EXIT_SUCCESS;
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
if (g_verbose >= 1)
|
|
|
06486d |
{
|
|
|
06486d |
const char *tmp = get_ureport_http_auth(ureport_conf);
|
|
|
06486d |
@@ -352,7 +385,7 @@ int main(int argc, char *argv[])
|
|
|
06486d |
else
|
|
|
06486d |
printf(" %s", _("anonymous auto reporting"));
|
|
|
06486d |
}
|
|
|
06486d |
-
|
|
|
06486d |
+#endif
|
|
|
06486d |
putchar('\n');
|
|
|
06486d |
|
|
|
06486d |
goto finito;
|
|
|
06486d |
@@ -371,16 +404,20 @@ int main(int argc, char *argv[])
|
|
|
06486d |
if (ureport_conf_bck != NULL)
|
|
|
06486d |
save_plugin_conf_file(UREPORT_NAME, ureport_conf_bck);
|
|
|
06486d |
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
if (rhts_conf_bck != NULL)
|
|
|
06486d |
save_plugin_conf_file(RHTS_NAME, rhts_conf_bck);
|
|
|
06486d |
+#endif
|
|
|
06486d |
}
|
|
|
06486d |
|
|
|
06486d |
|
|
|
06486d |
finito:
|
|
|
06486d |
free_map_string(ureport_conf);
|
|
|
06486d |
free_map_string(ureport_conf_bck);
|
|
|
06486d |
+#if AUTHENTICATED_AUTOREPORTING != 0
|
|
|
06486d |
free_map_string(rhts_conf);
|
|
|
06486d |
free_map_string(rhts_conf_bck);
|
|
|
06486d |
+#endif
|
|
|
06486d |
free_map_string(conf);
|
|
|
06486d |
return exit_code;
|
|
|
06486d |
}
|
|
|
06486d |
--
|
|
|
06486d |
2.4.3
|
|
|
06486d |
|