mirror of
				https://github.com/nsnail/Ocelot.git
				synced 2025-10-25 08:49:24 +08:00 
			
		
		
		
	changes to add new feature to url routing (#186)
This commit is contained in:
		| @@ -9,6 +9,7 @@ namespace Ocelot.Configuration.Creator | ||||
|         private const string RegExMatchEndString = "$"; | ||||
|         private const string RegExIgnoreCase = "(?i)"; | ||||
|         private const string RegExForwardSlashOnly = "^/$"; | ||||
|         private const string RegExForwardSlashAndOnePlaceHolder = "^/.*"; | ||||
|  | ||||
|         public string Create(FileReRoute reRoute) | ||||
|         { | ||||
| @@ -22,8 +23,13 @@ namespace Ocelot.Configuration.Creator | ||||
|                 { | ||||
|                     var postitionOfPlaceHolderClosingBracket = upstreamTemplate.IndexOf('}', i); | ||||
|                     var difference = postitionOfPlaceHolderClosingBracket - i + 1; | ||||
|                     var variableName = upstreamTemplate.Substring(i, difference); | ||||
|                     placeholders.Add(variableName); | ||||
|                     var placeHolderName = upstreamTemplate.Substring(i, difference); | ||||
|                     placeholders.Add(placeHolderName); | ||||
|  | ||||
|                     if(ForwardSlashAndOnePlaceHolder(upstreamTemplate, placeholders, postitionOfPlaceHolderClosingBracket)) | ||||
|                     { | ||||
|                         return RegExForwardSlashAndOnePlaceHolder; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| @@ -49,6 +55,16 @@ namespace Ocelot.Configuration.Creator | ||||
|             return route; | ||||
|         } | ||||
|  | ||||
|         private bool ForwardSlashAndOnePlaceHolder(string upstreamTemplate, List<string> placeholders, int postitionOfPlaceHolderClosingBracket) | ||||
|         { | ||||
|             if(upstreamTemplate.Substring(0, 2) == "/{" && placeholders.Count == 1 && upstreamTemplate.Length == postitionOfPlaceHolderClosingBracket + 1) | ||||
|             {    | ||||
|                 return true; | ||||
|             } | ||||
|  | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|  | ||||
|         private bool IsPlaceHolder(string upstreamTemplate, int i) | ||||
|         { | ||||
|   | ||||
| @@ -38,6 +38,7 @@ namespace Ocelot.DownstreamRouteFinder.Middleware | ||||
|  | ||||
|             //todo make this getting config its own middleware one day? | ||||
|             var configuration = await _configProvider.Get();  | ||||
|              | ||||
|             if(configuration.IsError) | ||||
|             { | ||||
|                 _logger.LogError($"{MiddlewareName} setting pipeline errors. IOcelotConfigurationProvider returned {configuration.Errors.ToErrorString()}"); | ||||
|   | ||||
| @@ -33,6 +33,34 @@ namespace Ocelot.AcceptanceTests | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_return_response_200_with_forward_slash_and_placeholder_only() | ||||
|         { | ||||
|             var configuration = new FileConfiguration | ||||
|             { | ||||
|                 ReRoutes = new List<FileReRoute> | ||||
|                     { | ||||
|                         new FileReRoute | ||||
|                         { | ||||
|                             DownstreamPathTemplate = "/{url}", | ||||
|                             DownstreamScheme = "http", | ||||
|                             DownstreamHost = "localhost", | ||||
|                             DownstreamPort = 51879, | ||||
|                             UpstreamPathTemplate = "/{url}", | ||||
|                             UpstreamHttpMethod = new List<string> { "Get" }, | ||||
|                         } | ||||
|                     } | ||||
|             }; | ||||
|  | ||||
|             this.Given(x => x.GivenThereIsAServiceRunningOn("http://localhost:51879", "", 200, "Hello from Laura")) | ||||
|                 .And(x => _steps.GivenThereIsAConfiguration(configuration)) | ||||
|                 .And(x => _steps.GivenOcelotIsRunning()) | ||||
|                 .When(x => _steps.WhenIGetUrlOnTheApiGateway("/")) | ||||
|                 .Then(x => _steps.ThenTheStatusCodeShouldBe(HttpStatusCode.OK)) | ||||
|                 .And(x => _steps.ThenTheResponseBodyShouldBe("Hello from Laura")) | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_return_response_200_with_simple_url() | ||||
|         { | ||||
| @@ -275,6 +303,35 @@ namespace Ocelot.AcceptanceTests | ||||
|         } | ||||
|  | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_return_response_200_with_complex_url_that_starts_with_placeholder() | ||||
|         { | ||||
|             var configuration = new FileConfiguration | ||||
|             { | ||||
|                 ReRoutes = new List<FileReRoute> | ||||
|                     { | ||||
|                         new FileReRoute | ||||
|                         { | ||||
|                             DownstreamPathTemplate = "/api/{variantId}/products/{productId}", | ||||
|                             DownstreamScheme = "http", | ||||
|                             DownstreamHost = "localhost", | ||||
|                             DownstreamPort = 51879, | ||||
|                             UpstreamPathTemplate = "/{variantId}/products/{productId}", | ||||
|                             UpstreamHttpMethod = new List<string> { "Get" }, | ||||
|                         } | ||||
|                     } | ||||
|             }; | ||||
|  | ||||
|             this.Given(x => x.GivenThereIsAServiceRunningOn("http://localhost:51879", "/api/23/products/1", 200, "Some Product")) | ||||
|                 .And(x => _steps.GivenThereIsAConfiguration(configuration)) | ||||
|                 .And(x => _steps.GivenOcelotIsRunning()) | ||||
|                 .When(x => _steps.WhenIGetUrlOnTheApiGateway("23/products/1")) | ||||
|                 .Then(x => _steps.ThenTheStatusCodeShouldBe(HttpStatusCode.OK)) | ||||
|                 .And(x => _steps.ThenTheResponseBodyShouldBe("Some Product")) | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_not_add_trailing_slash_to_downstream_url() | ||||
|         { | ||||
|   | ||||
| @@ -121,6 +121,35 @@ namespace Ocelot.UnitTests.Configuration | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_create_template_pattern_that_matches_to_end_of_string_when_slash_and_placeholder() | ||||
|         { | ||||
|             var fileReRoute = new FileReRoute | ||||
|             { | ||||
|                 UpstreamPathTemplate = "/{url}" | ||||
|             }; | ||||
|  | ||||
|             this.Given(x => x.GivenTheFollowingFileReRoute(fileReRoute)) | ||||
|                 .When(x => x.WhenICreateTheTemplatePattern()) | ||||
|                 .Then(x => x.ThenTheFollowingIsReturned("^/.*")) | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public void should_create_template_pattern_that_starts_with_placeholder_then_has_another_later() | ||||
|         { | ||||
|             var fileReRoute = new FileReRoute | ||||
|             { | ||||
|                 UpstreamPathTemplate = "/{productId}/products/variants/{variantId}/", | ||||
|                 ReRouteIsCaseSensitive = true | ||||
|             }; | ||||
|  | ||||
|             this.Given(x => x.GivenTheFollowingFileReRoute(fileReRoute)) | ||||
|                 .When(x => x.WhenICreateTheTemplatePattern()) | ||||
|                 .Then(x => x.ThenTheFollowingIsReturned("^/[0-9a-zA-Z].*/products/variants/[0-9a-zA-Z].*(/|)$")) | ||||
|                 .BDDfy(); | ||||
|         } | ||||
|  | ||||
|         private void GivenTheFollowingFileReRoute(FileReRoute fileReRoute) | ||||
|         { | ||||
|             _fileReRoute = fileReRoute; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Tom Pallister
					Tom Pallister