aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2020-02-17 01:34:51 +0200
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2020-02-17 01:34:51 +0200
commit6b59b18966fa95b24d8813752f5a1ba1fd730660 (patch)
tree2745287dca8601cc44e31ed689866086cf6fdc09 /Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs
parent7d746ab2f2979794c46f7f54a7f7100080993086 (diff)
downloadTango-6b59b18966fa95b24d8813752f5a1ba1fd730660.tar.gz
Tango-6b59b18966fa95b24d8813752f5a1ba1fd730660.zip
Started basic design of FSE skeletons.
Diffstat (limited to 'Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs')
-rw-r--r--Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs26
1 files changed, 26 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs b/Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs
index 6bbcd1884..b05e6e311 100644
--- a/Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs
+++ b/Software/Visual_Studio/Utilities/Tango.WebClientGenerator/Program.cs
@@ -21,6 +21,9 @@ namespace Tango.WebClientGenerator
//Generate Machine Studio client.
GenerateWebClient<MachineStudio.Common.Web.LoginRequest, MachineStudio.Common.Web.LoginResponse, MachineService.Controllers.MachineStudioController>("Tango.MachineStudio.Common.Web", "MachineStudioWebClientBase", PathHelper.GetSolutionFolder() + @"\MachineStudio\Tango.MachineStudio.Common\Web");
+
+ //Generate FSE client.
+ GenerateWebClientV2<FSE.Web.Messages.LoginRequest, FSE.Web.Messages.LoginResponse, MachineService.Controllers.FSEController>("Tango.FSE.Common.Web", "FSEWebClientBase", PathHelper.GetSolutionFolder() + @"\FSE\Tango.FSE.Common\Web");
}
private static void GenerateWebClient<TLoginRequest, TLoginResponse, TController>(String nameSpace, String name, String path) where TLoginRequest : WebRequestMessage where TLoginResponse : WebTokenResponse where TController : TangoController
@@ -45,5 +48,28 @@ namespace Tango.WebClientGenerator
String code = model.GenerateCode();
File.WriteAllText(Path.Combine(path, name + ".cs"), code);
}
+
+ private static void GenerateWebClientV2<TLoginRequest, TLoginResponse, TController>(String nameSpace, String name, String path) where TLoginRequest : WebRequestMessage where TLoginResponse : WebTokenResponse where TController : TangoController
+ {
+ TangoWebClientv2CodeFile model = new TangoWebClientv2CodeFile();
+ model.Namespace = nameSpace;
+ model.ControllerName = typeof(TController).Name.Replace("Controller", "");
+ model.Name = name;
+ model.LoginRequest = typeof(TLoginRequest).FullName;
+ model.LoginResponse = typeof(TLoginResponse).FullName;
+
+ foreach (var action in typeof(TController).GetMethods().Where(x => typeof(WebResponseMessage).IsAssignableFrom(x.ReturnType) && x.Name != "Login"))
+ {
+ model.Actions.Add(new TangoWebClientv2CodeFile.ControllerAction()
+ {
+ Name = action.Name,
+ Request = action.GetParameters()[0].ParameterType.FullName,
+ Response = action.ReturnType.FullName,
+ });
+ }
+
+ String code = model.GenerateCode();
+ File.WriteAllText(Path.Combine(path, name + ".cs"), code);
+ }
}
}