mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-18 14:00:41 +01:00
Fix search params being dropped when redirected to non-deck path (#31984)
This commit is contained in:
parent
83574f641a
commit
3dc4ddc663
4 changed files with 18 additions and 3 deletions
|
@ -31,7 +31,7 @@ module WebAppControllerConcern
|
||||||
def redirect_unauthenticated_to_permalinks!
|
def redirect_unauthenticated_to_permalinks!
|
||||||
return if user_signed_in? && current_account.moved_to_account_id.nil?
|
return if user_signed_in? && current_account.moved_to_account_id.nil?
|
||||||
|
|
||||||
permalink_redirector = PermalinkRedirector.new(request.path)
|
permalink_redirector = PermalinkRedirector.new(request.original_fullpath)
|
||||||
return if permalink_redirector.redirect_path.blank?
|
return if permalink_redirector.redirect_path.blank?
|
||||||
|
|
||||||
expires_in(15.seconds, public: true, stale_while_revalidate: 30.seconds, stale_if_error: 1.day) unless user_signed_in?
|
expires_in(15.seconds, public: true, stale_while_revalidate: 30.seconds, stale_if_error: 1.day) unless user_signed_in?
|
||||||
|
|
|
@ -186,7 +186,7 @@ class SwitchingColumnsArea extends PureComponent {
|
||||||
{redirect}
|
{redirect}
|
||||||
|
|
||||||
{singleColumn ? <Redirect from='/deck' to='/home' exact /> : null}
|
{singleColumn ? <Redirect from='/deck' to='/home' exact /> : null}
|
||||||
{singleColumn && pathName.startsWith('/deck/') ? <Redirect from={pathName} to={pathName.slice(5)} /> : null}
|
{singleColumn && pathName.startsWith('/deck/') ? <Redirect from={pathName} to={{...this.props.location, pathname: pathName.slice(5)}} /> : null}
|
||||||
{/* Redirect old bookmarks (without /deck) with home-like routes to the advanced interface */}
|
{/* Redirect old bookmarks (without /deck) with home-like routes to the advanced interface */}
|
||||||
{!singleColumn && pathName === '/getting-started' ? <Redirect from='/getting-started' to='/deck/getting-started' exact /> : null}
|
{!singleColumn && pathName === '/getting-started' ? <Redirect from='/getting-started' to='/deck/getting-started' exact /> : null}
|
||||||
{!singleColumn && pathName === '/home' ? <Redirect from='/home' to='/deck/getting-started' exact /> : null}
|
{!singleColumn && pathName === '/home' ? <Redirect from='/home' to='/deck/getting-started' exact /> : null}
|
||||||
|
|
|
@ -83,6 +83,6 @@ class PermalinkRedirector
|
||||||
end
|
end
|
||||||
|
|
||||||
def path_segments
|
def path_segments
|
||||||
@path_segments ||= @path.delete_prefix('/deck').delete_prefix('/').split('/')
|
@path_segments ||= @path.split('?')[0].delete_prefix('/deck').delete_prefix('/').split('/')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -29,5 +29,20 @@ RSpec.describe PermalinkRedirector do
|
||||||
redirector = described_class.new('@alice/123')
|
redirector = described_class.new('@alice/123')
|
||||||
expect(redirector.redirect_path).to eq 'https://example.com/status-123'
|
expect(redirector.redirect_path).to eq 'https://example.com/status-123'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'returns path for legacy status links with a query param' do
|
||||||
|
redirector = described_class.new('statuses/123?foo=bar')
|
||||||
|
expect(redirector.redirect_path).to eq 'https://example.com/status-123'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns path for pretty status links with a query param' do
|
||||||
|
redirector = described_class.new('@alice/123?foo=bar')
|
||||||
|
expect(redirector.redirect_path).to eq 'https://example.com/status-123'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'returns path for deck URLs with query params' do
|
||||||
|
redirector = described_class.new('/deck/directory?local=true')
|
||||||
|
expect(redirector.redirect_path).to eq '/directory?local=true'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue