mirror of https://github.com/mastodon/mastodon
				
				
				
			Fix: remove broken OAuth Application vacuuming & throttle OAuth Application registrations (#30316)
Co-authored-by: Claire <claire.github-309c@sitedethib.com>pull/30473/head
							parent
							
								
									6eea83211c
								
							
						
					
					
						commit
						d20a5c3ec9
					
				| @ -1,10 +0,0 @@ | ||||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Vacuum::ApplicationsVacuum | ||||
|   def perform | ||||
|     Doorkeeper::Application.where(owner_id: nil) | ||||
|                            .where.missing(:created_users, :access_tokens, :access_grants) | ||||
|                            .where(created_at: ...1.day.ago) | ||||
|                            .in_batches.delete_all | ||||
|   end | ||||
| end | ||||
| @ -1,48 +0,0 @@ | ||||
| # frozen_string_literal: true | ||||
| 
 | ||||
| require 'rails_helper' | ||||
| 
 | ||||
| RSpec.describe Vacuum::ApplicationsVacuum do | ||||
|   subject { described_class.new } | ||||
| 
 | ||||
|   describe '#perform' do | ||||
|     let!(:app_with_token)  { Fabricate(:application, created_at: 1.month.ago) } | ||||
|     let!(:app_with_grant)  { Fabricate(:application, created_at: 1.month.ago) } | ||||
|     let!(:app_with_signup) { Fabricate(:application, created_at: 1.month.ago) } | ||||
|     let!(:app_with_owner)  { Fabricate(:application, created_at: 1.month.ago, owner: Fabricate(:user)) } | ||||
|     let!(:unused_app)      { Fabricate(:application, created_at: 1.month.ago) } | ||||
|     let!(:recent_app)      { Fabricate(:application, created_at: 1.hour.ago) } | ||||
| 
 | ||||
|     before do | ||||
|       Fabricate(:access_token, application: app_with_token) | ||||
|       Fabricate(:access_grant, application: app_with_grant) | ||||
|       Fabricate(:user, created_by_application: app_with_signup) | ||||
| 
 | ||||
|       subject.perform | ||||
|     end | ||||
| 
 | ||||
|     it 'does not delete applications with valid access tokens' do | ||||
|       expect { app_with_token.reload }.to_not raise_error | ||||
|     end | ||||
| 
 | ||||
|     it 'does not delete applications with valid access grants' do | ||||
|       expect { app_with_grant.reload }.to_not raise_error | ||||
|     end | ||||
| 
 | ||||
|     it 'does not delete applications that were used to create users' do | ||||
|       expect { app_with_signup.reload }.to_not raise_error | ||||
|     end | ||||
| 
 | ||||
|     it 'does not delete owned applications' do | ||||
|       expect { app_with_owner.reload }.to_not raise_error | ||||
|     end | ||||
| 
 | ||||
|     it 'does not delete applications registered less than a day ago' do | ||||
|       expect { recent_app.reload }.to_not raise_error | ||||
|     end | ||||
| 
 | ||||
|     it 'deletes unused applications' do | ||||
|       expect { unused_app.reload }.to raise_error ActiveRecord::RecordNotFound | ||||
|     end | ||||
|   end | ||||
| end | ||||
					Loading…
					
					
				
		Reference in New Issue