2 * Copyright (C) 2010 Collabora Ltd.
4 * This library is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation, either version 2.1 of the License, or
7 * (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with this library. If not, see <http://www.gnu.org/licenses/>.
18 * Travis Reitter <travis.reitter@collabora.co.uk>
25 * Represents a "shard" of a person from a single source (a single
26 * {@link Backend}), such as an XMPP contact from Telepathy or a vCard contact
27 * from evolution-data-server. All the personas belonging to one physical person
28 * are aggregated to form a single {@link Individual} representing that person.
30 public abstract class Folks.Persona : Object, Alias, Avatar, Capabilities,
37 public abstract string alias { get; set; }
39 /* interface Avatar */
43 public abstract File avatar { get; set; }
45 /* interface Capabilities */
49 public abstract CapabilitiesFlags capabilities { get; set; }
51 /* interface Presence */
55 public abstract Folks.PresenceType presence_type { get; set; }
60 public abstract string presence_message { get; set; }
65 public abstract bool is_favourite { get; set; }
68 * The internal ID used to represent the Persona within its {@link Backend}.
70 * This should not be used by client code.
72 public string iid { get; construct; }
75 * The universal ID used to represent the Persona outside its {@link Backend}.
77 * For example: `foo@@xmpp.example.org`.
79 * This is the canonical way to refer to any Persona. It is guaranteed to be
80 * unique within the Persona's {@link PersonaStore}.
82 public string uid { get; construct; }
85 * The {@link PersonaStore} which contains this Persona.
87 public PersonaStore store { get; construct; }