blog

dubbo-goのProviderAuthFilterについて語る。

この記事の一連の流れは、ダボゴーの -go- の研究に焦点を当てています。...

May 29, 2020 · 3 min. read
シェア

メソッドのシーケンス

この記事ではdubbo-goのProviderAuthFilterを取り上げます。

ProviderAuthFilter

type ProviderAuthFilter struct {
}
func init() {
	extension.SetFilter(constant.PROVIDER_AUTH_FILTER, getProviderAuthFilter)
}
  • ProviderAuthFiltergetProviderAuthFilter の init メソッドが設定されます。

getProviderAuthFilter

func getProviderAuthFilter() filter.Filter {
	return &ProviderAuthFilter{}
}
  • getProviderAuthFilterProviderAuthFilter がインスタンス化されます。

Invoke

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)
}

OnResponse

func (paf *ProviderAuthFilter) OnResponse(ctx context.Context, result protocol.Result, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
	return result
}
  • OnResponse メソッドは結果を直接返します。

doAuthWork

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
}

認証

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メソッドは、呼び出しの添付ファイルからrequestTimestampとoriginSignatureを取得し、accesskeyStorage.GetAccessKeyPairからgetAccessKeyPairを取得します。accesskeyStorage.GetAccessKeyPairからgetAccessKeyPairを取得し、getSignatureで署名を計算し、computeSignatureとoriginSignatureを比較して同じかどうかを確認し、同じでない場合はエラーを返します。

概要

ProviderAuthFilterのInvokeメソッドは、doAuthWorkを介して認証を実行し、それが渡すfuncは、authenticator.Authenticate(invocation, &url)を実行します。

Read next

ストアドファンクション - ストアドファンクションの作成

mysqlの数は、関数が付属していますが、時間のいくつかは、関数の需要を満たすために十分ではありませんが付属して、この時点で、ストアド関数をカスタマイズする必要があり、ストアド関数とストアドプロシージャは、多少似ている、簡単に言えば、SQLコードの一部をカプセル化することです特定の関数を完了し、に戻ります。

May 29, 2020 · 2 min read