Added an option for user credentials on user menu
[pithos-web-client] / src / gr / grnet / pithos / web / client / FilePropertiesDialog.java
index b574bbc..989d8c9 100644 (file)
  */\r
 package gr.grnet.pithos.web.client;\r
 \r
-import com.google.gwt.core.client.Scheduler;\r
-import com.google.gwt.user.client.Window;\r
-import com.google.gwt.user.client.ui.Anchor;\r
-import com.google.gwt.user.client.ui.Label;\r
 import gr.grnet.pithos.web.client.foldertree.File;\r
+import gr.grnet.pithos.web.client.foldertree.FileVersions;\r
 import gr.grnet.pithos.web.client.foldertree.Resource;\r
-import gr.grnet.pithos.web.client.rest.PostCommand;\r
+import gr.grnet.pithos.web.client.foldertree.Version;\r
+import gr.grnet.pithos.web.client.rest.GetRequest;\r
 import gr.grnet.pithos.web.client.rest.PostRequest;\r
 import gr.grnet.pithos.web.client.rest.PutRequest;\r
 import gr.grnet.pithos.web.client.rest.RestException;\r
+import gr.grnet.pithos.web.client.tagtree.Tag;\r
+\r
+import java.util.List;\r
+import java.util.Map;\r
 \r
 import com.google.gwt.core.client.GWT;\r
+import com.google.gwt.core.client.Scheduler;\r
 import com.google.gwt.event.dom.client.ClickEvent;\r
 import com.google.gwt.event.dom.client.ClickHandler;\r
+import com.google.gwt.http.client.Response;\r
 import com.google.gwt.i18n.client.DateTimeFormat;\r
-import com.google.gwt.json.client.JSONBoolean;\r
-import com.google.gwt.json.client.JSONObject;\r
-import com.google.gwt.resources.client.ClientBundle;\r
 import com.google.gwt.resources.client.ImageResource;\r
-import com.google.gwt.user.client.DeferredCommand;\r
+import com.google.gwt.user.client.Window;\r
+import com.google.gwt.user.client.ui.Anchor;\r
 import com.google.gwt.user.client.ui.Button;\r
 import com.google.gwt.user.client.ui.CheckBox;\r
 import com.google.gwt.user.client.ui.DecoratedTabPanel;\r
@@ -63,10 +65,9 @@ import com.google.gwt.user.client.ui.FlowPanel;
 import com.google.gwt.user.client.ui.FocusPanel;\r
 import com.google.gwt.user.client.ui.HasHorizontalAlignment;\r
 import com.google.gwt.user.client.ui.HorizontalPanel;\r
+import com.google.gwt.user.client.ui.Label;\r
 import com.google.gwt.user.client.ui.TextBox;\r
 import com.google.gwt.user.client.ui.VerticalPanel;\r
