diff --git a/apps/dashboard/app/controllers/files_controller.rb b/apps/dashboard/app/controllers/files_controller.rb index f737a4a57b..b71e581d59 100644 --- a/apps/dashboard/app/controllers/files_controller.rb +++ b/apps/dashboard/app/controllers/files_controller.rb @@ -13,7 +13,7 @@ def fs if @path.directory? @path.raise_if_cant_access_directory_contents - request.format = 'zip' if params[:download] + request.format = 'zip' if download? respond_to do |format| @@ -25,7 +25,12 @@ def fs response.headers['Cache-Control'] = 'no-store' if params[:can_download] # check to see if this directory can be downloaded as a zip - can_download, error_message = @path.can_download_as_zip? + can_download, error_message = if ::Configuration.download_enabled? + @path.can_download_as_zip? + else + [false, t('dashboard.files_download_not_enabled')] + end + render json: { can_download: can_download, error_message: error_message } else @files = @path.ls @@ -39,7 +44,11 @@ def fs # and we can avoid rescuing in a block so we can reintroduce # the block braces which is the Rails convention with the respond_to formats. format.zip do - can_download, error_message = @path.can_download_as_zip? + can_download, error_message = if ::Configuration.download_enabled? + @path.can_download_as_zip? + else + raise(StandardError, t('dashboard.files_download_not_enabled')) + end if can_download zipname = @path.basename.to_s.gsub('"', '\"') + '.zip' @@ -211,6 +220,10 @@ def posix_file? @path.is_a?(PosixFile) end + def download? + params[:download] + end + def uppy_upload_path # careful: # @@ -226,6 +239,8 @@ def uppy_upload_path end def show_file + raise(StandardError, t('dashboard.files_download_not_enabled')) unless ::Configuration.download_enabled? + if posix_file? send_posix_file else @@ -237,7 +252,7 @@ def send_posix_file type = Files.mime_type_by_extension(@path).presence || PosixFile.new(@path).mime_type # svgs aren't safe to view until we update our CSP - if params[:download] || type.to_s == 'image/svg+xml' + if download? || type.to_s == 'image/svg+xml' type = 'text/plain; charset=utf-8' if type.to_s == 'image/svg+xml' send_file @path, type: type else @@ -261,7 +276,7 @@ def send_remote_file end # svgs aren't safe to view until we update our CSP - download = params[:download] || type.to_s == "image/svg+xml" + download = download? || type.to_s == "image/svg+xml" type = "text/plain; charset=utf-8" if type.to_s == "image/svg+xml" response.set_header('X-Accel-Buffering', 'no') diff --git a/apps/dashboard/app/views/files/_download_button.html.erb b/apps/dashboard/app/views/files/_download_button.html.erb new file mode 100644 index 0000000000..cfb42f21ef --- /dev/null +++ b/apps/dashboard/app/views/files/_download_button.html.erb @@ -0,0 +1,5 @@ +<%- if Configuration.download_enabled? -%> + +<%- end -%> diff --git a/apps/dashboard/app/views/files/_file_action_menu.html.erb b/apps/dashboard/app/views/files/_file_action_menu.html.erb index f687118377..cf386678e7 100755 --- a/apps/dashboard/app/views/files/_file_action_menu.html.erb +++ b/apps/dashboard/app/views/files/_file_action_menu.html.erb @@ -13,7 +13,9 @@
  • Edit
  • {{/if}}
  • Rename
  • + <%- if Configuration.download_enabled? -%>
  • Download
  • + <%- end -%>
  • Delete
  • diff --git a/apps/dashboard/app/views/files/_inline_js.html.erb b/apps/dashboard/app/views/files/_inline_js.html.erb index 4619d5d957..4bae262bb1 100755 --- a/apps/dashboard/app/views/files/_inline_js.html.erb +++ b/apps/dashboard/app/views/files/_inline_js.html.erb @@ -6,7 +6,7 @@ history.replaceState({ currentDirectoryUrl: '<%= files_path(@filesystem, @path) %>', currentDirectoryUpdatedAt: '<%= Time.now.to_i %>', currentFilesPath: '<%= files_path(@filesystem, '/') %>', - currentFilesUploadPath: '<%= url_for(fs: @filesystem, action: 'upload') %>', + currentFilesUploadPath: '<%= url_for(fs: @filesystem, action: 'upload') if Configuration.upload_enabled? %>', currentFilesystem: '<%= @filesystem %>' }, null); diff --git a/apps/dashboard/app/views/files/_upload_button.html.erb b/apps/dashboard/app/views/files/_upload_button.html.erb new file mode 100644 index 0000000000..5d312a0063 --- /dev/null +++ b/apps/dashboard/app/views/files/_upload_button.html.erb @@ -0,0 +1,5 @@ +<%- if Configuration.upload_enabled? -%> + +<%- end -%> diff --git a/apps/dashboard/app/views/files/index.html.erb b/apps/dashboard/app/views/files/index.html.erb index 8a9b32d9eb..7838216ca4 100644 --- a/apps/dashboard/app/views/files/index.html.erb +++ b/apps/dashboard/app/views/files/index.html.erb @@ -9,8 +9,8 @@ - - + <%= render(partial: 'upload_button') %> + <%= render(partial: 'download_button') %> <% if Configuration.globus_endpoints %> <%= render partial: 'globus' %> <% end %> diff --git a/apps/dashboard/app/views/files/index.json.jbuilder b/apps/dashboard/app/views/files/index.json.jbuilder index 9f2d425ccc..860f84b224 100644 --- a/apps/dashboard/app/views/files/index.json.jbuilder +++ b/apps/dashboard/app/views/files/index.json.jbuilder @@ -3,7 +3,7 @@ json.url files_path(@filesystem, @path).to_s #TODO: support array of shell urls, along with the default shell url which could be above json.shell_url OodAppkit.shell.url(path: @path.to_s).to_s json.files_path files_path(@filesystem, '/') -json.files_upload_path url_for(fs: @filesystem, action: 'upload') +json.files_upload_path url_for(fs: @filesystem, action: 'upload') if Configuration.upload_enabled? json.filesystem @filesystem json.files @files do |f| diff --git a/apps/dashboard/config/configuration_singleton.rb b/apps/dashboard/config/configuration_singleton.rb index c2671a3a0b..1ea77bc711 100644 --- a/apps/dashboard/config/configuration_singleton.rb +++ b/apps/dashboard/config/configuration_singleton.rb @@ -50,6 +50,8 @@ def boolean_configs :cancel_session_enabled => false, :hide_app_version => false, :motd_render_html => false, + :upload_enabled => true, + :download_enabled => true, }.freeze end diff --git a/apps/dashboard/config/locales/en.yml b/apps/dashboard/config/locales/en.yml index 9f9149b3cc..d56a09a509 100644 --- a/apps/dashboard/config/locales/en.yml +++ b/apps/dashboard/config/locales/en.yml @@ -209,6 +209,7 @@ en: recently_used_apps_title: 'Recently Used Apps' + files_download_not_enabled: "Downloading files is not enabled on this server." files_directory_download_error_modal_title: "Directory too large to download" files_directory_download_unauthorized: "You can only download a directory as zip that you have read and execute access to" files_directory_download_size_0: "The directory size is 0 and has no contents for download." diff --git a/apps/dashboard/config/routes.rb b/apps/dashboard/config/routes.rb index d5bdf85e4a..d28a6bad9b 100644 --- a/apps/dashboard/config/routes.rb +++ b/apps/dashboard/config/routes.rb @@ -25,7 +25,7 @@ get "files/api/v1/:fs(/*filepath)" => "files#fs", :defaults => { :fs => 'fs', :format => 'html' }, :format => false put "files/api/v1/:fs/*filepath" => "files#update", :format => false, :defaults => { :fs => 'fs', :format => 'json' } end - post "files/upload/:fs" => "files#upload", :defaults => { :fs => 'fs' } + post "files/upload/:fs" => "files#upload", :defaults => { :fs => 'fs' } if Configuration.upload_enabled? get "files", to: redirect("files/fs#{Dir.home}")