ConnectionsController.cs 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. using FastReport.Data;
  2. using FastReport.Utils;
  3. using FastReport.Web.Services;
  4. using Microsoft.AspNetCore.Mvc;
  5. using System;
  6. using System.Collections;
  7. using System.Collections.Generic;
  8. using System.ComponentModel;
  9. using System.IO;
  10. using System.Net;
  11. using System.Text;
  12. using System.Text.Encodings.Web;
  13. using FastReport.Web.Infrastructure;
  14. using Microsoft.AspNetCore.Http;
  15. namespace FastReport.Web.Controllers
  16. {
  17. static partial class Controllers
  18. {
  19. public sealed class ConnectionsParams
  20. {
  21. public string ConnectionType { get; set; }
  22. public string ConnectionString { get; set; }
  23. }
  24. public sealed class ConnectionTablesRequestModel
  25. {
  26. public ConnectionsParams ConnectionsParams { get; set; }
  27. public List<CustomViewModel> CustomViews { get; set; }
  28. }
  29. [HttpGet("/designer.getConnectionTypes")]
  30. public static IResult GetConnectionTypes([FromQuery] string needSqlSupportInfo, IConnectionsService connectionsService)
  31. {
  32. var isNeedSqlSupport = bool.TryParse(needSqlSupportInfo, out var parsedBool) && parsedBool;
  33. var response = connectionsService.GetConnectionTypes(isNeedSqlSupport);
  34. var content = "{" + string.Join(",", response.ToArray()) + "}";
  35. return Results.Content(content, "application/json");
  36. }
  37. [Obsolete]
  38. [HttpGet("/designer.getConnectionTables")]
  39. public static IResult GetConnectionTables([FromQuery] ConnectionsParams query,
  40. IConnectionsService connectionsService)
  41. {
  42. var request = new ConnectionTablesRequestModel
  43. {
  44. ConnectionsParams = query,
  45. CustomViews = new()
  46. };
  47. return GetConnectionTables(request, connectionsService);
  48. }
  49. [HttpPost("/designer.getConnectionTables")]
  50. public static IResult GetConnectionTables([FromBody] ConnectionTablesRequestModel request, IConnectionsService connectionsService)
  51. {
  52. try
  53. {
  54. var response = connectionsService.GetConnectionTables(request.ConnectionsParams.ConnectionType, request.ConnectionsParams.ConnectionString, request.CustomViews);
  55. return Results.Content(response, "application/xml");
  56. }
  57. catch (Exception ex)
  58. {
  59. return Results.BadRequest(ex.Message);
  60. }
  61. }
  62. [HttpPost("/designer.makeConnectionString")]
  63. public static IResult MakeConnectionString(string connectionType,
  64. IConnectionsService connectionsService,
  65. HttpRequest request)
  66. {
  67. var form = request.Form;
  68. var response = connectionsService.CreateConnectionStringJSON(connectionType, form, out var isError);
  69. return isError
  70. ? Results.Content(response, "text/plain")
  71. : Results.Content(response, "application/xml");
  72. }
  73. [HttpGet("/designer.getConnectionStringProperties")]
  74. public static IResult GetConnectionStringProperties([FromQuery] ConnectionsParams query,
  75. IConnectionsService connectionsService)
  76. {
  77. var response = connectionsService.GetConnectionStringPropertiesJSON(query.ConnectionType, query.ConnectionString, out var isError);
  78. return isError
  79. ? Results.Content(response, "text/plain")
  80. : Results.Content(response, "application/xml");
  81. }
  82. }
  83. }