DatabaseInfoService.cs 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. using Attribute;
  2. using Model;
  3. using Model.Base;
  4. using Repository;
  5. using Service;
  6. using Microsoft.AspNetCore.Mvc;
  7. using Vo.Admin;
  8. using Dto.Admin;
  9. using Custom;
  10. using Common;
  11. namespace Services
  12. {
  13. /// <summary>
  14. /// 数据库配置Service业务层处理
  15. /// </summary>
  16. [AppService(ServiceType = typeof(IDatabaseInfoService), ServiceLifetime = LifeTime.Transient)]
  17. public class DatabaseInfoService : BaseService<DatabaseInfo>, IDatabaseInfoService
  18. {
  19. /// <summary>
  20. /// 数据库配置-列表
  21. /// </summary>
  22. /// <param name="param">参数请求体</param>
  23. /// <param name="page">分页参数</param>
  24. /// <returns>列表</returns>
  25. public PagedInfo<GetDatabaseInfoListVo> getDatabaseInfoList([FromQuery] PagerInfo page, [FromQuery] DatabaseInfo param)
  26. {
  27. //拼装查询条件
  28. var predicate = Expressionable.Create<DatabaseInfo>();
  29. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.dbName), m => m.dbName.Contains(param.dbName));
  30. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.hostAddress), m => m.hostAddress.Contains(param.hostAddress));
  31. var response = Queryable()
  32. .Where(predicate.ToExpression())
  33. .OrderByDescending(m => m.id)
  34. .ToPage<DatabaseInfo, GetDatabaseInfoListVo>(page);
  35. return response;
  36. }
  37. /// <summary>
  38. /// 生成SQL脚本
  39. /// </summary>
  40. /// <param name="param">参数请求体</param>
  41. /// <returns>生成</returns>
  42. public void makeDatabaseInfo([FromBody] MakeDatabaseInfoDto param, List<DatabaseTable> tables, List<DatabaseField> fields, TokenModel loginUser)
  43. {
  44. DatabaseInfo databaseInfo = GetById(param.id) ?? new DatabaseInfo();
  45. foreach(DatabaseTable table in tables)
  46. {
  47. table.fields = fields.Where(m => m.tableId == table.id).ToList();
  48. }
  49. MakeData makeData = new();
  50. string requestId = DateTime.Now.ToString("yyyyMMddHHmmssfff") + Function.get_Random(8);
  51. makeData.requestId = requestId;
  52. makeData.modePath = "Sql/db.sql";
  53. Dictionary<string, string> attach = new();
  54. attach.Add("id", param.id.ToString());
  55. attach.Add("kind", "db");
  56. attach.Add("operator", loginUser.username);
  57. makeData.attach = Newtonsoft.Json.JsonConvert.SerializeObject(attach);
  58. makeData.data = new Dictionary<string, object>();
  59. makeData.data.Add("databaseInfo", databaseInfo);
  60. makeData.data.Add("databaseTable", tables);
  61. RabbitMQClient.Instance.Push("MakeSqlQueue", Newtonsoft.Json.JsonConvert.SerializeObject(makeData));
  62. }
  63. }
  64. }