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.

sub_state_machine_parser.go 3.6 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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 parser
  18. import (
  19. "fmt"
  20. "github.com/pkg/errors"
  21. "github.com/seata/seata-go/pkg/saga/statemachine/constant"
  22. "github.com/seata/seata-go/pkg/saga/statemachine/statelang"
  23. "github.com/seata/seata-go/pkg/saga/statemachine/statelang/state"
  24. )
  25. type SubStateMachineParser struct {
  26. *AbstractTaskStateParser
  27. }
  28. func NewSubStateMachineParser() *SubStateMachineParser {
  29. return &SubStateMachineParser{
  30. NewAbstractTaskStateParser(),
  31. }
  32. }
  33. func (s SubStateMachineParser) StateType() string {
  34. return constant.StateTypeSubStateMachine
  35. }
  36. func (s SubStateMachineParser) Parse(stateName string, stateMap map[string]interface{}) (statelang.State, error) {
  37. subStateMachineImpl := state.NewSubStateMachineImpl()
  38. err := s.ParseTaskAttributes(stateName, subStateMachineImpl.AbstractTaskState, stateMap)
  39. if err != nil {
  40. return nil, err
  41. }
  42. stateMachineName, err := s.BaseStateParser.GetString(stateName, stateMap, "StateMachineName")
  43. if err != nil {
  44. return nil, err
  45. }
  46. subStateMachineImpl.SetName(stateMachineName)
  47. if subStateMachineImpl.CompensateState() == "" {
  48. // build default SubStateMachine compensate state
  49. compensateSubStateMachineStateParser := NewCompensateSubStateMachineStateParser()
  50. compensateState, err := compensateSubStateMachineStateParser.Parse(stateName, nil)
  51. if err != nil {
  52. return nil, err
  53. }
  54. compensateStateImpl, ok := compensateState.(state.TaskState)
  55. if !ok {
  56. return nil, errors.New(fmt.Sprintf("State [name:%s] has wrong compensateState type", stateName))
  57. }
  58. subStateMachineImpl.SetCompensateStateImpl(compensateStateImpl)
  59. subStateMachineImpl.SetCompensateState(compensateStateImpl.Name())
  60. }
  61. return subStateMachineImpl, nil
  62. }
  63. type CompensateSubStateMachineStateParser struct {
  64. *AbstractTaskStateParser
  65. }
  66. func NewCompensateSubStateMachineStateParser() *CompensateSubStateMachineStateParser {
  67. return &CompensateSubStateMachineStateParser{
  68. NewAbstractTaskStateParser(),
  69. }
  70. }
  71. func (c CompensateSubStateMachineStateParser) StateType() string {
  72. return constant.StateTypeCompensateSubMachine
  73. }
  74. func (c CompensateSubStateMachineStateParser) Parse(stateName string, stateMap map[string]interface{}) (statelang.State, error) {
  75. compensateSubStateMachineStateImpl := state.NewCompensateSubStateMachineStateImpl()
  76. compensateSubStateMachineStateImpl.SetForCompensation(true)
  77. if stateMap != nil {
  78. err := c.ParseTaskAttributes(stateName, compensateSubStateMachineStateImpl.ServiceTaskStateImpl.AbstractTaskState, stateMap)
  79. if err != nil {
  80. return nil, err
  81. }
  82. }
  83. if compensateSubStateMachineStateImpl.Name() == "" {
  84. compensateSubStateMachineStateImpl.SetName(constant.CompensateSubMachineStateNamePrefix + compensateSubStateMachineStateImpl.Hashcode())
  85. }
  86. return compensateSubStateMachineStateImpl, nil
  87. }