197 lines
4.5 KiB
Go
197 lines
4.5 KiB
Go
package conf
|
||
|
||
import (
|
||
"errors"
|
||
"flag"
|
||
|
||
"go-common/library/cache/redis"
|
||
"go-common/library/conf"
|
||
"go-common/library/database/sql"
|
||
"go-common/library/log"
|
||
"go-common/library/net/http/blademaster"
|
||
"go-common/library/net/http/blademaster/middleware/antispam"
|
||
"go-common/library/net/http/blademaster/middleware/auth"
|
||
"go-common/library/net/http/blademaster/middleware/verify"
|
||
"go-common/library/net/rpc"
|
||
"go-common/library/net/rpc/warden"
|
||
"go-common/library/net/trace"
|
||
"go-common/library/queue/databus"
|
||
xtime "go-common/library/time"
|
||
|
||
"go-common/library/database/hbase.v2"
|
||
|
||
"github.com/BurntSushi/toml"
|
||
)
|
||
|
||
// global var
|
||
var (
|
||
confPath string
|
||
client *conf.Client
|
||
// Conf config
|
||
Conf = &Config{}
|
||
)
|
||
|
||
// Config config set
|
||
type Config struct {
|
||
Log *log.Config
|
||
HTTPClient *blademaster.ClientConfig
|
||
Tracer *trace.Config
|
||
Auth *auth.Config
|
||
Verify *verify.Config
|
||
// Wechat wechat config
|
||
Wechat *wechat
|
||
// HBase for fans
|
||
HBase *hbaseConf
|
||
// FansHBase for attention groups + active time
|
||
FansHBase *hbaseConf
|
||
Redis *redis.Config
|
||
// MySQL
|
||
MySQL *sql.Config
|
||
AccountRPC *rpc.ClientConfig
|
||
// ArchiveSub archive_result databus consumer
|
||
ArchiveSub *databus.Config
|
||
// RelationSub relation_xxx databus consumer
|
||
RelationSub *databus.Config
|
||
Push *push
|
||
// ArcPush archive push settings
|
||
ArcPush *arcPush
|
||
PushRPC *warden.ClientConfig
|
||
// Anti antispam
|
||
Anti *antispam.Config
|
||
Bm *blademaster.ServerConfig
|
||
Abtest *abtest
|
||
}
|
||
|
||
type abtest struct {
|
||
HbaseBlacklistTable string
|
||
HbaseBlacklistFamily []string
|
||
HbaseeWhitelistTable string
|
||
HbaseWhitelistFamily []string
|
||
TestGroup []int
|
||
ComparisonGroup []int
|
||
TestMids []int64
|
||
}
|
||
|
||
type hbaseConf struct {
|
||
hbase.Config
|
||
ReadTimeout xtime.Duration
|
||
ReadsTimeout xtime.Duration
|
||
WriteTimeout xtime.Duration
|
||
WritesTimeout xtime.Duration
|
||
}
|
||
|
||
/**
|
||
* 配置规则:
|
||
PushStatisticsKeepDays 推送数据保留天数
|
||
PushStatisticsClearTim 每日推送数据删除的时间点
|
||
Order 分组优先级,元素=类型#组名,优先级只针对同一类型下有效,没配置优先级的分组不可用
|
||
ActiveTime 默认活跃时间(24小时制),过滤粉丝是否在活跃时间段内;未配置则不过滤;若希望过滤活跃时间但不提供默认活跃时间,配置成[0]
|
||
ForbidTimes 固定免推送时间段组
|
||
Proportions 灰度策略,粉丝尾号100内, 起始点+step
|
||
FanGroup 分组具体信息
|
||
*/
|
||
// arcPush 稿件更新的推送设置
|
||
type arcPush struct {
|
||
PushStatisticsKeepDays int
|
||
PushStatisticsClearTime string
|
||
Order []string
|
||
ActiveTime []int
|
||
ForbidTimes []ForbidTime
|
||
Proportions []Proportion
|
||
FanGroup []*fanGroup
|
||
UpperLimitExpire xtime.Duration
|
||
}
|
||
|
||
// ForbidTime 禁止时间范围
|
||
type ForbidTime struct {
|
||
PushForbidStartTime string
|
||
PushForbidEndTime string
|
||
}
|
||
|
||
// Proportion 灰度uid范围
|
||
type Proportion struct {
|
||
ProportionStartFrom string
|
||
Proportion string //必须是2位小数,比如:1.00, 0.05
|
||
}
|
||
|
||
// fanGroup 关注up主的粉丝分组
|
||
type fanGroup struct {
|
||
Name string
|
||
Desc string
|
||
RelationType int
|
||
Hitby string //命中分组规则,default=全部命中,hbase=hbase表过滤
|
||
Limit int
|
||
PerUpperLimit int
|
||
LimitExpire xtime.Duration
|
||
HBaseTable string
|
||
HBaseFamily []string
|
||
MsgTemplateDesc string
|
||
MsgTemplate string
|
||
}
|
||
|
||
type wechat struct {
|
||
UserName, Token, Secret string
|
||
}
|
||
|
||
type push struct {
|
||
ProdSwitch bool
|
||
AddAPI string
|
||
MultiAPI string
|
||
BusinessID int
|
||
BusinessToken string
|
||
BusinessSpecialID int
|
||
BusinessSpecialToken string
|
||
LoadSettingsInterval xtime.Duration
|
||
}
|
||
|
||
func init() {
|
||
flag.StringVar(&confPath, "conf", "", "default config path")
|
||
}
|
||
|
||
// Init init conf
|
||
func Init() error {
|
||
if confPath != "" {
|
||
return local()
|
||
}
|
||
return remote()
|
||
}
|
||
|
||
func local() (err error) {
|
||
_, err = toml.DecodeFile(confPath, &Conf)
|
||
return
|
||
}
|
||
|
||
func remote() (err error) {
|
||
if client, err = conf.New(); err != nil {
|
||
return
|
||
}
|
||
if err = load(); err != nil {
|
||
return
|
||
}
|
||
go func() {
|
||
for range client.Event() {
|
||
log.Info("config reload")
|
||
if load() != nil {
|
||
log.Error("config reload error (%v)", err)
|
||
}
|
||
}
|
||
}()
|
||
return
|
||
}
|
||
|
||
func load() (err error) {
|
||
var (
|
||
s string
|
||
ok bool
|
||
tmpConf *Config
|
||
)
|
||
if s, ok = client.Toml2(); !ok {
|
||
return errors.New("load config center error")
|
||
}
|
||
if _, err = toml.Decode(s, &tmpConf); err != nil {
|
||
return errors.New("could not decode config")
|
||
}
|
||
*Conf = *tmpConf
|
||
return
|
||
}
|