Revision 6b7d024f src/gr/grnet/pithos/web/client/FolderPropertiesDialog.java
b/src/gr/grnet/pithos/web/client/FolderPropertiesDialog.java | ||
---|---|---|
34 | 34 |
*/ |
35 | 35 |
package gr.grnet.pithos.web.client; |
36 | 36 |
|
37 |
import com.google.gwt.core.client.Scheduler; |
|
38 |
import com.google.gwt.event.dom.client.KeyDownEvent; |
|
39 |
import com.google.gwt.user.client.Command; |
|
40 | 37 |
import gr.grnet.pithos.web.client.foldertree.File; |
41 | 38 |
import gr.grnet.pithos.web.client.foldertree.Folder; |
42 | 39 |
import gr.grnet.pithos.web.client.foldertree.Resource; |
43 |
import gr.grnet.pithos.web.client.rest.PostRequest; |
|
44 | 40 |
import gr.grnet.pithos.web.client.rest.PutRequest; |
45 | 41 |
import gr.grnet.pithos.web.client.rest.RestException; |
46 | 42 |
|
43 |
import java.util.Iterator; |
|
44 |
|
|
47 | 45 |
import com.google.gwt.core.client.GWT; |
46 |
import com.google.gwt.core.client.Scheduler; |
|
48 | 47 |
import com.google.gwt.dom.client.NativeEvent; |
49 | 48 |
import com.google.gwt.event.dom.client.ChangeEvent; |
50 | 49 |
import com.google.gwt.event.dom.client.ChangeHandler; |
51 | 50 |
import com.google.gwt.event.dom.client.ClickEvent; |
52 | 51 |
import com.google.gwt.event.dom.client.ClickHandler; |
53 | 52 |
import com.google.gwt.event.dom.client.KeyCodes; |
53 |
import com.google.gwt.event.dom.client.KeyDownEvent; |
|
54 | 54 |
import com.google.gwt.http.client.Response; |
55 |
import com.google.gwt.http.client.URL; |
|
56 | 55 |
import com.google.gwt.i18n.client.DateTimeFormat; |
56 |
import com.google.gwt.user.client.Command; |
|
57 | 57 |
import com.google.gwt.user.client.Event.NativePreviewEvent; |
58 | 58 |
import com.google.gwt.user.client.ui.Anchor; |
59 | 59 |
import com.google.gwt.user.client.ui.Button; |
60 |
import com.google.gwt.user.client.ui.DecoratedTabPanel; |
|
61 | 60 |
import com.google.gwt.user.client.ui.DialogBox; |
62 | 61 |
import com.google.gwt.user.client.ui.FlexTable; |
63 | 62 |
import com.google.gwt.user.client.ui.HasHorizontalAlignment; |
64 |
import com.google.gwt.user.client.ui.HorizontalPanel; |
|
65 | 63 |
import com.google.gwt.user.client.ui.Label; |
66 |
import com.google.gwt.user.client.ui.TabPanel; |
|
67 | 64 |
import com.google.gwt.user.client.ui.TextBox; |
68 | 65 |
import com.google.gwt.user.client.ui.VerticalPanel; |
69 |
import java.util.Iterator; |
|
70 |
import java.util.Map; |
|
71 | 66 |
|
72 | 67 |
/** |
73 | 68 |
* The 'Folder properties' dialog box implementation. |
... | ... | |
87 | 82 |
*/ |
88 | 83 |
private final boolean create; |
89 | 84 |
|
90 |
protected PermissionsList permList; |
|
91 |
|
|
92 | 85 |
final Folder folder; |
93 | 86 |
|
94 |
final TabPanel inner;
|
|
87 |
final VerticalPanel inner;
|
|
95 | 88 |
|
96 | 89 |
/** |
97 | 90 |
* The widget's constructor. |
... | ... | |
103 | 96 |
close.addClickHandler(new ClickHandler() { |
104 | 97 |
|
105 | 98 |
@Override |
106 |
public void onClick(ClickEvent event) { |
|
99 |
public void onClick(@SuppressWarnings("unused") ClickEvent event) {
|
|
107 | 100 |
hide(); |
108 | 101 |
} |
109 | 102 |
}); |
... | ... | |
129 | 122 |
VerticalPanel outer = new VerticalPanel(); |
130 | 123 |
outer.add(close); |
131 | 124 |
// Inner contains generalPanel and permPanel |
132 |
inner = new DecoratedTabPanel(); |
|
133 |
inner.setAnimationEnabled(true); |
|
125 |
inner = new VerticalPanel(); |
|
134 | 126 |
inner.addStyleName("inner"); |
135 |
inner.getDeckPanel().addStyleName("pithos-TabPanelBottom"); |
|
136 | 127 |
|
137 | 128 |
VerticalPanel generalPanel = new VerticalPanel(); |
138 | 129 |
FlexTable generalTable = new FlexTable(); |
... | ... | |
168 | 159 |
generalTable.getFlexCellFormatter().setStyleName(3, 1, "props-values"); |
169 | 160 |
generalTable.setCellSpacing(4); |
170 | 161 |
generalPanel.add(generalTable); |
171 |
inner.add(generalPanel, "General"); |
|
172 |
|
|
173 |
VerticalPanel permPanel = new VerticalPanel(); |
|
174 |
FilePermissionsDialog.Images images = GWT.create(FilePermissionsDialog.Images.class); |
|
175 |
boolean permsReadonly = folder.getInheritedPermissionsFrom() != null || folder.existChildrenPermissions(); |
|
176 |
permList = new PermissionsList(images, folder.getPermissions(), folder.getOwner(), permsReadonly); |
|
177 |
permPanel.add(permList); |
|
178 |
|
|
179 |
if (!permsReadonly) { |
|
180 |
HorizontalPanel permButtons = new HorizontalPanel(); |
|
181 |
Button add = new Button("Add Group", new ClickHandler() { |
|
182 |
@Override |
|
183 |
public void onClick(@SuppressWarnings("unused") ClickEvent event) { |
|
184 |
PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, false); |
|
185 |
dlg.center(); |
|
186 |
} |
|
187 |
}); |
|
188 |
add.addStyleName("button"); |
|
189 |
permButtons.add(add); |
|
190 |
permButtons.setCellHorizontalAlignment(add, HasHorizontalAlignment.ALIGN_CENTER); |
|
191 |
|
|
192 |
Button addUser = new Button("Add User", new ClickHandler() { |
|
193 |
@Override |
|
194 |
public void onClick(@SuppressWarnings("unused") ClickEvent event) { |
|
195 |
PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, true); |
|
196 |
dlg.center(); |
|
197 |
} |
|
198 |
}); |
|
199 |
addUser.addStyleName("button"); |
|
200 |
permButtons.add(addUser); |
|
201 |
permButtons.setCellHorizontalAlignment(addUser, HasHorizontalAlignment.ALIGN_CENTER); |
|
202 |
permButtons.setSpacing(8); |
|
203 |
permPanel.add(permButtons); |
|
204 |
} |
|
205 |
|
|
206 |
if (!create) |
|
207 |
inner.add(permPanel, "Sharing"); |
|
208 |
inner.selectTab(0); |
|
162 |
inner.add(generalPanel); |
|
209 | 163 |
|
210 | 164 |
outer.add(inner); |
211 | 165 |
|
... | ... | |
310 | 264 |
} |
311 | 265 |
|
312 | 266 |
@Override |
313 |
protected void onUnauthorized(Response response) { |
|
267 |
protected void onUnauthorized(@SuppressWarnings("unused") Response response) {
|
|
314 | 268 |
app.sessionExpired(); |
315 | 269 |
} |
316 | 270 |
}; |
... | ... | |
335 | 289 |
} |
336 | 290 |
|
337 | 291 |
private void updateFolder() { |
338 |
final Map<String, Boolean[]> perms = (permList.hasChanges() ? permList.getPermissions() : null); |
|
339 | 292 |
final String newName = folderName.getText().trim(); |
340 | 293 |
if (!folder.isContainer() && !folder.getName().equals(newName)) { |
341 | 294 |
final String path = folder.getParent().getUri() + "/" + newName; |
... | ... | |
351 | 304 |
@Override |
352 | 305 |
public void execute() { |
353 | 306 |
app.deleteFolder(folder); |
354 |
updateMetadata(path + "?update=", perms); |
|
307 |
app.updateFolder(folder.getParent(), false, new Command() { |
|
308 |
|
|
309 |
@Override |
|
310 |
public void execute() { |
|
311 |
app.updateMySharedRoot(); |
|
312 |
} |
|
313 |
}); |
|
355 | 314 |
} |
356 | 315 |
}); |
357 | 316 |
} |
... | ... | |
370 | 329 |
} |
371 | 330 |
|
372 | 331 |
@Override |
373 |
protected void onUnauthorized(Response response) { |
|
332 |
protected void onUnauthorized(@SuppressWarnings("unused") Response response) {
|
|
374 | 333 |
app.sessionExpired(); |
375 | 334 |
} |
376 | 335 |
}; |
... | ... | |
381 | 340 |
Scheduler.get().scheduleDeferred(newFolder); |
382 | 341 |
} |
383 | 342 |
else |
384 |
updateMetadata(folder.getUri() + "?update=", perms); |
|
385 |
} |
|
386 |
|
|
387 |
protected void updateMetadata(final String path, final Map<String, Boolean[]> newPermissions) { |
|
388 |
if (newPermissions != null) { |
|
389 |
PostRequest updateFolder = new PostRequest(app.getApiPath(), folder.getOwner(), path) { |
|
390 |
@Override |
|
391 |
public void onSuccess(@SuppressWarnings("unused") Resource result) { |
|
392 |
app.updateFolder(folder.getParent(), false, new Command() { |
|
393 |
|
|
394 |
@Override |
|
395 |
public void execute() { |
|
396 |
app.updateMySharedRoot(); |
|
397 |
} |
|
398 |
}); |
|
399 |
} |
|
400 |
|
|
401 |
@Override |
|
402 |
public void onError(Throwable t) { |
|
403 |
GWT.log("", t); |
|
404 |
app.setError(t); |
|
405 |
if (t instanceof RestException) { |
|
406 |
if (((RestException) t).getHttpStatusCode() == Response.SC_NOT_FOUND) { //Probably a virtual folder |
|
407 |
final String path1 = folder.getUri(); |
|
408 |
PutRequest newFolder = new PutRequest(app.getApiPath(), folder.getOwner(), path1) { |
|
409 |
@Override |
|
410 |
public void onSuccess(@SuppressWarnings("unused") Resource result) { |
|
411 |
updateMetadata(path, newPermissions); |
|
412 |
} |
|
413 |
|
|
414 |
@Override |
|
415 |
public void onError(Throwable _t) { |
|
416 |
GWT.log("", _t); |
|
417 |
app.setError(_t); |
|
418 |
if(_t instanceof RestException){ |
|
419 |
app.displayError("Unable to update folder: " + ((RestException) _t).getHttpStatusText()); |
|
420 |
} |
|
421 |
else |
|
422 |
app.displayError("System error modifying folder: " + _t.getMessage()); |
|
423 |
} |
|
424 |
|
|
425 |
@Override |
|
426 |
protected void onUnauthorized(Response response) { |
|
427 |
app.sessionExpired(); |
|
428 |
} |
|
429 |
}; |
|
430 |
newFolder.setHeader("X-Auth-Token", app.getToken()); |
|
431 |
newFolder.setHeader("Content-Type", "application/folder"); |
|
432 |
newFolder.setHeader("Accept", "*/*"); |
|
433 |
newFolder.setHeader("Content-Length", "0"); |
|
434 |
Scheduler.get().scheduleDeferred(newFolder); |
|
435 |
} |
|
436 |
else if (((RestException) t).getHttpStatusCode() == Response.SC_CONFLICT) { |
|
437 |
app.displayError("Cannot set permissions. Probably subfolders or files already have permissions set"); |
|
438 |
} |
|
439 |
else |
|
440 |
app.displayError("Wrror modifying folder: " + t.getMessage()); |
|
441 |
} |
|
442 |
else |
|
443 |
app.displayError("System error modifying folder: " + t.getMessage()); |
|
444 |
} |
|
445 |
|
|
446 |
@Override |
|
447 |
protected void onUnauthorized(Response response) { |
|
448 |
app.sessionExpired(); |
|
449 |
} |
|
450 |
}; |
|
451 |
updateFolder.setHeader("X-Auth-Token", app.getToken()); |
|
452 |
String readPermHeader = "read="; |
|
453 |
String writePermHeader = "write="; |
|
454 |
for (String u : newPermissions.keySet()) { |
|
455 |
Boolean[] p = newPermissions.get(u); |
|
456 |
if (p[0] != null && p[0]) |
|
457 |
readPermHeader += u + ","; |
|
458 |
if (p[1] != null && p[1]) |
|
459 |
writePermHeader += u + ","; |
|
460 |
} |
|
461 |
if (readPermHeader.endsWith("=")) |
|
462 |
readPermHeader = ""; |
|
463 |
else if (readPermHeader.endsWith(",")) |
|
464 |
readPermHeader = readPermHeader.substring(0, readPermHeader.length() - 1); |
|
465 |
if (writePermHeader.endsWith("=")) |
|
466 |
writePermHeader = ""; |
|
467 |
else if (writePermHeader.endsWith(",")) |
|
468 |
writePermHeader = writePermHeader.substring(0, writePermHeader.length() - 1); |
|
469 |
String permHeader = readPermHeader + ((readPermHeader.length() > 0 && writePermHeader.length() > 0) ? ";" : "") + writePermHeader; |
|
470 |
if (permHeader.length() == 0) |
|
471 |
permHeader = "~"; |
|
472 |
else |
|
473 |
permHeader = URL.encodePathSegment(permHeader); |
|
474 |
updateFolder.setHeader("X-Object-Sharing", permHeader); |
|
475 |
Scheduler.get().scheduleDeferred(updateFolder); |
|
476 |
} |
|
477 |
else |
|
478 | 343 |
app.updateFolder(folder.getParent(), false, new Command() { |
479 |
|
|
480 |
@Override |
|
481 |
public void execute() { |
|
482 |
app.updateMySharedRoot(); |
|
483 |
} |
|
484 |
}); |
|
485 |
} |
|
486 |
|
|
487 |
public void selectTab(int _tab) { |
|
488 |
inner.selectTab(_tab); |
|
344 |
|
|
345 |
@Override |
|
346 |
public void execute() { |
|
347 |
app.updateMySharedRoot(); |
|
348 |
} |
|
349 |
}); |
|
489 | 350 |
} |
490 | 351 |
} |
Also available in: Unified diff