mirror of
https://github.com/injoyai/tdx.git
synced 2025-11-26 21:25:35 +08:00
Merge remote-tracking branch 'origin/master'
This commit is contained in:
31
client.go
31
client.go
@@ -8,6 +8,7 @@ import (
|
|||||||
"github.com/injoyai/conv"
|
"github.com/injoyai/conv"
|
||||||
"github.com/injoyai/ios"
|
"github.com/injoyai/ios"
|
||||||
"github.com/injoyai/ios/client"
|
"github.com/injoyai/ios/client"
|
||||||
|
"github.com/injoyai/ios/module/common"
|
||||||
"github.com/injoyai/logs"
|
"github.com/injoyai/logs"
|
||||||
"github.com/injoyai/tdx/protocol"
|
"github.com/injoyai/tdx/protocol"
|
||||||
"runtime/debug"
|
"runtime/debug"
|
||||||
@@ -15,6 +16,16 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
LevelNone = common.LevelNone
|
||||||
|
LevelDebug = common.LevelDebug
|
||||||
|
LevelWrite = common.LevelWrite
|
||||||
|
LevelRead = common.LevelRead
|
||||||
|
LevelInfo = common.LevelInfo
|
||||||
|
LevelError = common.LevelError
|
||||||
|
LevelAll = common.LevelAll
|
||||||
|
)
|
||||||
|
|
||||||
// WithDebug 是否打印通讯数据
|
// WithDebug 是否打印通讯数据
|
||||||
func WithDebug(b ...bool) client.Option {
|
func WithDebug(b ...bool) client.Option {
|
||||||
return func(c *client.Client) {
|
return func(c *client.Client) {
|
||||||
@@ -22,6 +33,12 @@ func WithDebug(b ...bool) client.Option {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WithLevel(level int) client.Option {
|
||||||
|
return func(c *client.Client) {
|
||||||
|
c.Logger.SetLevel(level)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// WithRedial 断线重连
|
// WithRedial 断线重连
|
||||||
func WithRedial(b ...bool) client.Option {
|
func WithRedial(b ...bool) client.Option {
|
||||||
return func(c *client.Client) {
|
return func(c *client.Client) {
|
||||||
@@ -31,6 +48,7 @@ func WithRedial(b ...bool) client.Option {
|
|||||||
|
|
||||||
// DialDefault 默认连接方式
|
// DialDefault 默认连接方式
|
||||||
func DialDefault(op ...client.Option) (cli *Client, err error) {
|
func DialDefault(op ...client.Option) (cli *Client, err error) {
|
||||||
|
op = append([]client.Option{WithRedial()}, op...)
|
||||||
return DialHostsRange(Hosts, op...)
|
return DialHostsRange(Hosts, op...)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -63,7 +81,8 @@ func DialWith(dial ios.DialFunc, op ...client.Option) (cli *Client, err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
cli.Client, err = client.Dial(dial, func(c *client.Client) {
|
cli.Client, err = client.Dial(dial, func(c *client.Client) {
|
||||||
c.Logger.Debug(false) //关闭日志打印
|
c.Logger.Debug(true) //关闭日志打印
|
||||||
|
c.Logger.SetLevel(LevelInfo) //设置日志级别
|
||||||
c.Logger.WithHEX() //以HEX显示
|
c.Logger.WithHEX() //以HEX显示
|
||||||
c.SetOption(op...) //自定义选项
|
c.SetOption(op...) //自定义选项
|
||||||
c.Event.OnReadFrom = protocol.ReadFrom //分包
|
c.Event.OnReadFrom = protocol.ReadFrom //分包
|
||||||
@@ -86,16 +105,6 @@ func DialWith(dial ios.DialFunc, op ...client.Option) (cli *Client, err error) {
|
|||||||
|
|
||||||
go cli.Client.Run()
|
go cli.Client.Run()
|
||||||
|
|
||||||
/*
|
|
||||||
部分接口需要通过代码信息计算得出
|
|
||||||
*/
|
|
||||||
codesOnce.Do(func() {
|
|
||||||
//初始化代码管理
|
|
||||||
if DefaultCodes == nil {
|
|
||||||
DefaultCodes, err = NewCodes(cli, "./codes.db")
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
return cli, err
|
return cli, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
8
codes.go
8
codes.go
@@ -8,17 +8,13 @@ import (
|
|||||||
"math"
|
"math"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sync"
|
|
||||||
"time"
|
"time"
|
||||||
"xorm.io/core"
|
"xorm.io/core"
|
||||||
"xorm.io/xorm"
|
"xorm.io/xorm"
|
||||||
)
|
)
|
||||||
|
|
||||||
// 增加单例,部分数据需要通过Codes里面的信息计算
|
// DefaultCodes 增加单例,部分数据需要通过Codes里面的信息计算
|
||||||
var (
|
var DefaultCodes *Codes
|
||||||
DefaultCodes *Codes
|
|
||||||
codesOnce sync.Once
|
|
||||||
)
|
|
||||||
|
|
||||||
func NewCodes(c *Client, filename string) (*Codes, error) {
|
func NewCodes(c *Client, filename string) (*Codes, error) {
|
||||||
|
|
||||||
|
|||||||
3
dial.go
3
dial.go
@@ -73,7 +73,8 @@ func NewRangeDial(hosts []string) ios.DialFunc {
|
|||||||
}
|
}
|
||||||
if i < len(hosts)-1 {
|
if i < len(hosts)-1 {
|
||||||
//最后一个错误返回出去
|
//最后一个错误返回出去
|
||||||
logs.Err(err)
|
logs.Err(err, "等待2秒后尝试下一个服务地址...")
|
||||||
|
<-time.After(time.Second * 2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
|
|||||||
16
manage.go
16
manage.go
@@ -16,19 +16,18 @@ func NewManage(cfg *ManageConfig, op ...client.Option) (*Manage, error) {
|
|||||||
if cfg == nil {
|
if cfg == nil {
|
||||||
cfg = &ManageConfig{}
|
cfg = &ManageConfig{}
|
||||||
}
|
}
|
||||||
if len(cfg.Hosts) == 0 {
|
|
||||||
cfg.Hosts = Hosts
|
|
||||||
}
|
|
||||||
if cfg.CodesDir == "" {
|
if cfg.CodesDir == "" {
|
||||||
cfg.CodesDir = DefaultDatabaseDir
|
cfg.CodesDir = DefaultDatabaseDir
|
||||||
}
|
}
|
||||||
if cfg.WorkdayDir == "" {
|
if cfg.WorkdayDir == "" {
|
||||||
cfg.WorkdayDir = DefaultDatabaseDir
|
cfg.WorkdayDir = DefaultDatabaseDir
|
||||||
}
|
}
|
||||||
|
if cfg.Dial == nil {
|
||||||
|
cfg.Dial = DialDefault
|
||||||
|
}
|
||||||
|
|
||||||
//代码
|
//代码
|
||||||
DefaultCodes = &Codes{}
|
codesClient, err := cfg.Dial(op...)
|
||||||
codesClient, err := DialHostsRange(cfg.Hosts, op...)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -37,18 +36,17 @@ func NewManage(cfg *ManageConfig, op ...client.Option) (*Manage, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
DefaultCodes = codes
|
|
||||||
|
|
||||||
//连接池
|
//连接池
|
||||||
p, err := NewPool(func() (*Client, error) {
|
p, err := NewPool(func() (*Client, error) {
|
||||||
return DialHostsRange(cfg.Hosts, op...)
|
return cfg.Dial(op...)
|
||||||
}, cfg.Number)
|
}, cfg.Number)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
//工作日
|
//工作日
|
||||||
workdayClient, err := DialHostsRange(cfg.Hosts, op...)
|
workdayClient, err := cfg.Dial(op...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -85,8 +83,8 @@ func (this *Manage) AddWorkdayTask(spec string, f func(m *Manage)) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type ManageConfig struct {
|
type ManageConfig struct {
|
||||||
Hosts []string //服务端IP
|
|
||||||
Number int //客户端数量
|
Number int //客户端数量
|
||||||
CodesDir string //代码数据库位置
|
CodesDir string //代码数据库位置
|
||||||
WorkdayDir string //工作日数据库位置
|
WorkdayDir string //工作日数据库位置
|
||||||
|
Dial func(op ...client.Option) (cli *Client, err error) //默认连接方式
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -77,7 +77,10 @@ func (this *Kline) RisePrice() Price {
|
|||||||
|
|
||||||
// RiseRate 涨跌比例/涨跌幅,第一个数据不准,仅做参考
|
// RiseRate 涨跌比例/涨跌幅,第一个数据不准,仅做参考
|
||||||
func (this *Kline) RiseRate() float64 {
|
func (this *Kline) RiseRate() float64 {
|
||||||
return float64(this.RisePrice()) / float64(this.Open) * 100
|
if this.Last == 0 {
|
||||||
|
return float64(this.Close-this.Open) / float64(this.Open) * 100
|
||||||
|
}
|
||||||
|
return float64(this.Close-this.Last) / float64(this.Last) * 100
|
||||||
}
|
}
|
||||||
|
|
||||||
type kline struct{}
|
type kline struct{}
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ func (this *Workday) Update() error {
|
|||||||
|
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
if lastWorkday == nil || lastWorkday.Unix < IntegerDay(now).Unix() {
|
if lastWorkday == nil || lastWorkday.Unix < IntegerDay(now).Unix() {
|
||||||
resp, err := this.Client.GetKlineDayAll("sh000001")
|
resp, err := this.Client.GetIndexDayAll("sh000001")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logs.Err(err)
|
logs.Err(err)
|
||||||
return err
|
return err
|
||||||
|
|||||||
Reference in New Issue
Block a user