diff --git a/Rest.Net.Example/Program.cs b/Rest.Net.Example/Program.cs index 01091bd..a18e771 100644 --- a/Rest.Net.Example/Program.cs +++ b/Rest.Net.Example/Program.cs @@ -8,6 +8,7 @@ using System.IO; using MontoyaTech.Rest.Net; using System.Net.Mime; using System.Collections; +using Newtonsoft.Json.Linq; namespace MontoyaTech.Rest.Net.Example { @@ -80,6 +81,7 @@ namespace MontoyaTech.Rest.Net.Example new Route(HttpRequestMethod.Get, "/auth/{username}", Exists), new Route(HttpRequestMethod.Post, "/auth/signup", Signup), new Route(HttpRequestMethod.Get, "/auth/", Json), + new Route(HttpRequestMethod.Get, "/auth/dynamic", Dynamic), new Route(HttpRequestMethod.Get, "/auth/role", GetRole), new Route(HttpRequestMethod.Post, "/upload", Upload), new Route(HttpRequestMethod.Get, "/download", Download), @@ -208,6 +210,13 @@ namespace MontoyaTech.Rest.Net.Example return context.Response.WithStatus(HttpStatusCode.OK).WithJson(new User("Rest.Net")); } + [RouteGroup("Auth")] + [RouteResponse(typeof(JObject))] + public static HttpListenerResponse Dynamic(HttpListenerContext context) + { + return context.Response.WithStatus(HttpStatusCode.OK).WithJson(777); + } + [RouteGroup("Stream")] [RouteRequest(typeof(MemoryStream))] public static HttpListenerResponse Upload(HttpListenerContext context) diff --git a/Rest.Net/Rest.Net.csproj b/Rest.Net/Rest.Net.csproj index 78df348..a119ca5 100644 --- a/Rest.Net/Rest.Net.csproj +++ b/Rest.Net/Rest.Net.csproj @@ -17,7 +17,7 @@ MontoyaTech.Rest.Net MontoyaTech.Rest.Net True - 1.7.4 + 1.7.5 Logo_Symbol_Black_Outline.png diff --git a/Rest.Net/RestClientGenerator.cs b/Rest.Net/RestClientGenerator.cs index d9e73b3..8e11355 100644 --- a/Rest.Net/RestClientGenerator.cs +++ b/Rest.Net/RestClientGenerator.cs @@ -1,4 +1,4 @@ -using System; +using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.ComponentModel.Design; @@ -69,11 +69,14 @@ namespace MontoyaTech.Rest.Net { foreach (var argument in arguments) { - var types = this.FindTypeDependencies(argument); + if (argument != type) + { + var types = this.FindTypeDependencies(argument); - for (int i = 0; i < types.Count; i++) - if (!dependencies.Contains(types[i])) - dependencies.Add(types[i]); + for (int i = 0; i < types.Count; i++) + if (!dependencies.Contains(types[i])) + dependencies.Add(types[i]); + } } } @@ -99,7 +102,7 @@ namespace MontoyaTech.Rest.Net { foreach (var field in fields) { - if (field.IsPublic && !field.IsSpecialName) + if (field.IsPublic && !field.IsSpecialName && field.FieldType != type) { var types = this.FindTypeDependencies(field.FieldType); @@ -116,7 +119,7 @@ namespace MontoyaTech.Rest.Net { foreach (var property in properties) { - if (!property.IsSpecialName && property.GetSetMethod() != null && property.GetGetMethod() != null) + if (!property.IsSpecialName && property.GetSetMethod() != null && property.GetGetMethod() != null && property.PropertyType != type) { var types = this.FindTypeDependencies(property.PropertyType);