Begin support of org. freedesktop.DBus.Peer (GetMachineId)

This commit is contained in:
Jaidyn Ann 2023-04-19 11:02:00 -05:00
parent 9675c880d9
commit bbc45c527e

View File

@ -15,7 +15,7 @@
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;
(import (prefix dbus dbus:) sxml-serializer)
(import (chicken io) srfi-13 (prefix dbus dbus:) sxml-serializer)
;; Debugging
@ -107,20 +107,39 @@
;; DBUS generally
;; —————————————————————————————————————
;; Creates an Introspectable interface for the given path, given a list
;; of interfaces and subnodes.
;; Definition of org.freedesktop.DBus.Introspectable, in
;; `introspect-interface-sxml`-compliant format.
(define *introspectable-interface*
'("org.freedesktop.DBus.Introspectable"
. (("Introspect"
. (((direction . "out")
(type . "s")
(name . "xml_data")))))))
;; Definition of org.freedesktop.DBus.Peer, in
;; `introspect-interface-sxml`-compliant format.
(define *peer-interface*
'("org.freedesktop.DBus.Peer"
. (("GetMachineId"
. (((direction . "out")
(type . "s")
(name . "machine_uuid")))))))
;; Creates an org.freedesktop.DBus.Introspectable interface for the given
;; path, given a list of interfaces and subnodes.
;; Subnodes ought be a list of names e.g., '(subnode-a subnode-b), but
;; interfaces ought be in a specific format; see the comment on
;; `introspect-interface-sxml` for details.
(define-syntax handle-introspection-for-path
(syntax-rules ()
((handle-introspection-for-path node-path interfaces subnodes)
(let* ([xml
(introspect-node-xml
(list
(append '("org.freedesktop.DBus.Introspectable"
. (("Introspect"
. (((direction . "out")
(type . "s")
(name . "xml_data"))))))
interfaces))
(append
(list *introspectable-interface*)
interfaces)
subnodes)]
[context
(dbus:make-context bus: dbus:session-bus
@ -131,12 +150,34 @@
(lambda () xml))))))
;; Creates a org.freedesktop.DBus.Peer interface along the given path.
(define-syntax handle-peers-for-path
(syntax-rules ()
[(handle-peers-for-path node-path)
(let ([machine-id
(string-delete #\newline
(call-with-input-file "/var/lib/dbus/machine-id"
(lambda (in-port)
(read-string #f in-port))))]
[context
(dbus:make-context bus: dbus:session-bus
service: 'org.jadedctrl.secrettabero
interface: 'org.freedesktop.DBus.Peer
path: node-path)])
(dbus:register-method context "Ping"
(lambda () '()))
(dbus:register-method context "GetMachineId"
(lambda () machine-id)))]))
;; —————————————————————————————————————
;; DBUS Path: /
;; —————————————————————————————————————
(handle-introspection-for-path '/ '() '(org))
(handle-peers-for-path '/)
(handle-introspection-for-path '/ (list *peer-interface*) '(org))
@ -144,7 +185,8 @@
;; DBUS Path: /org/
;; —————————————————————————————————————
(handle-introspection-for-path '/org '() '(freedesktop))
(handle-peers-for-path '/org)
(handle-introspection-for-path '/org (list *peer-interface*) '(freedesktop))
@ -152,7 +194,8 @@
;; DBUS Path: /org/freedesktop/
;; —————————————————————————————————————
(handle-introspection-for-path '/org/freedesktop '() '(secrets))
(handle-peers-for-path '/org/freedesktop)
(handle-introspection-for-path '/org/freedesktop (list *peer-interface*) '(secrets))
@ -160,7 +203,8 @@
;; DBUS Path: /org/freedesktop/secrets
;; —————————————————————————————————————
(handle-introspection-for-path '/org/freedesktop/secrets '() '())
(handle-peers-for-path '/org/freedesktop/secrets)
(handle-introspection-for-path '/org/freedesktop/secrets (list *peer-interface*) '())
@ -174,4 +218,3 @@
(dbus:poll-for-message)
(loop))