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
|
#ifndef KIOAPT_APTPROTOCOL_H
#define KIOAPT_APTPROTOCOL_H
#include <qstring.h>
#include <qcstring.h>
#include <kurl.h>
#include <kio/global.h>
#include <kio/slavebase.h>
#include "debug.h"
#include "aptcache.h"
#include "packagemanager.h"
#include <memory>
class QCString;
namespace Parsers
{
class Parser;
}
class AptProtocol : public QObject, public KIO::SlaveBase {
Q_OBJECT
friend class AptCache;
AptCache m_process;
PackageManager* m_adept_batch;
typedef QMap<QString, QString> QueryOptions;
/** This this the URL that should be used if we want
* to get the same output again. It is especially
* used in the make_html_form for the command link.
*
* The get() method sets it to apt:/command?query
* the various methods should add the relevant options,
* that is options which modify the query itself.
* The GUI-related options (like show_filelist in the
* show command) should NOT be added
*/
KURL m_query;
/** if m_act is false, the ioslave is in browse-only
* mode (for forbidding install, for instance) */
bool m_act, m_search, m_internal;
QString m_stylesheet;
QString m_header_background;
QString m_logo;
QString m_logo_alt;
public:
AptProtocol( const QCString &pool_socket, const QCString &app_socket );
virtual ~AptProtocol();
virtual void mimetype( const KURL& url );
virtual void get ( const KURL& url );
/** Sends the string to the ioslave's master
* SlaveBase::data() sends a byte array as is. Since we
* definitely don't want to send \0 to the master,
* we redefine data() for strings */
void data(const QCString& string);
/** @overload */
void data(const QString& string);
/** @overload */
void data(const char* string);
void data(const QByteArray& array);
KURL buildURL(const QString& command, const QString& query) const;
KURL buildURL(const KURL& query) const;
QString stylesheet() const;
QString header_background() const;
QString logo() const;
QString logo_alt() const;
private slots:
void token_dispatch(const QString& tag, const QString& value);
private:
std::auto_ptr<Parsers::Parser> m_parser;
/** apt-cache search
* Performs apt-cache search, with the query encoded in url.query()
* and sends the result as an HTML file */
void search( const QString& url, const QueryOptions& options );
/** apt-cache show
* Performs apt-cache search, with the package name encoded in url.query()
* and sends the result as an HTML file.
* It checks that the query contains a valid package name */
void show( const QString& url, const QueryOptions& options );
/** apt-cache policy
* Performs apt-cache policy, with the package name encoded in url.query()
* and sends the result as an HTML file.
* It checks that the query contains a valid package name */
void policy( const QString& url, const QueryOptions& options );
/**
* Sends an application/x-adept_batch file with commands
* understandable by adept_batch */
void adept_batch( const QString& url, const QueryOptions& options );
/**
* Shows a form where one can enter parameters for some queries
**/
void help();
/** Offline listing of the file of a package */
bool can_listfiles(bool is_installed) const;
void listfiles( const QString& query, const QueryOptions& options);
/** Offline file search.
* Searches the package which contains the specified file */
bool can_searchfile(bool is_installed) const;
void searchfile( const QString& query, const QueryOptions& options);
bool can_online(int mode) const;
void online( const QString& query, const QueryOptions& options);
bool check_validpackage(const QString& query);
QString make_html_form() const;
QString make_html_tail(const QString& note = QString::null, bool with_form = true);
KShellProcess * p;
};
#endif
|