LunaSysMgr
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
BackupManager.h
Go to the documentation of this file.
1 /* @@@LICENSE
2 *
3 * Copyright (c) 2009-2012 Hewlett-Packard Development Company, L.P.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 * LICENSE@@@ */
18 
19 
20 
21 
22 #ifndef BACKUP_MANAGER_H
23 #define BACKUP_MANAGER_H
24 
25 #include "Common.h"
26 
27 #include <string>
28 #include <list>
29 #include <map>
30 #include "lunaservice.h"
31 #include <QObject>
32 #include <QList>
33 #include <QString>
34 
35 struct LSHandle;
36 struct LSMessage;
37 
38 //FIXME-qtwebkit
39 namespace Palm
40 {
41  struct DbBackupStatus { std::string url; int err;};
42 };
43 
49 {
50 
51 public:
52 
53  bool init (GMainLoop* mainLoop);
54 
55  static BackupManager* instance();
56 
57 private:
58 
59  BackupManager ();
60  ~BackupManager ();
61 
62  static LSMethod s_BackupServerMethods[];
63  static BackupManager* s_instance;
64 
65  GMainLoop* m_mainLoop;
66  LSHandle* m_clientService; // The client's connection to the backup service.
67  LSPalmService* m_serverService; // The methods we expose to the backup service.
68  std::string m_strBackupServiceName;
69 
70  bool m_doBackupFiles;
71  bool m_doBackupCookies;
72  std::list<std::string> m_backupFiles;
73 
74  void initFilesForBackup();
75 
76  static bool preBackupCallback( LSHandle* lshandle, LSMessage *message, void *user_data);
77  static bool postRestoreCallback( LSHandle* lshandle, LSMessage *message, void *user_data);
78 };
79 
80 
81 #endif // BACKUP_MANAGER_H