/** * Returns files linked to a document. * * @param documentId Document ID * @return Response * @throws JSONException */ @GET @Path("list") @Produces(MediaType.APPLICATION_JSON) public Response list(@QueryParam("id") String documentId, @QueryParam("share") String shareId) throws JSONException { authenticate(); // Check document visibility try { DocumentDao documentDao = new DocumentDao(); Document document = documentDao.getDocument(documentId); ShareDao shareDao = new ShareDao(); if (!shareDao.checkVisibility(document, principal.getId(), shareId)) { throw new ForbiddenClientException(); } } catch (NoResultException e) { throw new ClientException( "DocumentNotFound", MessageFormat.format("Document not found: {0}", documentId)); } FileDao fileDao = new FileDao(); List<File> fileList = fileDao.getByDocumentId(documentId); JSONObject response = new JSONObject(); List<JSONObject> files = new ArrayList<>(); for (File fileDb : fileList) { JSONObject file = new JSONObject(); file.put("id", fileDb.getId()); file.put("mimetype", fileDb.getMimeType()); file.put("document_id", fileDb.getDocumentId()); file.put("create_date", fileDb.getCreateDate().getTime()); files.add(file); } response.put("files", files); return Response.ok().entity(response).build(); }
/** * Returns a file. * * @param fileId File ID * @return Response * @throws JSONException */ @GET @Path("{id: [a-z0-9\\-]+}/data") @Produces(MediaType.APPLICATION_OCTET_STREAM) public Response data( @PathParam("id") final String fileId, @QueryParam("share") String shareId, @QueryParam("size") String size) throws JSONException { authenticate(); if (size != null) { if (!Lists.newArrayList("web", "thumb").contains(size)) { throw new ClientException("SizeError", "Size must be web or thumb"); } } // Get the file FileDao fileDao = new FileDao(); DocumentDao documentDao = new DocumentDao(); UserDao userDao = new UserDao(); File file; Document document; try { file = fileDao.getFile(fileId); document = documentDao.getDocument(file.getDocumentId()); // Check document visibility ShareDao shareDao = new ShareDao(); if (!shareDao.checkVisibility(document, principal.getId(), shareId)) { throw new ForbiddenClientException(); } } catch (NoResultException e) { throw new ClientException( "FileNotFound", MessageFormat.format("File not found: {0}", fileId)); } // Get the stored file java.io.File storedfile; String mimeType; boolean decrypt = false; if (size != null) { storedfile = Paths.get(DirectoryUtil.getStorageDirectory().getPath(), fileId + "_" + size).toFile(); mimeType = MimeType.IMAGE_JPEG; // Thumbnails are JPEG decrypt = true; // Thumbnails are encrypted if (!storedfile.exists()) { storedfile = new java.io.File(getClass().getResource("/image/file.png").getFile()); mimeType = MimeType.IMAGE_PNG; decrypt = false; } } else { storedfile = Paths.get(DirectoryUtil.getStorageDirectory().getPath(), fileId).toFile(); mimeType = file.getMimeType(); decrypt = true; // Original files are encrypted } // Stream the output and decrypt it if necessary StreamingOutput stream; User user = userDao.getById(document.getUserId()); try { InputStream fileInputStream = new FileInputStream(storedfile); final InputStream responseInputStream = decrypt ? EncryptionUtil.decryptInputStream(fileInputStream, user.getPrivateKey()) : fileInputStream; stream = new StreamingOutput() { @Override public void write(OutputStream outputStream) throws IOException, WebApplicationException { try { ByteStreams.copy(responseInputStream, outputStream); } finally { responseInputStream.close(); outputStream.close(); } } }; } catch (Exception e) { throw new ServerException("FileError", "Error while reading the file", e); } return Response.ok(stream) .header("Content-Type", mimeType) .header( "Expires", new SimpleDateFormat("EEE, dd MMM yyyy HH:mm:ss Z") .format(new Date().getTime() + 3600000 * 24)) .build(); }