mirror of
				https://github.com/discourse/discourse.git
				synced 2025-02-25 18:55:32 -06:00 
			
		
		
		
	SECURITY: Don't pass email backup token to sidekiq as a parameter.
* This exposes the token in the Sidekiq dashboard which can be viewed by an admin and defeats the purpose of using a token in the download backup email ink.
This commit is contained in:
		| @@ -127,27 +127,6 @@ describe Admin::BackupsController do | ||||
|  | ||||
|     end | ||||
|  | ||||
|     describe ".email" do | ||||
|  | ||||
|       let(:b) { Backup.new(backup_filename) } | ||||
|  | ||||
|       it "enqueues email job" do | ||||
|         Backup.expects(:[]).with(backup_filename).returns(b) | ||||
|         Jobs.expects(:enqueue).with(:download_backup_email, has_entries(to_address: @admin.email)) | ||||
|  | ||||
|         put :email, params: { id: backup_filename }, format: :json | ||||
|  | ||||
|         expect(response).to be_success | ||||
|       end | ||||
|  | ||||
|       it "returns 404 when the backup does not exist" do | ||||
|         put :email, params: { id: backup_filename }, format: :json | ||||
|  | ||||
|         expect(response).to be_not_found | ||||
|       end | ||||
|  | ||||
|     end | ||||
|  | ||||
|     describe ".destroy" do | ||||
|  | ||||
|       let(:b) { Backup.new(backup_filename) } | ||||
|   | ||||
							
								
								
									
										22
									
								
								spec/jobs/download_backup_email_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								spec/jobs/download_backup_email_spec.rb
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| require 'rails_helper' | ||||
|  | ||||
| RSpec.describe Jobs::DownloadBackupEmail do | ||||
|   let(:user) { Fabricate(:admin) } | ||||
|  | ||||
|   it "should work" do | ||||
|     described_class.new.execute( | ||||
|       user_id: user.id, | ||||
|       backup_file_path: "http://some.example.test/" | ||||
|     ) | ||||
|  | ||||
|     email = ActionMailer::Base.deliveries.last | ||||
|  | ||||
|     expect(email.subject).to eq(I18n.t('download_backup_mailer.subject_template', | ||||
|       email_prefix: SiteSetting.title | ||||
|     )) | ||||
|  | ||||
|     expect(email.body.raw_source).to eq(I18n.t('download_backup_mailer.text_body_template', | ||||
|       backup_file_path: "http://some.example.test/?token=#{EmailBackupToken.get(user.id)}" | ||||
|     )) | ||||
|   end | ||||
| end | ||||
| @@ -36,4 +36,29 @@ RSpec.describe Admin::BackupsController do | ||||
|         .to raise_error(ActionController::RoutingError) | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   describe "#email" do | ||||
|     let(:backup_filename) { "test.tar.gz" } | ||||
|     let(:backup) { Backup.new(backup_filename) } | ||||
|  | ||||
|     it "enqueues email job" do | ||||
|       Backup.expects(:[]).with(backup_filename).returns(backup) | ||||
|  | ||||
|       Jobs.expects(:enqueue).with(:download_backup_email, | ||||
|         user_id: admin.id, | ||||
|         backup_file_path: 'http://www.example.com/admin/backups/test.tar.gz' | ||||
|       ) | ||||
|  | ||||
|       put "/admin/backups/#{backup_filename}.json" | ||||
|  | ||||
|       expect(response).to be_success | ||||
|     end | ||||
|  | ||||
|     it "returns 404 when the backup does not exist" do | ||||
|       put "/admin/backups/#{backup_filename}.json" | ||||
|  | ||||
|       expect(response).to be_not_found | ||||
|     end | ||||
|  | ||||
|   end | ||||
| end | ||||
|   | ||||
		Reference in New Issue
	
	Block a user