SysEnumService.cs 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core.Service;
  7. /// <summary>
  8. /// 系统枚举服务 🧩
  9. /// </summary>
  10. [ApiDescriptionSettings(Order = 275)]
  11. [AllowAnonymous]
  12. public class SysEnumService : IDynamicApiController, ITransient
  13. {
  14. private readonly EnumOptions _enumOptions;
  15. public SysEnumService(IOptions<EnumOptions> enumOptions)
  16. {
  17. _enumOptions = enumOptions.Value;
  18. }
  19. /// <summary>
  20. /// 获取所有枚举类型 🔖
  21. /// </summary>
  22. /// <returns></returns>
  23. [DisplayName("获取所有枚举类型")]
  24. public List<EnumTypeOutput> GetEnumTypeList()
  25. {
  26. var enumTypeList = App.EffectiveTypes.Where(u => u.IsEnum && _enumOptions.EntityAssemblyNames.Contains(u.Assembly.GetName().Name)).OrderBy(u => u.Name).OrderBy(u => u.FullName).ToList();
  27. var result = new List<EnumTypeOutput>();
  28. foreach (var item in enumTypeList)
  29. {
  30. result.Add(GetEnumDescription(item));
  31. }
  32. return result;
  33. }
  34. /// <summary>
  35. /// 获取字典描述
  36. /// </summary>
  37. /// <param name="type"></param>
  38. /// <returns></returns>
  39. private static EnumTypeOutput GetEnumDescription(Type type)
  40. {
  41. string description = type.Name;
  42. var attrs = type.GetCustomAttributes(typeof(DescriptionAttribute), false);
  43. if (attrs.Any())
  44. {
  45. var att = ((DescriptionAttribute[])attrs)[0];
  46. description = att.Description;
  47. }
  48. var enumType = App.EffectiveTypes.FirstOrDefault(t => t.IsEnum && t.Name == type.Name);
  49. return new EnumTypeOutput
  50. {
  51. TypeDescribe = description,
  52. TypeName = type.Name,
  53. TypeRemark = description,
  54. EnumEntities = enumType.EnumToList()
  55. };
  56. }
  57. /// <summary>
  58. /// 通过枚举类型获取枚举值集合 🔖
  59. /// </summary>
  60. /// <param name="input"></param>
  61. /// <returns></returns>
  62. [DisplayName("通过枚举类型获取枚举值集合")]
  63. public List<EnumEntity> GetEnumDataList([FromQuery] EnumInput input)
  64. {
  65. var enumType = App.EffectiveTypes.FirstOrDefault(u => u.IsEnum && u.Name == input.EnumName);
  66. if (enumType is not { IsEnum: true })
  67. throw Oops.Oh(ErrorCodeEnum.D1503);
  68. return enumType.EnumToList();
  69. }
  70. /// <summary>
  71. /// 通过实体的字段名获取相关枚举值集合(目前仅支持枚举类型) 🔖
  72. /// </summary>
  73. /// <param name="input"></param>
  74. /// <returns></returns>
  75. [DisplayName("通过实体的字段名获取相关枚举值集合")]
  76. public static List<EnumEntity> GetEnumDataListByField([FromQuery] QueryEnumDataInput input)
  77. {
  78. // 获取实体类型属性
  79. Type entityType = App.EffectiveTypes.FirstOrDefault(u => u.Name == input.EntityName) ?? throw Oops.Oh(ErrorCodeEnum.D1504);
  80. // 获取字段类型
  81. var fieldType = entityType.GetProperties().FirstOrDefault(u => u.Name == input.FieldName)?.PropertyType;
  82. if (fieldType is not { IsEnum: true })
  83. throw Oops.Oh(ErrorCodeEnum.D1503);
  84. return fieldType.EnumToList();
  85. }
  86. }