diff --git a/Rest.Net/Rest.Net.csproj b/Rest.Net/Rest.Net.csproj index 8e7f716..7504c34 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.8.0 + 1.8.1 Logo_Symbol_Black_Outline.png diff --git a/Rest.Net/RestJavascriptClientGenerator.cs b/Rest.Net/RestJavascriptClientGenerator.cs index ccce9ed..2635e5b 100644 --- a/Rest.Net/RestJavascriptClientGenerator.cs +++ b/Rest.Net/RestJavascriptClientGenerator.cs @@ -38,27 +38,16 @@ namespace MontoyaTech.Rest.Net writer.WriteBreak().WriteLine($"class {this.ClientName} {{").Indent(); //Create the base url field - if (this.StaticCode) - { - writer.WriteBreak().WriteLine("/** @type {string} */"); - writer.WriteLine("static BaseUrl = null;"); - } - else - { - writer.WriteBreak().WriteLine("/** @type {string} */"); - writer.WriteLine("BaseUrl = null;"); - } + writer.WriteBreak().WriteLine("/** @type {string} */"); + writer.WriteAssert(this.StaticCode, "static ").WriteLine("BaseUrl = null;"); + + //Create the url handler field + writer.WriteBreak().WriteLine("/** @type {Function} */"); + writer.WriteAssert(this.StaticCode, "static ").WriteLine("UrlHandler = null;"); //Create the request handler field. - if (this.StaticCode) - { - writer.WriteBreak().WriteLine("/** @type {Function} */"); - } - else - { - writer.WriteBreak().WriteLine("/** @type {Function} */"); - - } + writer.WriteBreak().WriteLine("/** @type {Function} */"); + writer.WriteAssert(this.StaticCode, "static ").WriteLine("RequestHandler = null;"); //Create fields foreach route group so they can be accessed. if (!this.StaticCode) @@ -73,12 +62,13 @@ namespace MontoyaTech.Rest.Net //Create the client constructor or init method if (this.StaticCode) { - writer.WriteBreak().WriteLine("/**").Indent(); - writer.WriteLine("Initializes the api client with a given baseUrl of where to send requests."); - writer.WriteLine("@param {string} baseUrl"); + writer.WriteLine("Initializes this api client with a given baseUrl of where to send requests."); + writer.WriteLine("@param {string} baseUrl Base url of the server to make requests against."); + writer.WriteLine("@param {Function} urlHandler An optional function to process request urls before they are sent. This must return the url."); + writer.WriteLine("@param {Function} requestHandler An optional function to process requests before they are sent. This must return the request."); writer.Outdent().WriteLine("*/"); - writer.Write("static Init(baseUrl, requestHandler) ").WriteLine("{").Indent(); + writer.Write("static Init(baseUrl, urlHandler = null, requestHandler = null) ").WriteLine("{").Indent(); //Make sure the baseUrl isn't null or whitespace writer.WriteBreak().WriteLine("if (baseUrl == null || baseUrl == undefined || baseUrl.trim() == '') {").Indent(); @@ -93,12 +83,23 @@ namespace MontoyaTech.Rest.Net //Store the baseUrl writer.WriteBreak().WriteLine($"{this.ClientName}.BaseUrl = baseUrl;"); + //Store the urlHandler + writer.WriteBreak().WriteLine($"{this.ClientName}.UrlHandler = urlHandler;"); + + //Store the requestHandler + writer.WriteBreak().WriteLine($"{this.ClientName}.RequestHandler = requestHandler;"); + writer.Outdent().WriteLine("}"); } else { - writer.WriteBreak().WriteLine("/** @param {string} baseUrl */"); - writer.Write("constructor(baseUrl) ").WriteLine("{").Indent(); + writer.WriteBreak().WriteLine("/**").Indent(); + writer.WriteLine("Initializes this api client with a given baseUrl of where to send requests."); + writer.WriteLine("@param {string} baseUrl Base url of the server to make requests against."); + writer.WriteLine("@param {Function} urlHandler An optional function to process request urls before they are sent. This must return the url."); + writer.WriteLine("@param {Function} requestHandler An optional function to process requests before they are sent. This must return the request."); + writer.Outdent().WriteLine("*/"); + writer.Write("constructor(baseUrl, urlHandler = null, requestHandler = null) ").WriteLine("{").Indent(); //Make sure the baseUrl isn't null or whitespace writer.WriteBreak().WriteLine("if (baseUrl == null || baseUrl == undefined || baseUrl.trim() == '') {").Indent(); @@ -113,8 +114,15 @@ namespace MontoyaTech.Rest.Net //Store the baseUrl writer.WriteBreak().WriteLine("this.BaseUrl = baseUrl;"); + //Store the urlHandler + writer.WriteBreak().WriteLine($"this.UrlHandler = urlHandler;"); + + //Store the request handler + writer.WriteBreak().WriteLine("this.RequestHandler = requestHandler;"); + //Init all the route group fields writer.WriteBreak(); + foreach (var group in routeGroups) writer.WriteLine($"this.{group.Key} = new {group.Key}Api(this);"); @@ -547,15 +555,14 @@ namespace MontoyaTech.Rest.Net writer.WriteLine(") {").Indent(); - //Generate function body - - writer.WriteLine("var response = await fetch(").Indent(); + //Generate the url + writer.WriteBreak().Write("var url = "); //Generate the request url if (this.StaticCode) - writer.WriteSeparator().Write('`').Write($"${{{this.ClientName}.BaseUrl}}"); + writer.Write('`').Write($"${{{this.ClientName}.BaseUrl}}"); else - writer.WriteSeparator().Write('`').Write("${this.Client.BaseUrl}"); + writer.Write('`').Write("${this.Client.BaseUrl}"); //Reconstruct the route syntax into a request url. var components = route.Syntax.Split('/'); @@ -586,7 +593,10 @@ namespace MontoyaTech.Rest.Net } } - writer.WriteLine("`, {").Indent(); + writer.WriteLine("`;"); + + //Generate the request + writer.WriteBreak().WriteLine("var request = {").Indent(); //Include credentials writer.WriteLine("credentials: 'include',"); @@ -613,10 +623,26 @@ namespace MontoyaTech.Rest.Net } } - writer.Outdent().WriteLine("}"); + writer.Outdent().WriteLine("};"); - writer.Outdent().WriteLine(");"); + //Generate the response + writer.WriteBreak().Write("var response = await fetch("); + if (this.StaticCode) + writer.Write($"{this.ClientName}.UrlHandler ? {this.ClientName}.UrlHandler(url) : url"); + else + writer.Write($"this.Client.UrlHandler ? this.Client.UrlHandler(url) : url"); + + writer.WriteSeparator(); + + if (this.StaticCode) + writer.Write($"{this.ClientName}.RequestHandler ? {this.ClientName}.RequestHandler(request) : request"); + else + writer.Write("this.Client.RequestHandler ? this.Client.RequestHandler(request) : request"); + + writer.WriteLine(");"); + + //Generate code to handle the response if (routeResponse != null) { writer.WriteBreak().WriteLine("if (response.ok) {").Indent(); @@ -678,9 +704,9 @@ namespace MontoyaTech.Rest.Net } } - writer.Outdent().WriteLine("} else {").Indent(); - writer.WriteLine("throw response;"); writer.Outdent().WriteLine("}"); + + writer.WriteBreak().WriteLine("throw response;"); } else {