summaryrefslogtreecommitdiff
path: root/spec/Connection_Interface_Resources1.xml
blob: ca7dddd3b2e66fb22c09005fb8e0dddf423c8137 (plain)
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
<?xml version="1.0" ?>
<node name="/Connection_Interface_Resources1"
  xmlns:tp="http://telepathy.freedesktop.org/wiki/DbusSpec#extensions-v0">
  <tp:copyright>Copyright © 2010 Collabora Ltd.</tp:copyright>
  <tp:license xmlns="http://www.w3.org/1999/xhtml">
    <p>This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.</p>

<p>This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.</p>

<p>You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.</p>
  </tp:license>
  <interface name="im.telepathy1.Connection.Interface.Resources1"
    tp:causes-havoc="experimental">
    <tp:added version="0.21.1">(draft 1)</tp:added>
    <tp:requires interface="im.telepathy1.Connection"/>

    <tp:docstring xmlns="http://www.w3.org/1999/xhtml">
      <p>An interface on connections to show contact attributes for
        specific resources of a contact, if the protocol supports
        multiple resources. Resources are most common in XMPP, hence the
        name of this interface, but they are also present in MSN, where
        they are called points of presence.</p>

      <p>When a client requests some attribute of a contact using its
        handle on the connection, the CM uses an algorithm to choose the
        most appropriate resource for the job. If there is only one
        resource, then the choice is obvious. If, however, there is more
        than one resource connected at any one time, the CM either
        aggregates all appropriate information to return (in the case of
        capabilities), or chooses one specific resource (in the case of
        presence).</p>

      <p>Resources in XMPP have names, and it can be extremely useful
        for the user to be able to know which resources of a contact are
        online, providing the names are human-readable. Before now,
        resources have not been exposed in Telepathy, but this interface
        attempts to change this.</p>

      <p>When using this interface, it is a little like using the
        <tp:dbus-ref namespace="im.telepathy1.Connection.Interface"
        >Contacts</tp:dbus-ref> interface, but only resource-specific
        attributes are ever returned. The resource-specific contact
        attributes are decided on by the CM, but XMPP's are listed
        below:</p>

      <ul>
        <li><tp:dbus-ref namespace="im.telepathy1.Connection.Interface">Presence1/presence</tp:dbus-ref></li>
        <li><tp:dbus-ref namespace="im.telepathy1.Connection.Interface">ContactCapabilities1/capabilities</tp:dbus-ref></li>
        <li><tp:dbus-ref namespace="im.telepathy1.Connection.Interface">ClientTypes1/client-types</tp:dbus-ref></li>
      </ul>

    </tp:docstring>

    <method name="GetResources" tp:name-for-bindings="Get_Resources">
      <tp:docstring>
        Return the resource information of the given contacts. If any
        of the contact attributes for specific resources of the given
        contacts' are not known return immediately without waiting for
        a reply.
      </tp:docstring>

      <arg direction="in" name="Contacts" type="au" tp:type="Contact_Handle[]">
        <tp:docstring>
          The contacts whose resource attributes should be returned.
        </tp:docstring>
      </arg>

      <arg direction="out" name="Resources" type="a{ua{sa{sv}}}"
        tp:type="Resources_Attributes_Map">
        <tp:docstring xmlns="http://www.w3.org/1999/xhtml">
          <p>The contacts' resources and the contact attributes specific
            to each resource. If contact attributes are not immediately
            known, the behaviour is defined by the interface; the
            attribute should either be omitted from the result or
            replaced with a default value.</p>

          <p>For every contact handle passed into this method, it is
            guaranteed that there will be a key in the returned map
            that corresponds to said handle. If there is no information
            regarding the contact the resource information map will be
            empty.</p>
        </tp:docstring>
      </arg>

      <tp:possible-errors>
        <tp:error name="im.telepathy1.Error.Disconnected"/>
        <tp:error name="im.telepathy1.Error.InvalidHandle"/>
      </tp:possible-errors>
    </method>

    <tp:enum name="Resources_Human_Readability" type="u">
      <tp:enumvalue suffix="Never" value="0">
        <tp:docstring>
          The resource string is never human-readable.
        </tp:docstring>
      </tp:enumvalue>
      <tp:enumvalue suffix="Maybe" value="1">
        <tp:docstring>
          The resource string might be human-readable.
        </tp:docstring>
      </tp:enumvalue>
    </tp:enum>

    <property name="ResourcesHumanReadable" type="u" access="read"
      tp:type="Resources_Human_Readability"
      tp:name-for-bindings="Resources_Human_Readable">
      <tp:docstring xmlns="http://www.w3.org/1999/xhtml">
        <p>Whether the resources returned from <tp:member-ref>GetResources</tp:member-ref>
          are human readable or not.</p>

        <p>If the connection manager knows that all resource names are
          automatically generated, then the resource strings mean
          nothing to the user. Showing these strings in the UI would
          be confusing, so by setting this to
          Resources_Human_Readability_Never, the UI is advised not to
          show resources.</p>

        <p>If on the other hand, all resources are set to nice names
          (such as "office" or "home") then it might be wise to expose
          these strings in the UI, so this property would be set to
          Resources_Human_Readability_Maybe. This is the case in XMPP --
          most resources are set in a way that the user can deduce some
          information from them. The absence of an Always enum value is
          because in the case of XMPP, the resource string could be
          partially human-readable (as on Google Talk, where a resource
          of "home" is changed by the server to a unique string like
          "home_1234fdec") or not at all human-readable.</p>

      </tp:docstring>
    </property>

    <signal name="ResourcesUpdated" tp:name-for-bindings="Resources_Updated">
      <tp:docstring>
        Emitted when a contact has a resource added or removed, or any
        contact attribute for any resource changes.
      </tp:docstring>

      <arg name="Contact" type="u" tp:type="Contact_Handle">
        <tp:docstring>
          The contact.
        </tp:docstring>
      </arg>
      <arg name="Resources" tp:type="Resource_Information_Map"
        type="a{sa{sv}}">
        <tp:docstring>
          The contact's resource information. All resource information
          is given, not just the details which have changed.
        </tp:docstring>
      </arg>
    </signal>

    <tp:mapping name="Resource_Information_Map">
      <tp:docstring>
        A map of a contact's resources to their resource-specific
        information.
      </tp:docstring>

      <tp:member name="Key" type="s">
        <tp:docstring>
          <p>The name of the resource.</p>
        </tp:docstring>
      </tp:member>

      <tp:member name="Contact_Attributes" type="a{sv}"
        tp:type="Single_Contact_Attributes_Map">
        <tp:docstring>
          A map of contact attributes whose data is specific to this
          resource.
        </tp:docstring>
      </tp:member>
    </tp:mapping>

    <tp:mapping name="Resources_Attributes_Map">
      <tp:docstring>Mapping returned by
        <tp:member-ref>GetResources</tp:member-ref>, representing a
        collection of Contacts, their resources, and their
        resource-specific contact attributes.</tp:docstring>

      <tp:member type="u" tp:type="Contact_Handle" name="Contact">
        <tp:docstring>
          A contact.
        </tp:docstring>
      </tp:member>

      <tp:member type="a{sa{sv}}" tp:type="Resource_Information_Map"
        name="Resources">
        <tp:docstring>
          A map of the contact's resources to their resource-specific
          information.
        </tp:docstring>
      </tp:member>
    </tp:mapping>

    <tp:contact-attribute name="resources" type="a{sa{sv}}"
      tp:type="Resource_Information_Map">
      <tp:docstring xmlns="http://www.w3.org/1999/xhtml">
        <p>The same mapping that would be returned by
          <tp:member-ref>GetResources</tp:member-ref> for this contact.</p>
      </tp:docstring>
    </tp:contact-attribute>

  </interface>
</node>
<!-- vim:set sw=2 sts=2 et ft=xml: -->