首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >聊聊dubbo-go的ProviderAuthFilter

聊聊dubbo-go的ProviderAuthFilter

作者头像
code4it
发布2020-07-29 10:58:35
3220
发布2020-07-29 10:58:35
举报
文章被收录于专栏:码匠的流水账码匠的流水账

本文主要研究一下dubbo-go的ProviderAuthFilter

ProviderAuthFilter

dubbo-go-v1.4.2/filter/filter_impl/auth/provider_auth.go

type ProviderAuthFilter struct {
}

func init() {
    extension.SetFilter(constant.PROVIDER_AUTH_FILTER, getProviderAuthFilter)
}
  • ProviderAuthFilter的init方法设置了getProviderAuthFilter

getProviderAuthFilter

dubbo-go-v1.4.2/filter/filter_impl/auth/provider_auth.go

func getProviderAuthFilter() filter.Filter {
    return &ProviderAuthFilter{}
}
  • getProviderAuthFilter实例化了ProviderAuthFilter

Invoke

dubbo-go-v1.4.2/filter/filter_impl/auth/provider_auth.go

func (paf *ProviderAuthFilter) Invoke(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
    logger.Infof("invoking providerAuth filter.")
    url := invoker.GetUrl()

    err := doAuthWork(&url, func(authenticator filter.Authenticator) error {
        return authenticator.Authenticate(invocation, &url)
    })
    if err != nil {
        logger.Infof("auth the request: %v occur exception, cause: %s", invocation, err.Error())
        return &protocol.RPCResult{
            Err: err,
        }
    }

    return invoker.Invoke(ctx, invocation)
}
  • Invoke方法通过doAuthWork来进行auth,其传递的func执行authenticator.Authenticate(invocation, &url)

OnResponse

dubbo-go-v1.4.2/filter/filter_impl/auth/default_authenticator.go

func (paf *ProviderAuthFilter) OnResponse(ctx context.Context, result protocol.Result, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
    return result
}
  • OnResponse方法直接返回result

doAuthWork

dubbo-go-v1.4.2/filter/filter_impl/auth/default_authenticator.go

func doAuthWork(url *common.URL, do func(filter.Authenticator) error) error {

    shouldAuth := url.GetParamBool(constant.SERVICE_AUTH_KEY, false)
    if shouldAuth {
        authenticator := extension.GetAuthenticator(url.GetParam(constant.AUTHENTICATOR_KEY, constant.DEFAULT_AUTHENTICATOR))
        return do(authenticator)
    }
    return nil
}
  • doAuthWork方法先从url读取constant.SERVICE_AUTH_KEY判断是否需要auth,需要的话,则获取authenticator,执行do(authenticator)

Authenticate

dubbo-go-v1.4.2/filter/filter_impl/auth/default_authenticator.go

func (authenticator *DefaultAuthenticator) Authenticate(invocation protocol.Invocation, url *common.URL) error {
    accessKeyId := invocation.AttachmentsByKey(constant.AK_KEY, "")

    requestTimestamp := invocation.AttachmentsByKey(constant.REQUEST_TIMESTAMP_KEY, "")
    originSignature := invocation.AttachmentsByKey(constant.REQUEST_SIGNATURE_KEY, "")
    consumer := invocation.AttachmentsByKey(constant.CONSUMER, "")
    if IsEmpty(accessKeyId, false) || IsEmpty(consumer, false) ||
        IsEmpty(requestTimestamp, false) || IsEmpty(originSignature, false) {
        return errors.New("failed to authenticate your ak/sk, maybe the consumer has not enabled the auth")
    }

    accessKeyPair, err := getAccessKeyPair(invocation, url)
    if err != nil {
        return errors.New("failed to authenticate , can't load the accessKeyPair")
    }

    computeSignature, err := getSignature(url, invocation, accessKeyPair.SecretKey, requestTimestamp)
    if err != nil {
        return err
    }
    if success := computeSignature == originSignature; !success {
        return errors.New("failed to authenticate, signature is not correct")
    }
    return nil
}
  • Authenticate方法从invocation的attachment获取requestTimestamp及originSignature,然后通过getAccessKeyPair从accesskeyStorage.GetAccessKeyPair获取accessKeyPair,之后通过getSignature计算signature,然后对比computeSignature与originSignature是否一样,不一样则返回error

小结

ProviderAuthFilter的Invoke方法通过doAuthWork来进行auth,其传递的func执行authenticator.Authenticate(invocation, &url)

doc

  • provider_auth
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码匠的流水账 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ProviderAuthFilter
  • getProviderAuthFilter
  • Invoke
  • OnResponse
  • doAuthWork
  • Authenticate
  • 小结
  • doc
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档