-
Notifications
You must be signed in to change notification settings - Fork 122
/
Copy pathxep-0011.xml
485 lines (480 loc) · 20 KB
/
xep-0011.xml
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
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE xep SYSTEM 'xep.dtd' [
<!ENTITY % ents SYSTEM 'xep.ent'>
%ents;
]>
<?xml-stylesheet type='text/xsl' href='xep.xsl'?>
<xep>
<header>
<title>Jabber Browsing</title>
<abstract>This document defines a way to describe information about Jabber entities and the relationships between entities. Note: This document is superseded by XEP-0030: Service Discovery.</abstract>
&LEGALNOTICE;
<number>0011</number>
<status>Obsolete</status>
<type>Historical</type>
<sig>Standards</sig>
<dependencies>
<spec>XMPP Core</spec>
</dependencies>
<supersedes/>
<supersededby>
<spec>XEP-0030</spec>
</supersededby>
<shortname>iq-browse</shortname>
&jer;
&xvirge;
&temas;
<revision>
<version>1.3.1</version>
<date>2021-03-04</date>
<initials>mw</initials>
<remark><p>Cross-document editorial adjustments for inclusive language.</p></remark>
</revision>
<revision>
<version>1.3</version>
<date>2009-06-03</date>
<initials>psa</initials>
<remark><p>Per a vote of the XMPP Council, changed status to Obsolete.</p></remark>
</revision>
<revision>
<version>1.2</version>
<date>2004-11-12</date>
<initials>psa</initials>
<remark><p>Per a vote of the Jabber Council, changed status to Deprecated.</p></remark>
</revision>
<revision>
<version>1.1</version>
<date>2004-01-06</date>
<initials>psa</initials>
<remark><p>Added schema.</p></remark>
</revision>
<revision>
<version>1.0</version>
<date>2002-05-08</date>
<initials>psa</initials>
<remark><p>Changed status to Active.</p></remark>
</revision>
<revision>
<version>0.4</version>
<date>2002-04-15</date>
<initials>jer</initials>
<remark><p>Changed the suggested use of category to an attribute of item instead of the element names.</p></remark>
</revision>
<revision>
<version>0.3</version>
<date>2002-01-16</date>
<initials>psa</initials>
<remark><p>Added additional category/type combinations from the protocol draft (also created new category 'validate' as a bucket for the grammar and spelling checkers, which formerly were under the 'render' category).</p></remark>
</revision>
<revision>
<version>0.2</version>
<date>2002-01-04</date>
<initials>jkm</initials>
<remark><p>Updated to XML format and revised description.</p></remark>
</revision>
<revision>
<version>0.1</version>
<date>2001-01-25</date>
<initials>jm</initials>
<remark><p>Initial draft version.</p></remark>
</revision>
</header>
<section1 topic='Introduction'>
<p>The Jabber world is a diverse place, with lots of services, transports, software agents, users, groupchat rooms, translators, headline tickers, and just about anything that might interact on a real-time basis using conversational messages or presence. Every JabberID (JID) is a node that can be interacted with via messages, presence, and special purpose IQ namespaces. Some JIDs are parents (such as transports), and often many JIDs have relationships with other JIDs (such as a user to their resources, a server to its services, etc.). We need a better way to structure and manage this culture of multi-namespace JID stew. The answer: Jabber Browsing.</p>
<p><em>Note well that implementors are encouraged to implement &xep0030; instead of Jabber Browsing.</em></p>
</section1>
<section1 topic='JID-Types'>
<p>One of the concepts in browsing which helps to extend the interaction between JIDs is a "JID-Type", a simple heirarchy for identifying the role of any JabberID that is similar to the mime-type format. Many programmers are comfortable with the concept of identifying file types by mime-types, which use the format "category/type". A JID-Type, once discovered, is to be used in the same way that a mime-type would be for a file, to alter the user interface representing that JID or provide alternative functionality for interacting with it (either automatically or driven by user interaction). The following categories and types are proposed as the canonical list for the purpose of JID-Types:</p>
<table caption='Official List of JID-Type Categories and Types'>
<tr>
<th>Category</th>
<th>Type</th>
<th>Description</th>
</tr>
<tr>
<td rowspan="7">application/</td>
<td> </td>
<td>Specific applications running as a resource on a user@host</td>
</tr>
<tr>
<td>bot</td>
<td>Automated conversations</td>
</tr>
<tr>
<td>calendar</td>
<td>Calendaring and scheduling service</td>
</tr>
<tr>
<td>editor</td>
<td>Collaborative editor</td>
</tr>
<tr>
<td>fileserver</td>
<td>Available files</td>
</tr>
<tr>
<td>game</td>
<td>Multi-player game</td>
</tr>
<tr>
<td>whiteboard</td>
<td>Whiteboard tool</td>
</tr>
<tr>
<td rowspan="7">conference/</td>
<td> </td>
<td>Nodes of this category provide multi-user chat facilities (a.k.a. conference rooms).</td>
</tr>
<tr>
<td>irc</td>
<td>IRC rooms (note: this enables Jabber users to connect to Internet Relay Chat rooms)</td>
</tr>
<tr>
<td>list</td>
<td>Mailing-list-style conferences</td>
</tr>
<tr>
<td>private</td>
<td>Private, dynamically-generated conference rooms</td>
</tr>
<tr>
<td>public</td>
<td>Public, permanent conference rooms</td>
</tr>
<tr>
<td>topic</td>
<td>Topic-based conferences</td>
</tr>
<tr>
<td>url</td>
<td>Website-hosted conferences</td>
</tr>
<tr>
<td rowspan="5">headline/</td>
<td> </td>
<td>Recognize different sources of headlines, GUI hints</td>
</tr>
<tr>
<td>logger</td>
<td>Log messages (usually presented in a scrolling GUI)</td>
</tr>
<tr>
<td>notice</td>
<td>Alerts and warnings (usually presented as popup messages)</td>
</tr>
<tr>
<td>rss</td>
<td>Rich Site Summary syndication</td>
</tr>
<tr>
<td>stock</td>
<td>Stock market information by symbol (ticker)</td>
</tr>
<tr>
<td rowspan="7">keyword/</td>
<td> </td>
<td>Keyword-based lookup services (search engines, etc.)</td>
</tr>
<tr>
<td>dictionary</td>
<td>Dictionary lookup service</td>
</tr>
<tr>
<td>dns</td>
<td>DNS resolver</td>
</tr>
<tr>
<td>software</td>
<td>Software search</td>
</tr>
<tr>
<td>thesaurus</td>
<td>Thesaurus lookup service</td>
</tr>
<tr>
<td>web</td>
<td>Web search</td>
</tr>
<tr>
<td>whois</td>
<td>Whois query service</td>
</tr>
<tr>
<td rowspan="4">render/</td>
<td> </td>
<td>Automated translation services</td>
</tr>
<tr>
<td>en2fr</td>
<td>English to French</td>
</tr>
<tr>
<td>*2*</td>
<td>Other language to language (using standard language codes)</td>
</tr>
<tr>
<td>tts</td>
<td>Text to Speech</td>
</tr>
<tr>
<td rowspan="12">service/</td>
<td> </td>
<td>Nodes of this category provide a link to another Instant Messaging network or messaging gateway. The 'jabber:iq:register' namespace can be used to gain access to such networks, and the 'jabber:iq:search' namespace may also be available.</td>
</tr>
<tr>
<td>aim</td>
<td>AIM transport</td>
</tr>
<tr>
<td>icq</td>
<td>ICQ transport</td>
</tr>
<tr>
<td>irc</td>
<td>IRC gateway (note: this enables IRC users to connect to Jabber)</td>
</tr>
<tr>
<td>jabber</td>
<td>A Jabber server which conforms to the specification for the 'jabber:client' namespace</td>
</tr>
<tr>
<td>jud</td>
<td>Jabber User Directory</td>
</tr>
<tr>
<td>msn</td>
<td>MSN transport</td>
</tr>
<tr>
<td>pager</td>
<td>Pager gateway</td>
</tr>
<tr>
<td>serverlist</td>
<td>A list of servers. It is assumed that this node has service/* children</td>
</tr>
<tr>
<td>sms</td>
<td>SMS gateway</td>
</tr>
<tr>
<td>smtp</td>
<td>SMTP gateway</td>
</tr>
<tr>
<td>yahoo</td>
<td>Yahoo! transport</td>
</tr>
<tr>
<td rowspan="6">user/</td>
<td> </td>
<td>Nodes of this category are Jabber users, typically implementing enough of the 'jabber:client' namespace to be compliant.</td>
</tr>
<tr>
<td>client</td>
<td>A standard or fully-featured Jabber client compliant with the 'jabber:client' namespace</td>
</tr>
<tr>
<td>forward</td>
<td>A forward alias</td>
</tr>
<tr>
<td>inbox</td>
<td>An alternate inbox</td>
</tr>
<tr>
<td>portable</td>
<td>A portable device implementing some of the 'jabber:client' namespace</td>
</tr>
<tr>
<td>voice</td>
<td>A node providing phone or voice access</td>
</tr>
<tr>
<td rowspan="4">validate/</td>
<td> </td>
<td>Validation services</td>
</tr>
<tr>
<td>grammar</td>
<td>Grammar-checking tool</td>
</tr>
<tr>
<td>spell</td>
<td>Spell-checking tool</td>
</tr>
<tr>
<td>xml</td>
<td>XML validator</td>
</tr>
</table>
<p>Historically each category was used as the name of an element, and the type was an attribute, such as <![CDATA[<service type="aim"/>]]>. The proper expression for all new implementations supporting this specification is to express the type information as attributes on a generic item element: <![CDATA[<item category="service" type="aim"/>]]>. When processing returned browse information this new syntax should always be handled first, and the old syntax only used if it is important to be able to access older implementations.</p>
<p>Additional unofficial categories or types may be specified by prefixing their name with an "x-", such as "service/x-virgeim" or "x-location/gps". Changes to the official categories and subtypes may be defined either by revising this document or by activating another specification. Removal of a category or subtype must be noted in this document.</p>
</section1>
<section1 topic='The jabber:iq:browse Namespace'>
<p>The namespace containing the Jabber Browsing data is jabber:iq:browse. The primary element within this namespace is 'item' (again, historically every category listed above would also be an element).</p>
<section2 topic='Browsing to a JabberID'>
<p>The common way to browse to a JabberID using IQ is:</p>
<example caption='Browsing to a JabberID'>
<iq type="get" to="jer@jabber.org" id="browse1">
<query xmlns="jabber:iq:browse"/>
</iq>
</example>
</section2>
<section2 topic='Generic Attributes for Browse Results'>
<p>The item element has these attributes in a browse result:</p>
<ul>
<li>jid [required] -- The full JabberID of the entity described.</li>
<li>category [optional] -- One of the categories from the list above, or a non-standard category prefixed with the string "x-".</li>
<li>type [optional] -- One of the official types from the specified category, or a non-standard type prefixed with the string "x-".</li>
<li>name [optional] -- A friendly name that may be used in a user interface.</li>
<li>version [optional] -- A string containing the version of the node, equivalent to the response provided to a query in the 'jabber:iq:version' namespace. This is useful for servers, especially for lists of services (see the 'service/serverlist' category/type above).</li>
</ul>
</section2>
<section2 topic='Expressing Relationships'>
<p>Any item may contain any number of additional items as a child, which describes the hierarchical relationship between the parent and the child items. This relationship could be represented as a "link" in a wizard or page-based user interface, or as a branch in a tree as it is expanded. Browse results usually only contain the direct children of a node, not the grandchildren. Browsing to a user, but not a resource, will return results from the server (still with the user's JID) containing the list of resources.</p>
<p>For example, this could be the result of browsing to jer@jabber.org:</p>
<example caption='Result of Browsing to a User'>
<iq type="result" from="jer@jabber.org" id="browse1">
<query
xmlns="jabber:iq:browse"
category="user"
jid="jer@jabber.org"
name="jer">
<item
category="user"
jid="jer@jabber.org/foxy"
type="client"/>
<item
category="application"
jid="jer@jabber.org/chess"
name="XChess"
type="game"/>
<item
category="user"
jid="jer@jabber.org/palm"
type="client"/>
</query>
</iq>
</example>
<p>More definitively, throughout all of browsing, a parent describes the children, and the children when browsed to fully describe themselves. The browse data received from the child takes precedence.</p>
<p>Parents should list children only if they are available. This means that if for a user a child client goes offline, the parent should remove it from its browse result.</p>
</section2>
<section2 topic='Namespace Advertising'>
<p>On top of the browsing framework, a simple form of "feature advertisement" can be built. This enables any entity to advertise which features it supports, based on the namespaces associated with those features. The <ns/> element is allowed as a subelement of the item. This element contains a single namespace that the entity supports, and multiple <ns/> elements can be included in any item. For a connected client this might be <ns>jabber:iq:oob</ns>, or for a service <ns>jabber:iq:search</ns>. This list of namespaces should be used to present available options for a user or to automatically locate functionality for an application.</p>
<p>The children of a browse result may proactively contain a few <ns/> elements (such as the result of the service request to the home server), which advertises the features that the particular service supports. This list may not be complete (it is only for first-pass filtering by simpler clients), and the JID should be browsed if a complete list is required.</p>
<p>Clients should answer incoming browsing requests to advertise the namespaces they support.</p>
<example caption='Result of Browsing to a Resource'>
<iq type="result" from="jer@jabber.org/foxy" id="browse2">
<query
xmlns="jabber:iq:browse"
category="user"
jid="jer@jabber.org/foxy"
name="laptop"
type="client">
<ns>jabber:client</ns>
<ns>jabber:iq:browse</ns>
<ns>jabber:iq:conference</ns>
<ns>jabber:iq:time</ns>
<ns>jabber:iq:version</ns>
<ns>jabber:x:roster</ns>
<ns>jabber:x:signed</ns>
<ns>jabber:x:encrypted</ns>
</query>
</iq>
</example>
</section2>
<section2 topic='Empty Results'>
<p>When a JabberID is browsed, the result may contain children or it may be empty. An empty result means there are no further relationships or links under that JID, which could be represented as a page containing a list of functions available for the JID, such as vCard, message, register, etc. When the result contains children, they may also be empty (as in the first result from jer@jabber.org above). An empty child does not mean anything, and to determine the namespaces supported or if there are more children, it must be browsed to directly.</p>
</section2>
</section1>
<section1 topic='Supplanting jabber:iq:agents'>
<p>The first important use of jabber:iq:browse is to replace the jabber:iq:agents namespace. When a client connects, it may optionally browse to the server to which it connected in order to retrieve a list of available services. The resulting iq might look like the following example:</p>
<example caption='Result of Browsing to a Server'>
<iq type="result" from="jabber.org" id="browse3">
<query
xmlns="jabber:iq:browse"
category="service"
type="jabber"
jid="jabber.org"
name="Jabber.org Public Server">
<ns>jabber:client</ns>
<ns>jabber:iq:browse</ns>
<ns>jabber:iq:conference</ns>
<ns>jabber:iq:time</ns>
<ns>jabber:iq:version</ns>
<item
category="service"
jid="icq.jabber.org"
name="ICQ Transport"
type="icq">
<ns>jabber:iq:register</ns>
<ns>jabber:iq:search</ns>
<ns>jabber:iq:gateway</ns>
</item>
<item
category="conference"
type="private"
jid="conference.jabber.org"
name="Private Chatrooms"/>
<item
category="application"
jid="jabber.org/help"
name="Assistance Agent"
type="bot"/>
</query>
</iq>
</example>
<p>To determine any further details from this list, each child would have to be browsed. The elements within the icq service are only hints to a client for building user interface elements. The icq.jabber.org service would still need to be browsed in order to determine any relationships or additional namespaces. This top-level list is the primary "services" list available from the server, and should be used for any default functionality when available. This list could also serve as the "home page" for a page-based browsing user interface.</p>
</section1>
<section1 topic='Implementation Notes'>
<p>A client should not just blindly request browse information every time the user requests it, rather, a client should cache the browse results based on JabberID. Any display or use of the browse data should then be returned from the cache. This model is similiar to that of presence.</p>
</section1>
<section1 topic='Security Considerations'>
<p>There are no security features or concerns related to this proposal.</p>
</section1>
<section1 topic='IANA Considerations'>
<p>This document requires no interaction with &IANA;.</p>
</section1>
<section1 topic='XMPP Registrar Considerations' anchor='registrar'>
<p>No action on the part of the ®ISTRAR; is necessary as a result of this document, since 'jabber:iq:browse' is already a registered protocol namespace.</p>
</section1>
<section1 topic='XML Schema'>
<code><![CDATA[
<?xml version='1.0' encoding='UTF-8'?>
<xs:schema
xmlns:xs='http://www.w3.org/2001/XMLSchema'
targetNamespace='jabber:iq:browse'
xmlns='jabber:iq:browse'
elementFormDefault='qualified'>
<xs:element name='query'>
<xs:complexType>
<xs:choice minOccurs='0' maxOccurs='unbounded'>
<xs:element ref='item'/>
<xs:element ref='ns'/>
</xs:choice>
<xs:attribute name='category' type='xs:string' use='optional'/>
<xs:attribute name='jid' type='xs:string' use='optional'/>
<xs:attribute name='name' type='xs:string' use='optional'/>
<xs:attribute name='type' type='xs:string' use='optional'/>
</xs:complexType>
</xs:element>
<xs:element name='item'>
<xs:complexType>
<xs:sequence>
<xs:element ref='ns' minOccurs='0' maxOccurs='unbounded'/>
</xs:sequence>
<xs:attribute name='category' type='xs:string' use='optional'/>
<xs:attribute name='jid' type='xs:string' use='optional'/>
<xs:attribute name='name' type='xs:string' use='optional'/>
<xs:attribute name='type' type='xs:string' use='optional'/>
</xs:complexType>
</xs:element>
<xs:element name='ns' type='xs:string'/>
</xs:schema>
]]></code>
</section1>
<section1 topic='Future Considerations'>
<p>The 'jabber:iq:browse' namespace has been in use for quite some time. However, live browsing still needs to be better defined by a generic publication/subscription system. It is assumed that when such a system is defined, updates to this document will be made. It is, however, possible that no futher changes to jabber:iq:browse itself may be needed.</p>
</section1>
</xep>