tcc/propagation/first/main.go (63 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package main import ( "context" "fmt" "sync" "seata.apache.org/seata-go-samples/tcc/propagation/second" "seata.apache.org/seata-go/pkg/client" "seata.apache.org/seata-go/pkg/rm/tcc" "seata.apache.org/seata-go/pkg/tm" "seata.apache.org/seata-go/pkg/util/log" ) func main() { client.InitPath("../../../conf/seatago.yml") log.Info(tm.WithGlobalTx(context.Background(), &tm.GtxConfig{ Name: "TccSampleLocalGlobalTxFirst", }, business)) <-make(chan struct{}) } func business(ctx context.Context) (re error) { log.Infof("FirstBusiness: propagation tx xid %v", tm.GetXID(ctx)) if _, re = New().Prepare(ctx, 1); re != nil { log.Errorf("FirstBusiness prepare error, %v", re) return } return } var ( tccService *tcc.TCCServiceProxy tccServiceOnce sync.Once ) type TestTCCServiceBusiness struct{} func New() *tcc.TCCServiceProxy { if tccService != nil { return tccService } tccServiceOnce.Do(func() { var err error tccService, err = tcc.NewTCCServiceProxy(&TestTCCServiceBusiness{}) if err != nil { panic(fmt.Errorf("get TestTccServiceBusiness tcc service proxy error, %v", err.Error())) } }) return tccService } func (T TestTCCServiceBusiness) Prepare(ctx context.Context, params interface{}) (bool, error) { log.Infof("FirstPrepare: propagation tx xid %v", tm.GetXID(ctx)) err := tm.WithGlobalTx(ctx, &tm.GtxConfig{ Name: "TccSampleLocalGlobalTxSecond", Propagation: tm.Mandatory, }, second.Business) return err == nil, err } func (T TestTCCServiceBusiness) Commit(ctx context.Context, businessActionContext *tm.BusinessActionContext) (bool, error) { log.Infof("FirstCommit: propagation tx xid %v", tm.GetXID(ctx)) return true, nil } func (T TestTCCServiceBusiness) Rollback(ctx context.Context, businessActionContext *tm.BusinessActionContext) (bool, error) { log.Infof("FirstRollback: propagation tx xid %v", tm.GetXID(ctx)) return true, nil } func (T TestTCCServiceBusiness) GetActionName() string { return "TestTCCServiceBusinessFirst" }