-import gr.grnet.pithos.web.client.tagtree.Tag;\r
-import java.util.Map;\r
 \r
 /**\r
  * The 'File properties' dialog box implementation.\r
@@ -74,19 +75,19 @@ import java.util.Map;
  */\r
 public class FilePropertiesDialog extends AbstractPropertiesDialog {\r
 \r
-       private PermissionsList permList;\r
+       protected PermissionsList permList;\r
 \r
-       private CheckBox readForAll;\r
+       protected CheckBox readForAll;\r
 \r
        /**\r
         * An image bundle for this widgets images.\r
         */\r
-       public interface Images extends ClientBundle,MessagePanel.Images {\r
+       public interface Images extends MessagePanel.Images {\r
 \r
                @Source("gr/grnet/pithos/resources/edit_user.png")\r
                ImageResource permUser();\r
 \r
-               @Source("gr/grnet/pithos/resources/groupevent.png")\r
+               @Source("gr/grnet/pithos/resources/groups22.png")\r
                ImageResource permGroup();\r
 \r
                @Source("gr/grnet/pithos/resources/editdelete.png")\r
@@ -130,8 +131,8 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
 \r
         inner.add(createSharingPanel(), "Sharing");\r
 \r
-        inner.add(createVersionPanel(), "Versions");\r
-\r
+               fetchVersions();\r
+                       \r
         inner.selectTab(0);\r
 \r
         outer.add(inner);\r
@@ -141,7 +142,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
                // when the button is clicked.\r
                final Button ok = new Button("OK", new ClickHandler() {\r
                        @Override\r
-                       public void onClick(ClickEvent event) {\r
+                       public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                                accept();\r
                                closeDialog();\r
                        }\r
@@ -153,7 +154,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
                // dialog when the button is clicked.\r
                final Button cancel = new Button("Cancel", new ClickHandler() {\r
                        @Override\r
-                       public void onClick(ClickEvent event) {\r
+                       public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                                closeDialog();\r
                        }\r
                });\r
@@ -170,7 +171,34 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
         setWidget(outer);\r
        }\r
 \r
-    private VerticalPanel createGeneralPanel() {\r
+    protected void fetchVersions() {\r
+       String path = file.getUri() + "?format=json&version=list";\r
+       GetRequest<FileVersions> getVersions = new GetRequest<FileVersions>(FileVersions.class, app.getApiPath(), file.getOwner(), path) {\r
+\r
+                       @Override\r
+                       public void onSuccess(FileVersions _result) {\r
+                       inner.add(createVersionPanel(_result.getVersions()), "Versions");\r
+                       }\r
+\r
+                       @Override\r
+                       public void onError(Throwable t) {\r
+                if (t instanceof RestException) {\r
+                    app.displayError("Unable to fetch versions: " + ((RestException) t).getHttpStatusText());\r
+                }\r
+                else\r
+                    app.displayError("System error unable to fetch versions: "+t.getMessage());\r
+                       }\r
+\r
+                       @Override\r
+                       protected void onUnauthorized(Response response) {\r
+                               app.sessionExpired();\r
+                       }\r
+               };\r
+               getVersions.setHeader("X-Auth-Token", app.getToken());\r
+               Scheduler.get().scheduleDeferred(getVersions);\r
+       }\r
+\r
+       private VerticalPanel createGeneralPanel() {\r
         final VerticalPanel generalPanel = new VerticalPanel();\r
         final FlexTable generalTable = new FlexTable();\r
         generalTable.setText(0, 0, "Name");\r
@@ -228,7 +256,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
             tagAnchor.addClickHandler(new ClickHandler() {\r
 \r
                 @Override\r
-                public void onClick(ClickEvent event) {\r
+                public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                     String existing = tags.getText().trim();\r
                     if (MULTIPLE_VALUES_TEXT.equals(existing))\r
                         existing = "";\r
@@ -256,7 +284,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
             HorizontalPanel permButtons = new HorizontalPanel();\r
             Button add = new Button("Add Group", new ClickHandler() {\r
                 @Override\r
-                public void onClick(ClickEvent event) {\r
+                public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                     PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, false);\r
                     dlg.center();\r
                     permList.updatePermissionTable();\r
@@ -267,7 +295,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
 \r
             final Button addUser = new Button("Add User", new ClickHandler() {\r
                 @Override\r
-                public void onClick(ClickEvent event) {\r
+                public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                     PermissionsAddDialog dlg = new PermissionsAddDialog(app, app.getAccount().getGroups(), permList, true);\r
                     dlg.center();\r
                     permList.updatePermissionTable();\r
@@ -291,7 +319,7 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
         readForAll.setValue(file.isPublished());\r
         readForAll.addClickHandler(new ClickHandler() {\r
             @Override\r
-            public void onClick(ClickEvent event) {\r
+            public void onClick(@SuppressWarnings("unused") ClickEvent event) {\r
                 readForAllNote.setVisible(readForAll.getValue());\r
             }\r
         });\r
@@ -336,56 +364,10 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
         return permPanel;\r
     }\r
 \r
-    private VerticalPanel createVersionPanel() {\r
+    VerticalPanel createVersionPanel(List<Version> versions) {\r
         VerticalPanel versionPanel = new VerticalPanel();\r
-\r
-//        VersionsList verList = new VersionsList(this, images, bodies);\r
-//        versionPanel.add(verList);\r
-//\r
-//        HorizontalPanel vPanel = new HorizontalPanel();\r
-//\r
-//             vPanel.setSpacing(8);\r
-//             vPanel.addStyleName("pithos-TabPanelBottom");\r
-//             vPanel.add(new Label("Versioned"));\r
-//\r
-//             versioned.setValue(file.isVersioned());\r
-//             vPanel.add(versioned);\r
-//             versionPanel.add(vPanel);\r
-//\r
-//        HorizontalPanel vPanel2 = new HorizontalPanel();\r
-//             vPanel2.setSpacing(8);\r
-//             vPanel2.addStyleName("pithos-TabPanelBottom");\r
-//\r
-//        HTML removeAllVersion = new HTML("<span>Remove all previous versions?</span>");\r
-//        vPanel2.add(removeAllVersion);\r
-//\r
-//             Button removeVersionsButton = new Button(AbstractImagePrototype.create(images.delete()).getHTML(), new ClickHandler() {\r
-//                     @Override\r
-//                     public void onClick(ClickEvent event) {\r
-//                             ConfirmationDialog confirm = new ConfirmationDialog("Really " +\r
-//                                             "remove all previous versions?", "Remove") {\r
-//\r
-//                                     @Override\r
-//                                     public void cancel() {\r
-//                                     }\r
-//\r
-//                                     @Override\r
-//                                     public void confirm() {\r
-//                                             FilePropertiesDialog.this.closeDialog();\r
-//                                             removeAllOldVersions();\r
-//                                     }\r
-//\r
-//                             };\r
-//                             confirm.center();\r
-//                     }\r
-//\r
-//             });\r
-//             vPanel2.add(removeVersionsButton);\r
-//        if(!file.isVersioned())\r
-//            vPanel2.setVisible(false);\r
-//\r
-//        versionPanel.add(vPanel2);\r
-\r
+        VersionsList verList = new VersionsList(app, this, images, file, versions);\r
+        versionPanel.add(verList);\r
         return versionPanel;\r
     }\r
 \r
@@ -412,15 +394,15 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
 \r
         String[] tagset = null;\r
                if (!tags.getText().equals(initialTagText))\r
-                       tagset = tags.getText().split(",");\r
+                       tagset = tags.getText().trim().split(",");\r
         final String[] newTags = tagset;\r
 \r
         if (newFilename != null) {\r
             final String path = file.getParent().getUri() + "/" + newFilename;\r
             PutRequest updateFile = new PutRequest(app.getApiPath(), app.getUsername(), path) {\r
                 @Override\r
-                public void onSuccess(Resource result) {\r
-                    updateMetaData(app.getApiPath(), app.getUsername(), path + "?update=", newTags, finalPublished, perms);\r
+                public void onSuccess(@SuppressWarnings("unused") Resource result) {\r
+                    updateMetaData(app.getApiPath(), file.getOwner(), path + "?update=", newTags, finalPublished, perms);\r
                 }\r
 \r
                 @Override\r
@@ -428,6 +410,11 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
                     GWT.log("", t);\r
                     app.displayError("System error modifying file:" + t.getMessage());\r
                 }\r
+\r
+                               @Override\r
+                               protected void onUnauthorized(Response response) {\r
+                                       app.sessionExpired();\r
+                               }\r
             };\r
             updateFile.setHeader("X-Auth-Token", app.getToken());\r
             updateFile.setHeader("X-Move-From", file.getUri());\r
@@ -438,12 +425,12 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
             updateMetaData(app.getApiPath(), app.getUsername(), file.getUri() + "?update=", newTags, finalPublished, perms);\r
        }\r
 \r
-    private void updateMetaData(String api, String owner, String path, String[] newTags, Boolean published, Map<String, Boolean[]> newPermissions) {\r
+       protected void updateMetaData(String api, String owner, String path, String[] newTags, Boolean published, Map<String, Boolean[]> newPermissions) {\r
         if (newTags != null || published != null || newPermissions != null) {\r
             PostRequest updateFile = new PostRequest(api, owner, path) {\r
                 @Override\r
-                public void onSuccess(Resource result) {\r
-                    app.updateFolder(file.getParent(), true);\r
+                public void onSuccess(@SuppressWarnings("unused") Resource result) {\r
+                    app.updateFolder(file.getParent(), true, null);\r
                 }\r
 \r
                 @Override\r
@@ -451,16 +438,24 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
                     GWT.log("", t);\r
                     app.displayError("System error modifying file:" + t.getMessage());\r
                 }\r
+\r
+                               @Override\r
+                               protected void onUnauthorized(Response response) {\r
+                                       app.sessionExpired();\r
+                               }\r
             };\r
             updateFile.setHeader("X-Auth-Token", app.getToken());\r
             if (newTags != null)\r
                 for (String t : newTags)\r
-                    updateFile.setHeader("X-Object-Meta-" + t.trim(), "true");\r
+                       if (t.length() > 0)\r
+                               updateFile.setHeader("X-Object-Meta-" + t.trim(), "true");\r
+                for (String t : file.getTags())\r
+                       updateFile.setHeader("X-Object-Meta-" + t.trim(), "~");\r
             if (published != null)\r
                 updateFile.setHeader("X-Object-Public", published.toString());\r
             if (newPermissions != null) {\r
-                String readPermHeader = "read=" + owner + ",";\r
-                String writePermHeader = "write=" + owner + ",";\r
+                String readPermHeader = "read=";\r
+                String writePermHeader = "write=";\r
                 for (String u : newPermissions.keySet()) {\r
                     Boolean[] p = newPermissions.get(u);\r
                     if (p[0] != null && p[0])\r
@@ -468,19 +463,22 @@ public class FilePropertiesDialog extends AbstractPropertiesDialog {
                     if (p[1] != null && p[1])\r
                         writePermHeader += u + ",";\r
                 }\r
-                if (readPermHeader.endsWith(","))\r
+                if (readPermHeader.endsWith("="))\r
+                    readPermHeader = "";\r
+                else if (readPermHeader.endsWith(","))\r
                     readPermHeader = readPermHeader.substring(0, readPermHeader.length() - 1);\r
-                if (writePermHeader.endsWith(","))\r
+                if (writePermHeader.endsWith("="))\r
+                    writePermHeader = "";\r
+                else if (writePermHeader.endsWith(","))\r
                     writePermHeader = writePermHeader.substring(0, writePermHeader.length() - 1);\r
-                String permHeader = readPermHeader +  ";" + writePermHeader;\r
+                String permHeader = readPermHeader +  ((readPermHeader.length()  > 0 && writePermHeader.length() > 0) ?  ";" : "") + writePermHeader;\r
+                if (permHeader.length() == 0)\r
+                    permHeader="~";\r
                 updateFile.setHeader("X-Object-Sharing", permHeader);\r
             }\r
             Scheduler.get().scheduleDeferred(updateFile);\r
         }\r
         else\r
-            app.updateFolder(file.getParent(), true);\r
+            app.updateFolder(file.getParent(), true, null);\r
     }\r
-\r
-       private void removeAllOldVersions() {\r
-       }\r
 }\r