// Admin.NET 项目的版æƒã€å•†æ ‡ã€ä¸“利和其他相关æƒåˆ©å‡å—ç›¸åº”æ³•å¾‹æ³•è§„çš„ä¿æŠ¤ã€‚ä½¿ç”¨æœ¬é¡¹ç›®åº”éµå®ˆç›¸å…³æ³•律法规和许å¯è¯çš„è¦æ±‚。 // // 本项目主è¦éµå¾ª MIT 许å¯è¯å’Œ Apache 许å¯è¯ï¼ˆç‰ˆæœ¬ 2.0)进行分å‘和使用。许å¯è¯ä½äºŽæºä»£ç æ ‘æ ¹ç›®å½•ä¸çš„ LICENSE-MIT å’Œ LICENSE-APACHE 文件。 // // ä¸å¾—利用本项目从事å±å®³å›½å®¶å®‰å…¨ã€æ‰°ä¹±ç¤¾ä¼šç§©åºã€ä¾µçŠ¯ä»–äººåˆæ³•æƒç›Šç‰æ³•å¾‹æ³•è§„ç¦æ¢çš„æ´»åЍï¼ä»»ä½•基于本项目二次开å‘è€Œäº§ç”Ÿçš„ä¸€åˆ‡æ³•å¾‹çº çº·å’Œè´£ä»»ï¼Œæˆ‘ä»¬ä¸æ‰¿æ‹…ä»»ä½•è´£ä»»ï¼ namespace Admin.NET.Core; /// <summary> /// Signature 身份验è¯äº‹ä»¶ /// </summary> public class SignatureAuthenticationEvent { public SignatureAuthenticationEvent() { } /// <summary> /// èŽ·å–æˆ–è®¾ç½®èŽ·å– AccessKey çš„ AccessSecret çš„é€»è¾‘å¤„ç† /// </summary> public Func<GetAccessSecretContext, Task<string>> OnGetAccessSecret { get; set; } /// <summary> /// èŽ·å–æˆ–è®¾ç½®è´¨è¯¢çš„é€»è¾‘å¤„ç† /// </summary> public Func<SignatureChallengeContext, Task> OnChallenge { get; set; } = _ => Task.CompletedTask; /// <summary> /// èŽ·å–æˆ–设置已验è¯çš„é€»è¾‘å¤„ç† /// </summary> public Func<SignatureValidatedContext, Task> OnValidated { get; set; } = _ => Task.CompletedTask; /// <summary> /// èŽ·å– AccessKey çš„ AccessSecret /// </summary> /// <param name="context"></param> /// <returns></returns> public virtual Task<string> GetAccessSecret(GetAccessSecretContext context) => OnGetAccessSecret?.Invoke(context) ?? throw new NotImplementedException($"éœ€è¦æä¾› {nameof(OnGetAccessSecret)} 实现"); /// <summary> /// 质询 /// </summary> /// <param name="context"></param> /// <returns></returns> public virtual Task Challenge(SignatureChallengeContext context) => OnChallenge?.Invoke(context) ?? Task.CompletedTask; /// <summary> /// å·²éªŒè¯æˆåŠŸ /// </summary> /// <param name="context"></param> /// <returns></returns> public virtual Task Validated(SignatureValidatedContext context) => OnValidated?.Invoke(context) ?? Task.CompletedTask; }