Description: Enable running of cups-pk-helper as cups-pk-helper Enable running of cups-pk-helper as cups-pk-helper by adding annotations to the policy fie and adding --with-daemon-user to configure.ac to make the cups-pk-helper dbus service run as cups-pk-helper. . cups-pk-helper (0.2.6-1ubuntu2) zesty; urgency=medium . * debian/patches/run_as_cups-pk-helper.patch - Make the cups-pk-helper run as cups-pk-helper passing cups-pk-helper as user too. * debian/cups-pk-helper.postinst: - Add cups-pk-helper group and user. * debian/cups-pk-helper.postrm: - Remove cups-pk-helper user and group. * Added --with-daemon-user Author: Shem Pasamba --- The information above should follow the Patch Tagging Guidelines, please checkout http://dep.debian.net/deps/dep3/ to learn about the format. Here are templates for supplementary fields that you might want to add: Origin: , Bug: Bug-Debian: https://bugs.debian.org/ Bug-Ubuntu: https://launchpad.net/bugs/ Forwarded: Reviewed-By: Last-Update: 2017-07-12 --- cups-pk-helper-0.2.6.orig/configure.ac +++ cups-pk-helper-0.2.6/configure.ac @@ -54,6 +54,17 @@ AC_SUBST(CUPS_LIBS) AC_PATH_PROG([GDBUS_CODEGEN], [gdbus-codegen]) +# custom daemon user +AC_ARG_WITH( + [daemon_user], + AC_HELP_STRING([--with-daemon-user], + [User for running the cups-pk-helper dbus service (default: root)]), + [daemon_user=$withval], + [daemon_user=root] +) +AC_SUBST(daemon_user) +AC_DEFINE_UNQUOTED([DAEMON_USER], ["$daemon_user"], [Daemon user]) + AC_OUTPUT([ Makefile src/Makefile --- cups-pk-helper-0.2.6.orig/po/POTFILES.in +++ cups-pk-helper-0.2.6/po/POTFILES.in @@ -2,3 +2,4 @@ # Please keep this file sorted alphabetically. [encoding: UTF-8] src/org.opensuse.cupspkhelper.mechanism.policy.in +src/org.opensuse.cupspkhelper.mechanism.policy.in.in --- cups-pk-helper-0.2.6.orig/src/Makefile.am +++ cups-pk-helper-0.2.6/src/Makefile.am @@ -67,7 +67,14 @@ dbus_services_in_files = org.opensuse.Cu dbus_services_DATA = $(dbus_services_in_files:.service.in=.service) $(dbus_services_DATA): $(dbus_services_in_files) - $(AM_V_GEN)sed -e "s|\@LIBEXECDIR\@|$(libexecdir)|" $< > $@ + $(AM_V_GEN)sed -e "s|\@LIBEXECDIR\@|$(libexecdir)|" -e "s|\@DAEMON_USER\@|$(daemon_user)|" $< > $@ + +org.opensuse.cupspkhelper.mechanism.policy.in: org.opensuse.cupspkhelper.mechanism.policy.in.in Makefile + $(AM_V_GEN)if test "x$(daemon_user)" != "xroot"; then \ + sed -e "s||unix-user:$(daemon_user)|g" $< > $@ ; \ + else \ + sed -e "/^\s*\s*$$/d;s|||g" $< > $@ ; \ + fi polkitdir = $(datadir)/polkit-1/actions polkit_in_files = org.opensuse.cupspkhelper.mechanism.policy.in --- cups-pk-helper-0.2.6.orig/src/org.opensuse.CupsPkHelper.Mechanism.service.in +++ cups-pk-helper-0.2.6/src/org.opensuse.CupsPkHelper.Mechanism.service.in @@ -1,4 +1,4 @@ [D-BUS Service] Name=org.opensuse.CupsPkHelper.Mechanism Exec=@LIBEXECDIR@/cups-pk-helper-mechanism -User=root +User=@DAEMON_USER@ --- /dev/null +++ cups-pk-helper-0.2.6/src/org.opensuse.cupspkhelper.mechanism.policy.in.in @@ -0,0 +1,138 @@ + + + + + The openSUSE Project + http://www.opensuse.org/ + printer + + + <_description>Get/Set server settings + <_message>Privileges are required to get/set server settings. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Get list of available devices + <_message>Privileges are required to get list of available devices. + + auth_admin + auth_admin + auth_admin_keep + + + + + + + <_description>Set a printer as default printer + <_message>Privileges are required to set a printer, or a class, as default printer. + + auth_admin + auth_admin + auth_admin_keep + + + + + + + <_description>Enable/Disable a printer + <_message>Privileges are required to enable/disable a printer, or a class. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Add/Remove/Edit a local printer + <_message>Privileges are required to add/remove/edit a local printer. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Add/Remove/Edit a remote printer + <_message>Privileges are required to add/remove/edit a remote printer. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Add/Remove/Edit a class + <_message>Privileges are required to add/remove/edit a class. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Restart/Cancel/Edit a job + <_message>Privileges are required to restart/cancel/edit a job. + + auth_admin + auth_admin + yes + + + + + + <_description>Restart/Cancel/Edit a job owned by another user + <_message>Privileges are required to restart/cancel/edit a job owned by another user. + + auth_admin + auth_admin + auth_admin_keep + + + + + + <_description>Change printer settings + <_message>Privileges are required to change printer settings. This should only be needed from the Printers system settings panel. + + auth_admin + auth_admin + auth_admin_keep + + + + + + + <_description>Add/Remove/Edit a printer + <_message>Privileges are required to add/remove/edit a printer. + + auth_admin + auth_admin + auth_admin_keep + + + +