diff --git a/docs-web/src/main/java/com/sismics/docs/rest/resource/AuditLogResource.java b/docs-web/src/main/java/com/sismics/docs/rest/resource/AuditLogResource.java index 3b431a95d..b87c3b7e9 100644 --- a/docs-web/src/main/java/com/sismics/docs/rest/resource/AuditLogResource.java +++ b/docs-web/src/main/java/com/sismics/docs/rest/resource/AuditLogResource.java @@ -9,6 +9,7 @@ import javax.ws.rs.QueryParam; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; +import javax.ws.rs.core.Response.Status; import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONObject; @@ -55,7 +56,7 @@ public Response list(@QueryParam("document") String documentId) throws JSONExcep // Check ACL on the document AclDao aclDao = new AclDao(); if (!aclDao.checkPermission(documentId, PermType.READ, principal.getId())) { - throw new ForbiddenClientException(); + return Response.status(Status.NOT_FOUND).build(); } criteria.setDocumentId(documentId); } diff --git a/docs-web/src/main/java/com/sismics/docs/rest/resource/DocumentResource.java b/docs-web/src/main/java/com/sismics/docs/rest/resource/DocumentResource.java index c276e44a0..a0c8ba444 100644 --- a/docs-web/src/main/java/com/sismics/docs/rest/resource/DocumentResource.java +++ b/docs-web/src/main/java/com/sismics/docs/rest/resource/DocumentResource.java @@ -20,6 +20,7 @@ import javax.ws.rs.QueryParam; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; +import javax.ws.rs.core.Response.Status; import org.apache.commons.lang.StringUtils; import org.codehaus.jettison.json.JSONException; @@ -92,7 +93,7 @@ public Response get( throw new ForbiddenClientException(); } } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + return Response.status(Status.NOT_FOUND).build(); } JSONObject document = new JSONObject(); @@ -430,7 +431,7 @@ public Response update( try { document = documentDao.getDocument(id, PermType.WRITE, principal.getId()); } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", id)); + return Response.status(Status.NOT_FOUND).build(); } // Update the document @@ -514,7 +515,7 @@ public Response delete( document = documentDao.getDocument(id, PermType.WRITE, principal.getId()); fileList = fileDao.getByDocumentId(principal.getId(), id); } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", id)); + return Response.status(Status.NOT_FOUND).build(); } // Delete the document diff --git a/docs-web/src/main/java/com/sismics/docs/rest/resource/FileResource.java b/docs-web/src/main/java/com/sismics/docs/rest/resource/FileResource.java index f86383f48..5e1a65f81 100644 --- a/docs-web/src/main/java/com/sismics/docs/rest/resource/FileResource.java +++ b/docs-web/src/main/java/com/sismics/docs/rest/resource/FileResource.java @@ -102,7 +102,7 @@ public Response add( try { document = documentDao.getDocument(documentId, PermType.WRITE, principal.getId()); } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + return Response.status(Status.NOT_FOUND).build(); } } @@ -199,7 +199,7 @@ public Response attach( file = fileDao.getFile(id, principal.getId()); document = documentDao.getDocument(documentId, PermType.WRITE, principal.getId()); } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + return Response.status(Status.NOT_FOUND).build(); } // Check that the file is orphan @@ -259,7 +259,7 @@ public Response reorder( try { documentDao.getDocument(documentId, PermType.WRITE, principal.getId()); } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + return Response.status(Status.NOT_FOUND).build(); } // Reorder files @@ -295,13 +295,9 @@ public Response list( // Check document visibility if (documentId != null) { - try { - AclDao aclDao = new AclDao(); - if (!aclDao.checkPermission(documentId, PermType.READ, shareId == null ? principal.getId() : shareId)) { - throw new ForbiddenClientException(); - } - } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + AclDao aclDao = new AclDao(); + if (!aclDao.checkPermission(documentId, PermType.READ, shareId == null ? principal.getId() : shareId)) { + return Response.status(Status.NOT_FOUND).build(); } } else if (!authenticated) { throw new ForbiddenClientException(); @@ -358,7 +354,7 @@ public Response delete( documentDao.getDocument(file.getDocumentId(), PermType.WRITE, principal.getId()); } } catch (NoResultException e) { - throw new ClientException("FileNotFound", MessageFormat.format("File not found: {0}", id)); + return Response.status(Status.NOT_FOUND).build(); } // Delete the file @@ -498,7 +494,7 @@ public Response zip( throw new ForbiddenClientException(); } } catch (NoResultException e) { - throw new ClientException("DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); + return Response.status(Status.NOT_FOUND).build(); } // Get files and user associated with this document diff --git a/docs-web/src/main/webapp/src/app/docs/controller/DocumentView.js b/docs-web/src/main/webapp/src/app/docs/controller/DocumentView.js index fe80252a5..8962c8841 100644 --- a/docs-web/src/main/webapp/src/app/docs/controller/DocumentView.js +++ b/docs-web/src/main/webapp/src/app/docs/controller/DocumentView.js @@ -7,6 +7,8 @@ angular.module('docs').controller('DocumentView', function ($scope, $state, $sta // Load document data from server Restangular.one('document', $stateParams.id).get().then(function(data) { $scope.document = data; + }, function(response) { + $scope.error = response; }); // Load audit log data from server diff --git a/docs-web/src/main/webapp/src/app/docs/directive/ImgError.js b/docs-web/src/main/webapp/src/app/docs/directive/ImgError.js new file mode 100644 index 000000000..78772edd3 --- /dev/null +++ b/docs-web/src/main/webapp/src/app/docs/directive/ImgError.js @@ -0,0 +1,16 @@ +'use strict'; + +/** + * Image error event directive. + */ +angular.module('docs').directive('imgError', function() { + return { + restrict: 'A', + link: function(scope, element, attrs) { + element.bind('error', function() { + //call the function that was passed + scope.$apply(attrs.imgError); + }); + } + }; +}) \ No newline at end of file diff --git a/docs-web/src/main/webapp/src/index.html b/docs-web/src/main/webapp/src/index.html index ce5a6e971..6247f46b2 100644 --- a/docs-web/src/main/webapp/src/index.html +++ b/docs-web/src/main/webapp/src/index.html @@ -64,6 +64,7 @@ +
diff --git a/docs-web/src/main/webapp/src/partial/docs/document.view.html b/docs-web/src/main/webapp/src/partial/docs/document.view.html index 439880908..2643b426f 100644 --- a/docs-web/src/main/webapp/src/partial/docs/document.view.html +++ b/docs-web/src/main/webapp/src/partial/docs/document.view.html @@ -1,4 +1,11 @@ - + + ++ + Document not found +
++ + File not found +