1/*
2 Copyright (c) 2006-2008 Tobias Koenig <tokoe@kde.org>
3
4 This library is free software; you can redistribute it and/or modify it
5 under the terms of the GNU Library General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or (at your
7 option) any later version.
8
9 This library is distributed in the hope that it will be useful, but WITHOUT
10 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
12 License for more details.
13
14 You should have received a copy of the GNU Library General Public License
15 along with this library; see the file COPYING.LIB. If not, write to the
16 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 02110-1301, USA.
18*/
19
20#ifndef AKONADI_AGENTMANAGER_P_H
21#define AKONADI_AGENTMANAGER_P_H
22
23#include "agentmanagerinterface.h"
24
25#include "agenttype.h"
26#include "agentinstance.h"
27
28#include <QtCore/QHash>
29
30namespace Akonadi {
31
32class AgentManager;
33
34/**
35 * @internal
36 */
37class AgentManagerPrivate
38{
39 friend class AgentManager;
40
41public:
42 AgentManagerPrivate(AgentManager *parent)
43 : mParent(parent)
44 , mManager(0)
45 {
46 }
47
48 /*
49 * Used by AgentInstanceCreateJob
50 */
51 AgentInstance createInstance(const AgentType &type);
52
53 void agentTypeAdded(const QString &);
54 void agentTypeRemoved(const QString &);
55 void agentInstanceAdded(const QString &);
56 void agentInstanceRemoved(const QString &);
57 void agentInstanceStatusChanged(const QString &, int, const QString &);
58 void agentInstanceProgressChanged(const QString &, uint, const QString &);
59 void agentInstanceNameChanged(const QString &, const QString &);
60 void agentInstanceWarning(const QString &, const QString &);
61 void agentInstanceError(const QString &, const QString &);
62 void agentInstanceOnlineChanged(const QString &, bool);
63
64 /**
65 * Reads the information about all known agent types from the serverside
66 * agent manager and updates mTypes, like agentTypeAdded() does.
67 *
68 * This will not remove agents from the internal map that are no longer on
69 * the server.
70 */
71 void readAgentTypes();
72
73 /**
74 * Reads the information about all known agent instances from the server. If AgentManager
75 * is created before the Akonadi.Control interface is registered, the agent
76 * instances aren't immediately found then.
77 */
78 void readAgentInstances();
79
80 void setName(const AgentInstance &, const QString &);
81 void setOnline(const AgentInstance &, bool);
82 void configure(const AgentInstance &, QWidget *);
83 void synchronize(const AgentInstance &);
84 void synchronizeCollectionTree(const AgentInstance &);
85
86 void serviceOwnerChanged(const QString &name, const QString &oldOwner, const QString &newOwner);
87 void createDBusInterface();
88
89 AgentType fillAgentType(const QString &identifier) const;
90 AgentInstance fillAgentInstance(const QString &identifier) const;
91 AgentInstance fillAgentInstanceLight(const QString &identifier) const;
92
93 static AgentManager *mSelf;
94
95 AgentManager *mParent;
96 org::freedesktop::Akonadi::AgentManager *mManager;
97
98 QHash<QString, AgentType> mTypes;
99 QHash<QString, AgentInstance> mInstances;
100};
101
102}
103
104#endif
105