SysEnumService.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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. public class SysEnumService : IDynamicApiController, ITransient
  12. {
  13. private readonly EnumOptions _enumOptions;
  14. public SysEnumService(IOptions<EnumOptions> enumOptions)
  15. {
  16. _enumOptions = enumOptions.Value;
  17. }
  18. /// <summary>
  19. /// 获取所有枚举类型 🔖
  20. /// </summary>
  21. /// <returns></returns>
  22. [DisplayName("获取所有枚举类型")]
  23. public List<EnumTypeOutput> GetEnumTypeList()
  24. {
  25. var enumTypeList = App.EffectiveTypes.Where(t => t.IsEnum)
  26. .Where(t => _enumOptions.EntityAssemblyNames.Contains(t.Assembly.GetName().Name) || _enumOptions.EntityAssemblyNames.Any(name => t.Assembly.GetName().Name!.Contains(name)))
  27. .Where(t => t.GetCustomAttributes(typeof(ErrorCodeTypeAttribute), false).Length == 0) // 排除错误代码类型
  28. .OrderBy(u => u.Name).ThenBy(u => u.FullName)
  29. .ToList();
  30. // 如果存在同名枚举类,则依次增加 "_序号" 前缀
  31. var list = enumTypeList.Select(GetEnumDescription).ToList();
  32. var appEnumList = list.Where(u => !u.TypeFullName.StartsWith(typeof(AccountTypeEnum).Namespace!));
  33. foreach (var enumType in list.GroupBy(u => u.TypeName).Where(g => g.Count() > 1))
  34. {
  35. int i = 1;
  36. // 过滤框架中的枚举
  37. foreach (var item in appEnumList.Where(u => u.TypeName == enumType.Key)) item.TypeName = $"{i++}_{item.TypeName}";
  38. }
  39. return list;
  40. }
  41. /// <summary>
  42. /// 获取字典描述
  43. /// </summary>
  44. /// <param name="type"></param>
  45. /// <returns></returns>
  46. private static EnumTypeOutput GetEnumDescription(Type type)
  47. {
  48. string description = type.Name;
  49. var attrs = type.GetCustomAttributes(typeof(DescriptionAttribute), false);
  50. if (attrs.Length != 0)
  51. {
  52. var att = ((DescriptionAttribute[])attrs)[0];
  53. description = att.Description;
  54. }
  55. var enumType = App.EffectiveTypes.FirstOrDefault(t => t.IsEnum && t.Name == type.Name);
  56. return new EnumTypeOutput
  57. {
  58. TypeDescribe = description,
  59. TypeName = type.Name,
  60. TypeRemark = description,
  61. TypeFullName = type.FullName,
  62. EnumEntities = (enumType ?? type).EnumToList()
  63. };
  64. }
  65. /// <summary>
  66. /// 通过枚举类型获取枚举值集合 🔖
  67. /// </summary>
  68. /// <param name="input"></param>
  69. /// <returns></returns>
  70. [DisplayName("通过枚举类型获取枚举值集合")]
  71. public List<EnumEntity> GetEnumDataList([FromQuery] EnumInput input)
  72. {
  73. var enumType = App.EffectiveTypes.FirstOrDefault(u => u.IsEnum && u.Name == input.EnumName);
  74. if (enumType is not { IsEnum: true }) throw Oops.Oh(ErrorCodeEnum.D1503);
  75. return enumType.EnumToList();
  76. }
  77. /// <summary>
  78. /// 通过实体的字段名获取相关枚举值集合(目前仅支持枚举类型) 🔖
  79. /// </summary>
  80. /// <param name="input"></param>
  81. /// <returns></returns>
  82. [DisplayName("通过实体的字段名获取相关枚举值集合")]
  83. public static List<EnumEntity> GetEnumDataListByField([FromQuery] QueryEnumDataInput input)
  84. {
  85. // 获取实体类型属性
  86. Type entityType = App.EffectiveTypes.FirstOrDefault(u => u.Name == input.EntityName) ?? throw Oops.Oh(ErrorCodeEnum.D1504);
  87. // 获取字段类型
  88. var fieldType = entityType.GetProperties().FirstOrDefault(u => u.Name == input.FieldName)?.PropertyType;
  89. if (fieldType is not { IsEnum: true }) throw Oops.Oh(ErrorCodeEnum.D1503);
  90. return fieldType.EnumToList();
  91. }
  92. }