You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

rm_handler_facade.go 2.4 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. package handler
  18. import (
  19. "context"
  20. "sync"
  21. "github.com/seata/seata-go/pkg/protocol/branch"
  22. "github.com/seata/seata-go/pkg/protocol/message"
  23. )
  24. var (
  25. onceRMHandlerFacade = &sync.Once{}
  26. rmHandler *RMHandlerFacade
  27. )
  28. type RMHandlerFacade struct {
  29. rmHandlerMap sync.Map
  30. }
  31. func GetRMHandlerFacadeInstance() *RMHandlerFacade {
  32. if rmHandler == nil {
  33. onceRMHandlerFacade.Do(func() {
  34. rmHandler = &RMHandlerFacade{}
  35. })
  36. }
  37. return rmHandler
  38. }
  39. // Handle branch commit response.
  40. func (h *RMHandlerFacade) HandleBranchCommitRequest(ctx context.Context, request message.BranchCommitRequest) (*message.BranchCommitResponse, error) {
  41. return h.getRMHandler(request.BranchType).HandleBranchCommitRequest(ctx, request)
  42. }
  43. // Handle branch rollback response.
  44. // TODO
  45. func (h *RMHandlerFacade) HandleBranchRollbackRequest(ctx context.Context, request message.BranchRollbackRequest) (*message.BranchRollbackResponse, error) {
  46. return h.getRMHandler(request.BranchType).HandleBranchRollbackRequest(ctx, request)
  47. }
  48. // Handle delete undo log .
  49. // TODO
  50. func (h *RMHandlerFacade) HandleUndoLogDeleteRequest(ctx context.Context, request message.UndoLogDeleteRequest) error {
  51. return h.getRMHandler(request.BranchType).HandleUndoLogDeleteRequest(ctx, request)
  52. }
  53. func (h *RMHandlerFacade) RegisteRMHandler(handler *CommonRMHandler) {
  54. if handler == nil {
  55. return
  56. }
  57. h.rmHandlerMap.Store(handler.GetBranchType(), handler)
  58. }
  59. func (h *RMHandlerFacade) getRMHandler(branchType branch.BranchType) *CommonRMHandler {
  60. if handler, ok := h.rmHandlerMap.Load(branchType); ok {
  61. return handler.(*CommonRMHandler)
  62. }
  63. return nil
  64. }