// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。 // // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。 // // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任! using Microsoft.AspNetCore.Mvc.ApiExplorer; using Org.BouncyCastle.Crypto.Parameters; using Org.BouncyCastle.Utilities.Encoders; using Swashbuckle.AspNetCore.SwaggerGen; namespace Admin.NET.Core.Service; /// /// 系统通用服务 🧩 /// [ApiDescriptionSettings(Order = 101)] [AllowAnonymous] public class SysCommonService : IDynamicApiController, ITransient { private readonly IApiDescriptionGroupCollectionProvider _apiProvider; public SysCommonService(IApiDescriptionGroupCollectionProvider apiProvider) { _apiProvider = apiProvider; } /// /// 获取国密公钥私钥对 🏆 /// /// [DisplayName("获取国密公钥私钥对")] public SmKeyPairOutput GetSmKeyPair() { var kp = GM.GenerateKeyPair(); var privateKey = Hex.ToHexString(((ECPrivateKeyParameters)kp.Private).D.ToByteArray()).ToUpper(); var publicKey = Hex.ToHexString(((ECPublicKeyParameters)kp.Public).Q.GetEncoded()).ToUpper(); return new SmKeyPairOutput { PrivateKey = privateKey, PublicKey = publicKey, }; } /// /// 获取所有接口/动态API 🔖 /// /// [DisplayName("获取所有接口/动态API")] public List GetApiList() { var apiList = new List(); foreach (var item in _apiProvider.ApiDescriptionGroups.Items) { foreach (var apiDescription in item.Items) { var displayName = apiDescription.TryGetMethodInfo(out MethodInfo apiMethodInfo) ? apiMethodInfo.GetCustomAttribute(true)?.DisplayName : ""; apiList.Add(new ApiOutput { GroupName = item.GroupName, DisplayName = displayName, RouteName = apiDescription.RelativePath }); } } return apiList; } /// /// 下载标记错误的临时Excel(全局) /// /// [DisplayName("下载标记错误的临时Excel(全局)")] public async Task DownloadErrorExcelTemp([FromQuery] string fileName = null) { var userId = App.User?.FindFirst(ClaimConst.UserId)?.Value; var resultStream = App.GetRequiredService().Get(CacheConst.KeyExcelTemp + userId); if (resultStream == null) throw Oops.Oh("错误标记文件已过期。"); return await Task.FromResult(new FileStreamResult(resultStream, "application/octet-stream") { FileDownloadName = $"{(string.IsNullOrEmpty(fileName) ? "错误标记_" + DateTime.Now.ToString("yyyyMMddhhmmss") : fileName)}.xlsx" }); } }