Fix /api/v1/tags/:id route constraints (#18854)
The constraint was applied prior to decoding, and rejected anything containing the '%' character, which would be used for anything with non-ASCII unicode characters.
This commit is contained in:
		
							parent
							
								
									f8b3e36929
								
							
						
					
					
						commit
						726931fe4a
					
				| @ -24,6 +24,7 @@ class Api::V1::TagsController < Api::BaseController | ||||
|   private | ||||
| 
 | ||||
|   def set_or_create_tag | ||||
|     return not_found unless /\A(#{Tag::HASHTAG_NAME_RE})\z/.match?(params[:id]) | ||||
|     @tag = Tag.find_normalized(params[:id]) || Tag.new(name: Tag.normalize(params[:id]), display_name: params[:id]) | ||||
|   end | ||||
| end | ||||
|  | ||||
| @ -530,7 +530,7 @@ Rails.application.routes.draw do | ||||
|         resource :note, only: :create, controller: 'accounts/notes' | ||||
|       end | ||||
| 
 | ||||
|       resources :tags, only: [:show], constraints: { id: /#{Tag::HASHTAG_NAME_RE}/ } do | ||||
|       resources :tags, only: [:show] do | ||||
|         member do | ||||
|           post :follow | ||||
|           post :unfollow | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user