pkg/rm/tcc/fence/fence.go (31 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 fence
import (
"flag"
"seata.apache.org/seata-go/pkg/rm/tcc/fence/config"
"seata.apache.org/seata-go/pkg/rm/tcc/fence/handler"
"seata.apache.org/seata-go/pkg/rm/tcc/fence/store/db/dao"
"time"
)
var (
FenceConfig Config
)
func InitFenceConfig(cfg Config) {
FenceConfig = cfg
if FenceConfig.Enable {
dao.GetTccFenceStoreDatabaseMapper().InitLogTableName(FenceConfig.LogTableName)
handler.GetFenceHandler().InitCleanPeriod(FenceConfig.CleanPeriod)
config.InitCleanTask(FenceConfig.Url)
}
}
type Config struct {
Enable bool `yaml:"enable" json:"enable" koanf:"enable"`
Url string `yaml:"url" json:"url" koanf:"url"`
LogTableName string `yaml:"log-table-name" json:"log-table-name" koanf:"log-table-name"`
CleanPeriod time.Duration `yaml:"clean-period" json:"clean-period" koanf:"clean-period"`
}
// RegisterFlagsWithPrefix for Config.
func (cfg *Config) RegisterFlagsWithPrefix(prefix string, f *flag.FlagSet) {
f.BoolVar(&cfg.Enable, prefix+".enable", false, "Whether the fence is initialized.")
f.StringVar(&cfg.Url, prefix+".url", "", "Data source name.")
f.StringVar(&cfg.LogTableName, prefix+".log-table-name", "tcc_fence_log", "Undo log table name.")
f.DurationVar(&cfg.CleanPeriod, prefix+".clean-period", 5*time.Minute, "Undo log retention time.")
}