Mon, 05 Feb 2024 11:15:47 +0100
eric-ide Server
- Integrated the eric-ide server into the ViewManager and Editor file handling logic.
10539 | 1 | # -*- coding: utf-8 -*- |
2 | ||
3 | # Copyright (c) 2024 Detlev Offenbach <detlev@die-offenbachs.de> | |
4 | # | |
5 | ||
6 | """ | |
7 | Module implementing the file system interface to the eric-ide server. | |
8 | """ | |
9 | ||
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
10 | import base64 |
10539 | 11 | import contextlib |
12 | ||
13 | from PyQt6.QtCore import QEventLoop, QObject | |
14 | ||
15 | from eric7.RemoteServer.EricRequestCategory import EricRequestCategory | |
16 | ||
17 | ||
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
18 | # TODO: sanitize all file name with FileSystemUtilities.plainFileName() |
10539 | 19 | class EricServerFileSystemInterface(QObject): |
20 | """ | |
21 | Class implementing the file system interface to the eric-ide server. | |
22 | """ | |
23 | ||
24 | def __init__(self, serverInterface): | |
25 | """ | |
26 | Constructor | |
27 | ||
28 | @param serverInterface reference to the eric-ide server interface | |
29 | @type EricServerInterface | |
30 | """ | |
31 | super().__init__(parent=serverInterface) | |
32 | ||
33 | self.__serverInterface = serverInterface | |
34 | ||
35 | def getcwd(self): | |
36 | """ | |
37 | Public method to get the current working directory of the eric-ide server. | |
38 | ||
39 | @return current working directory of the eric-ide server | |
40 | @rtype str | |
41 | """ | |
42 | loop = QEventLoop() | |
43 | cwd = "" | |
44 | ||
45 | def callback(reply, params): | |
46 | """ | |
47 | Function to handle the server reply | |
48 | ||
49 | @param reply name of the server reply | |
50 | @type str | |
51 | @param params dictionary containing the reply data | |
52 | @type dict | |
53 | """ | |
54 | nonlocal cwd | |
55 | ||
56 | if reply == "Getcwd": | |
57 | cwd = params["directory"] | |
58 | loop.quit() | |
59 | ||
60 | self.__serverInterface.sendJson( | |
61 | category=EricRequestCategory.FileSystem, | |
62 | request="Getcwd", | |
63 | params={}, | |
64 | callback=callback, | |
65 | ) | |
66 | ||
67 | loop.exec() | |
68 | return cwd | |
69 | ||
70 | def chdir(self, directory): | |
71 | """ | |
72 | Public method to change the current working directory of the eric-ide server. | |
73 | ||
74 | @param directory absolute path of the working directory to change to | |
75 | @type str | |
76 | @return tuple containing an OK flag and an error string in case of an issue | |
77 | @rtype tuple of (bool, str) | |
78 | """ | |
79 | loop = QEventLoop() | |
80 | ok = False | |
81 | error = "" | |
82 | ||
83 | def callback(reply, params): | |
84 | """ | |
85 | Function to handle the server reply | |
86 | ||
87 | @param reply name of the server reply | |
88 | @type str | |
89 | @param params dictionary containing the reply data | |
90 | @type dict | |
91 | """ | |
92 | nonlocal ok, error | |
93 | ||
94 | if reply == "Chdir": | |
95 | ok = params["ok"] | |
96 | with contextlib.suppress(KeyError): | |
97 | error = params["error"] | |
98 | loop.quit() | |
99 | ||
100 | self.__serverInterface.sendJson( | |
101 | category=EricRequestCategory.FileSystem, | |
102 | request="Chdir", | |
103 | params={"directory": directory}, | |
104 | callback=callback, | |
105 | ) | |
106 | ||
107 | loop.exec() | |
108 | return ok, error | |
109 | ||
110 | def listdir(self, directory=""): | |
111 | """ | |
112 | Public method to get a directory listing. | |
113 | ||
114 | @param directory directory to be listed. An empty directory means to list | |
115 | the eric-ide server current directory. (defaults to "") | |
116 | @type str (optional) | |
117 | @return tuple containing the listed directory, the path separartor and the | |
118 | directory listing. Each directory listing entry contains a dictionary | |
119 | with the relevant data. | |
120 | @rtype tuple of (str, str, dict) | |
121 | """ | |
122 | if directory is None: | |
123 | # sanitize the directory in case it is None | |
124 | directory = "" | |
125 | ||
126 | loop = QEventLoop() | |
127 | listedDirectory = "" | |
128 | separator = "" | |
129 | listing = [] | |
130 | ||
131 | def callback(reply, params): | |
132 | """ | |
133 | Function to handle the server reply | |
134 | ||
135 | @param reply name of the server reply | |
136 | @type str | |
137 | @param params dictionary containing the reply data | |
138 | @type dict | |
139 | """ | |
140 | nonlocal listedDirectory, listing, separator | |
141 | ||
142 | if reply == "Listdir": | |
143 | listedDirectory = params["directory"] | |
144 | listing = params["listing"] | |
145 | separator = params["separator"] | |
146 | loop.quit() | |
147 | ||
148 | self.__serverInterface.sendJson( | |
149 | category=EricRequestCategory.FileSystem, | |
150 | request="Listdir", | |
151 | params={"directory": directory}, | |
152 | callback=callback, | |
153 | ) | |
154 | ||
155 | loop.exec() | |
156 | return listedDirectory, separator, listing | |
157 | ||
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
158 | def stat(self, filename, stNames): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
159 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
160 | Public method to get the status of a file. |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
161 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
162 | @param filename name of the file |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
163 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
164 | @param stNames list of 'stat_result' members to retrieve |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
165 | @type list of str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
166 | @return dictionary containing the requested status data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
167 | @rtype dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
168 | @exception OSError raised in case the server reported an issue |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
169 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
170 | loop = QEventLoop() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
171 | ok = False |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
172 | error = "" |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
173 | stResult = {} |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
174 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
175 | def callback(reply, params): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
176 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
177 | Function to handle the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
178 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
179 | @param reply name of the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
180 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
181 | @param params dictionary containing the reply data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
182 | @type dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
183 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
184 | nonlocal ok, error, stResult |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
185 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
186 | if reply == "Stat": |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
187 | ok = params["ok"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
188 | if ok: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
189 | stResult = params["result"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
190 | else: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
191 | error = params["error"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
192 | loop.quit() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
193 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
194 | self.__serverInterface.sendJson( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
195 | category=EricRequestCategory.FileSystem, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
196 | request="Stat", |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
197 | params={"filename": filename, "st_names": stNames}, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
198 | callback=callback, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
199 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
200 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
201 | loop.exec() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
202 | if not ok: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
203 | raise OSError(error) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
204 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
205 | return stResult |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
206 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
207 | def exists(self, name): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
208 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
209 | Public method the existence of a file or directory. |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
210 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
211 | @param name name of the file or directory |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
212 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
213 | @return flag indicating the file existence |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
214 | @rtype bool |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
215 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
216 | loop = QEventLoop() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
217 | nameExists = False |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
218 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
219 | def callback(reply, params): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
220 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
221 | Function to handle the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
222 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
223 | @param reply name of the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
224 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
225 | @param params dictionary containing the reply data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
226 | @type dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
227 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
228 | nonlocal nameExists |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
229 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
230 | if reply == "Exists": |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
231 | nameExists = params["exists"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
232 | loop.quit() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
233 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
234 | self.__serverInterface.sendJson( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
235 | category=EricRequestCategory.FileSystem, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
236 | request="Exists", |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
237 | params={"name": name}, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
238 | callback=callback, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
239 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
240 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
241 | loop.exec() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
242 | return nameExists |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
243 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
244 | def access(self, name, modes): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
245 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
246 | Public method to test the given access rights to a file or directory. |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
247 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
248 | The modes to check for are 'read', 'write' or 'execute' or any combination. |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
249 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
250 | @param name name of the file or directory |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
251 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
252 | @param modes list of modes to check for |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
253 | @type str or list of str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
254 | @return flag indicating the user has the asked for permissions |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
255 | @rtype bool |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
256 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
257 | if not modes: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
258 | raise ValueError( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
259 | "At least one of 'read', 'write' or 'execute' must be specified." |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
260 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
261 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
262 | if isinstance(modes, str): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
263 | # convert to a list with one element |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
264 | modes = [modes] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
265 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
266 | loop = QEventLoop() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
267 | accessOK = False |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
268 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
269 | def callback(reply, params): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
270 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
271 | Function to handle the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
272 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
273 | @param reply name of the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
274 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
275 | @param params dictionary containing the reply data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
276 | @type dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
277 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
278 | nonlocal accessOK |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
279 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
280 | if reply == "Access": |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
281 | accessOK = params["ok"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
282 | loop.quit() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
283 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
284 | self.__serverInterface.sendJson( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
285 | category=EricRequestCategory.FileSystem, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
286 | request="Access", |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
287 | params={"name": name, "modes":modes}, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
288 | callback=callback, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
289 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
290 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
291 | loop.exec() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
292 | return accessOK |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
293 | |
10539 | 294 | def mkdir(self, directory): |
295 | """ | |
296 | Public method to create a new directory on the eric-ide server. | |
297 | ||
298 | @param directory absolute path of the new directory | |
299 | @type str | |
300 | @return tuple containing an OK flag and an error string in case of an issue | |
301 | @rtype tuple of (bool, str) | |
302 | """ | |
303 | loop = QEventLoop() | |
304 | ok = False | |
305 | error = "" | |
306 | ||
307 | def callback(reply, params): | |
308 | """ | |
309 | Function to handle the server reply | |
310 | ||
311 | @param reply name of the server reply | |
312 | @type str | |
313 | @param params dictionary containing the reply data | |
314 | @type dict | |
315 | """ | |
316 | nonlocal ok, error | |
317 | ||
318 | if reply == "Mkdir": | |
319 | ok = params["ok"] | |
320 | with contextlib.suppress(KeyError): | |
321 | error = params["error"] | |
322 | loop.quit() | |
323 | ||
324 | self.__serverInterface.sendJson( | |
325 | category=EricRequestCategory.FileSystem, | |
326 | request="Mkdir", | |
327 | params={"directory": directory}, | |
328 | callback=callback, | |
329 | ) | |
330 | ||
331 | loop.exec() | |
332 | return ok, error | |
333 | ||
334 | def rmdir(self, directory): | |
335 | """ | |
336 | Public method to delete a directory on the eric-ide server. | |
337 | ||
338 | @param directory absolute path of the directory | |
339 | @type str | |
340 | @return tuple containing an OK flag and an error string in case of an issue | |
341 | @rtype tuple of (bool, str) | |
342 | """ | |
343 | loop = QEventLoop() | |
344 | ok = False | |
345 | error = "" | |
346 | ||
347 | def callback(reply, params): | |
348 | """ | |
349 | Function to handle the server reply | |
350 | ||
351 | @param reply name of the server reply | |
352 | @type str | |
353 | @param params dictionary containing the reply data | |
354 | @type dict | |
355 | """ | |
356 | nonlocal ok, error | |
357 | ||
358 | if reply == "Rmdir": | |
359 | ok = params["ok"] | |
360 | with contextlib.suppress(KeyError): | |
361 | error = params["error"] | |
362 | loop.quit() | |
363 | ||
364 | self.__serverInterface.sendJson( | |
365 | category=EricRequestCategory.FileSystem, | |
366 | request="Rmdir", | |
367 | params={"directory": directory}, | |
368 | callback=callback, | |
369 | ) | |
370 | ||
371 | loop.exec() | |
372 | return ok, error | |
373 | ||
374 | def replace(self, oldName, newName): | |
375 | """ | |
376 | Public method to rename a file or directory. | |
377 | ||
378 | @param oldName current name of the file or directory | |
379 | @type str | |
380 | @param newName new name for the file or directory | |
381 | @type str | |
382 | @return tuple containing an OK flag and an error string in case of an issue | |
383 | @rtype tuple of (bool, str) | |
384 | """ | |
385 | loop = QEventLoop() | |
386 | ok = False | |
387 | error = "" | |
388 | ||
389 | def callback(reply, params): | |
390 | """ | |
391 | Function to handle the server reply | |
392 | ||
393 | @param reply name of the server reply | |
394 | @type str | |
395 | @param params dictionary containing the reply data | |
396 | @type dict | |
397 | """ | |
398 | nonlocal ok, error | |
399 | ||
400 | if reply == "Replace": | |
401 | ok = params["ok"] | |
402 | with contextlib.suppress(KeyError): | |
403 | error = params["error"] | |
404 | loop.quit() | |
405 | ||
406 | self.__serverInterface.sendJson( | |
407 | category=EricRequestCategory.FileSystem, | |
408 | request="Replace", | |
409 | params={"old_name": oldName, "new_name": newName}, | |
410 | callback=callback, | |
411 | ) | |
412 | ||
413 | loop.exec() | |
414 | return ok, error | |
415 | ||
416 | def remove(self, filename): | |
417 | """ | |
418 | Public method to delete a file on the eric-ide server. | |
419 | ||
420 | @param filename absolute path of the file | |
421 | @type str | |
422 | @return tuple containing an OK flag and an error string in case of an issue | |
423 | @rtype tuple of (bool, str) | |
424 | """ | |
425 | loop = QEventLoop() | |
426 | ok = False | |
427 | error = "" | |
428 | ||
429 | def callback(reply, params): | |
430 | """ | |
431 | Function to handle the server reply | |
432 | ||
433 | @param reply name of the server reply | |
434 | @type str | |
435 | @param params dictionary containing the reply data | |
436 | @type dict | |
437 | """ | |
438 | nonlocal ok, error | |
439 | ||
440 | if reply == "Remove": | |
441 | ok = params["ok"] | |
442 | with contextlib.suppress(KeyError): | |
443 | error = params["error"] | |
444 | loop.quit() | |
445 | ||
446 | self.__serverInterface.sendJson( | |
447 | category=EricRequestCategory.FileSystem, | |
448 | request="Remove", | |
449 | params={"filename": filename}, | |
450 | callback=callback, | |
451 | ) | |
452 | ||
453 | loop.exec() | |
454 | return ok, error | |
455 | ||
456 | ####################################################################### | |
457 | ## Methods for reading and writing files | |
458 | ####################################################################### | |
459 | ||
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
460 | def readFile(self, filename, create=False): |
10539 | 461 | """ |
462 | Public method to read a file from the eric-ide server. | |
463 | ||
464 | @param filename name of the file to read | |
465 | @type str | |
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
466 | @param create flag indicating to create an empty file, if it does not exist |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
467 | (defaults to False) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
468 | @type bool (optional) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
469 | @return bytes data read from the eric-ide server |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
470 | @rtype bytes |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
471 | @exception OSError raised in case the server reported an issue |
10539 | 472 | """ |
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
473 | loop = QEventLoop() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
474 | ok = False |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
475 | error = "" |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
476 | bText = b"" |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
477 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
478 | def callback(reply, params): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
479 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
480 | Function to handle the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
481 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
482 | @param reply name of the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
483 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
484 | @param params dictionary containing the reply data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
485 | @type dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
486 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
487 | nonlocal ok, error, bText |
10539 | 488 | |
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
489 | if reply == "ReadFile": |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
490 | ok = params["ok"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
491 | if ok: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
492 | bText = base64.b85decode( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
493 | bytes(params["filedata"], encoding="ascii") |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
494 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
495 | else: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
496 | error = params["error"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
497 | loop.quit() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
498 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
499 | self.__serverInterface.sendJson( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
500 | category=EricRequestCategory.FileSystem, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
501 | request="ReadFile", |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
502 | params={"filename": filename, "create": create}, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
503 | callback=callback, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
504 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
505 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
506 | loop.exec() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
507 | if not ok: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
508 | raise OSError(error) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
509 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
510 | return bText |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
511 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
512 | def writeFile(self, filename, data, withBackup=False): |
10539 | 513 | """ |
514 | Public method to write the data to a file on the eric-ide server. | |
515 | ||
516 | @param filename name of the file to write | |
517 | @type str | |
518 | @param data data to be written | |
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
519 | @type bytes |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
520 | @param withBackup flag indicating to create a backup file first |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
521 | (defaults to False) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
522 | @type bool (optional) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
523 | @exception OSError raised in case the server reported an issue |
10539 | 524 | """ |
10546
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
525 | loop = QEventLoop() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
526 | ok = False |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
527 | error = "" |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
528 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
529 | def callback(reply, params): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
530 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
531 | Function to handle the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
532 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
533 | @param reply name of the server reply |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
534 | @type str |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
535 | @param params dictionary containing the reply data |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
536 | @type dict |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
537 | """ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
538 | nonlocal ok, error |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
539 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
540 | if reply == "WriteFile": |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
541 | ok = params["ok"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
542 | with contextlib.suppress(KeyError): |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
543 | error = params["error"] |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
544 | loop.quit() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
545 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
546 | self.__serverInterface.sendJson( |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
547 | category=EricRequestCategory.FileSystem, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
548 | request="WriteFile", |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
549 | params={ |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
550 | "filename": filename, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
551 | "filedata": str(base64.b85encode(data), encoding="ascii"), |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
552 | "with_backup": withBackup, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
553 | }, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
554 | callback=callback, |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
555 | ) |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
556 | |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
557 | loop.exec() |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
558 | if not ok: |
300487f5f517
eric-ide Server
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10539
diff
changeset
|
559 | raise OSError(error) |