Browse Source
			
			
			Merge pull request #3547 from BlackDex/GH-3540
			
				Prevent 401 on main admin page
			
			
				pull/3548/head
			
			
		 
		
			
				
					
						 Mathijs van Veluw
					
					2 years ago
						Mathijs van Veluw
					
					2 years ago
					
						
							committed by
							
								 GitHub
								GitHub
							
						 
					
				 
				
			 
		 
		
			
				
					
					No known key found for this signature in database
					
						
							GPG Key ID: 4AEE18F83AFDEB23
						
					
				
			
		
		
		
	
		
			
				 1 changed files with 
17 additions and 
1 deletions
			 
			
		 
		
			
				- 
					
					
					 
					src/api/admin.rs
				
				
				
					
						
							
								
									
	
		
			
				
					|  |  | @ -36,6 +36,7 @@ pub fn routes() -> Vec<Route> { | 
			
		
	
		
			
				
					|  |  |  |         get_user_by_mail_json, | 
			
		
	
		
			
				
					|  |  |  |         post_admin_login, | 
			
		
	
		
			
				
					|  |  |  |         admin_page, | 
			
		
	
		
			
				
					|  |  |  |         admin_page_login, | 
			
		
	
		
			
				
					|  |  |  |         invite_user, | 
			
		
	
		
			
				
					|  |  |  |         logout, | 
			
		
	
		
			
				
					|  |  |  |         delete_user, | 
			
		
	
	
		
			
				
					|  |  | @ -256,6 +257,11 @@ fn admin_page(_token: AdminToken) -> ApiResult<Html<String>> { | 
			
		
	
		
			
				
					|  |  |  |     render_admin_page() | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[get("/", rank = 2)] | 
			
		
	
		
			
				
					|  |  |  | fn admin_page_login() -> ApiResult<Html<String>> { | 
			
		
	
		
			
				
					|  |  |  |     render_admin_login(None, None) | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | #[derive(Deserialize, Debug)] | 
			
		
	
		
			
				
					|  |  |  | #[allow(non_snake_case)] | 
			
		
	
		
			
				
					|  |  |  | struct InviteData { | 
			
		
	
	
		
			
				
					|  |  | @ -761,7 +767,17 @@ impl<'r> FromRequest<'r> for AdminToken { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             let access_token = match cookies.get(COOKIE_NAME) { | 
			
		
	
		
			
				
					|  |  |  |                 Some(cookie) => cookie.value(), | 
			
		
	
		
			
				
					|  |  |  |                 None => return Outcome::Failure((Status::Unauthorized, "Unauthorized")), | 
			
		
	
		
			
				
					|  |  |  |                 None => { | 
			
		
	
		
			
				
					|  |  |  |                     let requested_page = | 
			
		
	
		
			
				
					|  |  |  |                         request.segments::<std::path::PathBuf>(0..).unwrap_or_default().display().to_string(); | 
			
		
	
		
			
				
					|  |  |  |                     // When the requested page is empty, it is `/admin`, in that case, Forward, so it will render the login page
 | 
			
		
	
		
			
				
					|  |  |  |                     // Else, return a 401 failure, which will be caught
 | 
			
		
	
		
			
				
					|  |  |  |                     if requested_page.is_empty() { | 
			
		
	
		
			
				
					|  |  |  |                         return Outcome::Forward(Status::Unauthorized); | 
			
		
	
		
			
				
					|  |  |  |                     } else { | 
			
		
	
		
			
				
					|  |  |  |                         return Outcome::Failure((Status::Unauthorized, "Unauthorized")); | 
			
		
	
		
			
				
					|  |  |  |                     } | 
			
		
	
		
			
				
					|  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |             }; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |             if decode_admin(access_token).is_err() { | 
			
		
	
	
		
			
				
					|  |  | 
 |