services: 'polkit-service-type' can now be extended.

* gnu/packages/polkit.scm (polkit)[source]: Adjust snippet so that rules
  and actions are looked for under /etc/polkit-1.
* gnu/services/desktop.scm (<polkit-configuration>): New record type.
  (polkit-directory, polkit-etc-files, polkit-setuid-programs): New
  procedures.
  (polkit-service-type)[compose, extend]: New fields.
  (polkit-service): Refine docstring.
  (colord-service-type): Extend POLKIT-SERVICE-TYPE.
  (elogind-configuration-file): Extend POLKIT-SERVICE-TYPE.
* doc/guix.texi (Desktop Services): Update 'polkit-service'
  documentation.
This commit is contained in:
Ludovic Courtès 2015-11-01 17:19:33 +01:00
parent 67010dd886
commit 222e3319bd
3 changed files with 125 additions and 72 deletions

View File

@ -6716,12 +6716,13 @@ their default values are:
@deffn {Scheme Procedure} polkit-service @ @deffn {Scheme Procedure} polkit-service @
[#:polkit @var{polkit}] [#:polkit @var{polkit}]
Return a service that runs the Polkit privilege manager. Return a service that runs the
@uref{http://www.freedesktop.org/wiki/Software/polkit/, Polkit} allows @uref{http://www.freedesktop.org/wiki/Software/polkit/, Polkit privilege
system administrators to grant access to privileged operations in a management service}, which allows system administrators to grant access to
structured way. For example, polkit rules can allow a logged-in user privileged operations in a structured way. By querying the Polkit service, a
whose session is active to shut down the machine, if there are no other privileged system component can know when it should grant additional
users active. capabilities to ordinary users. For example, an ordinary user can be granted
the capability to suspend the system if the user is logged in locally.
@end deffn @end deffn
@deffn {Scheme Procedure} upower-service [#:upower @var{upower}] @ @deffn {Scheme Procedure} upower-service [#:upower @var{upower}] @

View File

@ -65,18 +65,16 @@
(substitute* "src/polkitbackend/polkitbackendjsauthority.c" (substitute* "src/polkitbackend/polkitbackendjsauthority.c"
(("systemd") "elogind")) (("systemd") "elogind"))
(substitute* "src/polkitagent/polkitagentsession.c" ;; GuixSD's polkit service stores actions under
(("PACKAGE_PREFIX \"/lib/polkit-1/polkit-agent-helper-1\"") ;; /etc/polkit-1/actions.
"\"/run/setuid-programs/polkit-agent-helper-1\""))
(substitute* "src/polkitbackend/polkitbackendinteractiveauthority.c" (substitute* "src/polkitbackend/polkitbackendinteractiveauthority.c"
(("PACKAGE_DATA_DIR \"/polkit-1/actions\"") (("PACKAGE_DATA_DIR \"/polkit-1/actions\"")
"\"/run/current-system/profile/share/polkit-1/actions\"")) "PACKAGE_SYSCONF_DIR \"/polkit-1/actions\""))
(substitute* "src/polkitbackend/polkitbackendjsauthority.c"
(("PACKAGE_SYSCONF_DIR \"/polkit-1/rules.d\"") ;; Set the setuid helper's real location.
"\"/run/current-system/profile/etc/polkit-1/rules.d\"")) (substitute* "src/polkitagent/polkitagentsession.c"
(substitute* "src/polkitbackend/polkitbackendjsauthority.c" (("PACKAGE_PREFIX \"/lib/polkit-1/polkit-agent-helper-1\"")
(("PACKAGE_DATA_DIR \"/polkit-1/rules.d\"") "\"/run/setuid-programs/polkit-agent-helper-1\""))))))
"\"/run/current-system/profile/share/polkit-1/rules.d\""))))))
(build-system gnu-build-system) (build-system gnu-build-system)
(inputs (inputs
`(("expat" ,expat) `(("expat" ,expat)

View File

@ -224,52 +224,6 @@ levels, with the given configuration settings. It implements the
(critical-power-action critical-power-action)))) (critical-power-action critical-power-action))))
(service upower-service-type config))) (service upower-service-type config)))
;;;
;;; Colord D-Bus service.
;;;
(define %colord-activation
#~(begin
(use-modules (guix build utils))
(mkdir-p "/var/lib/colord")
(let ((user (getpwnam "colord")))
(chown "/var/lib/colord"
(passwd:uid user) (passwd:gid user)))))
(define %colord-accounts
(list (user-group (name "colord") (system? #t))
(user-account
(name "colord")
(group "colord")
(system? #t)
(comment "colord daemon user")
(home-directory "/var/empty")
(shell #~(string-append #$shadow "/sbin/nologin")))))
(define colord-service-type
(service-type (name 'colord)
(extensions
(list (service-extension account-service-type
(const %colord-accounts))
(service-extension activation-service-type
(const %colord-activation))
;; Colord is a D-Bus service that dbus-daemon can
;; activate.
(service-extension dbus-root-service-type list)
;; Colord provides "color device" rules for udev.
(service-extension udev-service-type list)))))
(define* (colord-service #:key (colord colord))
"Return a service that runs @command{colord}, a system service with a D-Bus
interface to manage the color profiles of input and output devices such as
screens and scanners. It is notably used by the GNOME Color Manager graphical
tool. See @uref{http://www.freedesktop.org/software/colord/, the colord web
site} for more information."
(service colord-service-type colord))
;;; ;;;
;;; GeoClue D-Bus service. ;;; GeoClue D-Bus service.
@ -383,6 +337,14 @@ site} for more information."
;;; Polkit privilege management service. ;;; Polkit privilege management service.
;;; ;;;
(define-record-type* <polkit-configuration>
polkit-configuration make-polkit-configuration
polkit-configuration?
(polkit polkit-configuration-polkit ;<package>
(default polkit))
(actions polkit-configuration-actions ;list of <package>
(default '())))
(define %polkit-accounts (define %polkit-accounts
(list (user-group (name "polkitd") (system? #t)) (list (user-group (name "polkitd") (system? #t))
(user-account (user-account
@ -396,9 +358,31 @@ site} for more information."
(define %polkit-pam-services (define %polkit-pam-services
(list (unix-pam-service "polkitd"))) (list (unix-pam-service "polkitd")))
(define (polkit-directory packages)
"Return a directory containing an @file{actions} and possibly a
@file{rules.d} sub-directory, for use as @file{/etc/polkit-1}."
(computed-file "etc-polkit-1"
#~(begin
(use-modules (guix build union) (srfi srfi-26))
(union-build #$output
(map (cut string-append <>
"/share/polkit-1")
(list #$@packages))))
#:modules '((guix build union))))
(define polkit-etc-files
(match-lambda
(($ <polkit-configuration> polkit packages)
`(("polkit-1" ,(polkit-directory packages))))))
(define polkit-setuid-programs
(match-lambda
(($ <polkit-configuration> polkit)
(list #~(string-append #$polkit
"/lib/polkit-1/polkit-agent-helper-1")))))
(define polkit-service-type (define polkit-service-type
;; TODO: Make it extensible so it can collect policy files from other
;; services.
(service-type (name 'polkit) (service-type (name 'polkit)
(extensions (extensions
(list (service-extension account-service-type (list (service-extension account-service-type
@ -406,15 +390,83 @@ site} for more information."
(service-extension pam-root-service-type (service-extension pam-root-service-type
(const %polkit-pam-services)) (const %polkit-pam-services))
(service-extension dbus-root-service-type (service-extension dbus-root-service-type
list))))) (compose
list
polkit-configuration-polkit))
(service-extension etc-service-type
polkit-etc-files)
(service-extension setuid-program-service-type
polkit-setuid-programs)))
;; Extensions are lists of packages that provide polkit rules
;; or actions under share/polkit-1/{actions,rules.d}.
(compose concatenate)
(extend (lambda (config actions)
(polkit-configuration
(inherit config)
(actions
(append (polkit-configuration-actions config)
actions)))))))
(define* (polkit-service #:key (polkit polkit)) (define* (polkit-service #:key (polkit polkit))
"Return a service that runs the @command{polkit} privilege management "Return a service that runs the
service. By querying the @command{polkit} service, a privileged system @uref{http://www.freedesktop.org/wiki/Software/polkit/, Polkit privilege
component can know when it should grant additional capabilities to ordinary management service}, which allows system administrators to grant access to
users. For example, an ordinary user can be granted the capability to suspend privileged operations in a structured way. By querying the Polkit service, a
the system if the user is logged in locally." privileged system component can know when it should grant additional
(service polkit-service-type polkit)) capabilities to ordinary users. For example, an ordinary user can be granted
the capability to suspend the system if the user is logged in locally."
(service polkit-service-type
(polkit-configuration (polkit polkit))))
;;;
;;; Colord D-Bus service.
;;;
(define %colord-activation
#~(begin
(use-modules (guix build utils))
(mkdir-p "/var/lib/colord")
(let ((user (getpwnam "colord")))
(chown "/var/lib/colord"
(passwd:uid user) (passwd:gid user)))))
(define %colord-accounts
(list (user-group (name "colord") (system? #t))
(user-account
(name "colord")
(group "colord")
(system? #t)
(comment "colord daemon user")
(home-directory "/var/empty")
(shell #~(string-append #$shadow "/sbin/nologin")))))
(define colord-service-type
(service-type (name 'colord)
(extensions
(list (service-extension account-service-type
(const %colord-accounts))
(service-extension activation-service-type
(const %colord-activation))
;; Colord is a D-Bus service that dbus-daemon can
;; activate.
(service-extension dbus-root-service-type list)
;; Colord provides "color device" rules for udev.
(service-extension udev-service-type list)
;; It provides polkit "actions".
(service-extension polkit-service-type list)))))
(define* (colord-service #:key (colord colord))
"Return a service that runs @command{colord}, a system service with a D-Bus
interface to manage the color profiles of input and output devices such as
screens and scanners. It is notably used by the GNOME Color Manager graphical
tool. See @uref{http://www.freedesktop.org/software/colord/, the colord web
site} for more information."
(service colord-service-type colord))
;;; ;;;
@ -581,7 +633,9 @@ the system if the user is logged in locally."
(compose list elogind-package)) (compose list elogind-package))
(service-extension udev-service-type (service-extension udev-service-type
(compose list elogind-package)) (compose list elogind-package))
;; TODO: Extend polkit(?) and PAM. (service-extension polkit-service-type
(compose list elogind-package))
;; TODO: Extend PAM with pam_elogind.so.
)))) ))))
(define* (elogind-service #:key (config (elogind-configuration))) (define* (elogind-service #:key (config (elogind-configuration)))