-
Notifications
You must be signed in to change notification settings - Fork 29
/
protocols.lisp
170 lines (130 loc) · 5.82 KB
/
protocols.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
;;;; +----------------------------------------------------------------+
;;;; | DBUS |
;;;; +----------------------------------------------------------------+
(defpackage #:dbus/protocols
(:use #:cl)
(:export
#:server-address
#:server-address-transport-name
#:server-address-property
#:open-connection
#:connection
#:connection-server-address
#:connection-server-uuid
#:connection-fd
#:connection-pending-messages
#:connection-next-serial
#:drain-pending-messages
#:close-connection
#:wait-for-reply
#:receive-message-no-hang
#:receive-line
#:send-message
#:send-line
#:supported-authentication-mechanisms
#:authenticate
#:supports-unix-fd-passing-p
#:authentication-mechanism
#:authentication-mechanism-name
#:authentication-mechanism-textual-p
#:feed-authentication-mechanism))
(in-package #:dbus/protocols)
;;;; Server address protocol
(defclass server-address ()
()
(:documentation "Represents a DBUS server address, consisting of a
transport name and zero or more properties."))
(defgeneric server-address-transport-name (server-address)
(:documentation "Return the transport name for the server
address."))
(defgeneric server-address-property (name server-address &key if-does-not-exist)
(:documentation "Return the value of the server address's property
with the supplied name."))
(defgeneric open-connection (event-base server-address &key if-failed)
(:documentation "Open a connection to the server designated by the
server address and return a connection object. The default value for
IF-FAILED is :ERROR. An IOLIB event base object must be passed.
Should also send the initial \"nul byte\"."))
;;;; Connection protocol
(defclass connection ()
()
(:documentation "Represents a DBUS connection to a server."))
(defgeneric connection-server-address (connection)
(:documentation "Return the address of the server associated with
the connection."))
(defgeneric connection-server-uuid (connection)
(:documentation "Return the unique ID of the server associated with
the connection."))
(defgeneric (setf connection-server-uuid) (uuid connection)
(:documentation "Set the unique ID of the server associated with the
connection. If an ID is already set and is not EQUAL to the new ID,
signal a continuable error."))
(defgeneric connection-fd (connection)
(:documentation "Return the file descriptor associated with
the (open) connection."))
(defgeneric connection-pending-messages (connection)
(:documentation "Return a list of the currently pending messages
associated with the connection, from newest to oldest."))
(defgeneric (setf connection-pending-messages) (new-list connection)
(:documentation "Set the list of currently pending messages
associated with the connection."))
(defgeneric connection-next-serial (connection)
(:documentation "Return a 32-bit integer for associating request
messages and their replies."))
(defgeneric drain-pending-messages (connection)
(:documentation "Return a list of the currently pending messages
associated with the connection, from oldest to newest, and consider
these messages no longer pending."))
(defgeneric close-connection (connection)
(:documentation "Close an open connection."))
(defgeneric wait-for-reply (serial connection)
(:documentation "Wait for a reply message with the supplied serial
to be received via connection."))
(defgeneric receive-message-no-hang (connection)
(:documentation "Read a D-BUS message from the server. If no
message is available to read, return NIL."))
(defgeneric receive-line (connection)
(:documentation "Read a line of text from the server and return it as
a string. The operation blocks until a whole line can be read. The
string will not contain newline characters."))
(defgeneric send-message (encoded-message connection)
(:documentation "Send an encoded message to the server. The
operation will force (but not finish) output before returning."))
(defgeneric send-line (line connection)
(:documentation "Send a line of text, represented by a string, to
the server. The operation will force (but not finish) output before
returning. The string should not contain any newline characters."))
(defgeneric supported-authentication-mechanisms (connection)
(:documentation "Return a list of authentication mechanisms
supported by the server."))
(defgeneric authenticate (authentication-mechanisms connection &key if-failed)
(:documentation "Attempt to authenticate with the server associated
with the connection, and return true if successful. The default value
for IF-FAILED is :ERROR."))
(defgeneric supports-unix-fd-passing-p (connection)
(:documentation "Return true if Unix file descriptors can be passed
over the connection, and false otherwise."))
;;;; Authentication mechanism protocol
(defclass authentication-mechanism ()
()
(:documentation "Represents a way to authenticate a client with a
server."))
(defgeneric authentication-mechanism-name (authentication-mechanism)
(:documentation "Return the name for the authentication
mechanism."))
(defgeneric authentication-mechanism-textual-p (authentication-mechanism)
(:documentation "Return true if data from server should be converted
to a string, and false if it should remain an octet vector."))
(defgeneric feed-authentication-mechanism (authentication-mechanism challenge)
(:documentation "Feed authentication mechanism with a challenge,
which is either a string or an octet vector in accordance with the
mechanism's textuality, or :INITIAL-RESPONSE. The method should
return one of the following:
:CONTINUE <response>
Continue with the authentication conversation and send <response>
to the server.
:OK <response>
After sending <response> to the server the client is finished and
expecting an :OK response.
:ERROR
The challenge was invalid."))