forked from ethpoolproxy/stratumproxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.go
102 lines (88 loc) · 2.79 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
package main
import (
"errors"
"flag"
log "github.com/sirupsen/logrus"
"io/ioutil"
"os"
"os/signal"
"stratumproxy/config"
"stratumproxy/connection"
"stratumproxy/injector/eth"
"stratumproxy/injector/eth-stratum"
"stratumproxy/util"
"stratumproxy/webui"
"syscall"
"time"
)
var profileType string
func main() {
log.SetFormatter(&log.TextFormatter{
ForceColors: true,
FullTimestamp: true,
})
flag.StringVar(&config.ConfigFile, "config", "config.yml", "配置文件路径")
flag.StringVar(&profileType, "profile", "", "性能监控")
flag.Parse()
// 初始化
InitMain()
defer DeferMain()
log.Infof("加载配置文件 [%s]", config.ConfigFile)
_, err := os.Stat(config.ConfigFile)
if err != nil && errors.Is(err, os.ErrNotExist) {
example, _ := config.ExampleConfigFile.ReadFile("config.example.yml")
err = ioutil.WriteFile(config.ConfigFile, example, 0755)
if err != nil {
log.Fatalf("无法写入配置文件 [%s]: %s", config.ConfigFile, err.Error())
return
}
}
err = config.LoadConfig(config.ConfigFile)
if err != nil {
log.Fatalf("无法加载配置文件 [%s]: %s", config.ConfigFile, err.Error())
return
}
go func() {
time.Sleep(1 * time.Minute)
err = config.SaveConfig(config.ConfigFile)
if err != nil {
log.Errorf("无法保存配置文件 [%s]!请及时记录当前配置并关闭软件,否则可能造成当前配置丢失! [%s]", config.ConfigFile, err.Error())
return
}
}()
go func() {
log.Infof("在 [%s] 上启动在线面板", config.GlobalConfig.WebUI.Bind)
err = webui.StartWebServer()
if err != nil {
log.Fatalf("无法启动在线面板 [%s]", err.Error())
}
}()
// 加载协议
eth.RegisterProtocol()
eth_stratum.RegisterProtocol()
// 启动矿池
for _, pool := range config.GlobalConfig.Pools {
server, err := connection.NewPoolServer(pool)
if err != nil {
log.Errorf("无法启动矿池 [%s]: %s", pool.Name, err)
continue
}
go func() { _ = server.Start() }()
}
// 生成密码
if config.GlobalConfig.WebUI.Auth.Username == "" || config.GlobalConfig.WebUI.Auth.Passwd == "" {
config.GlobalConfig.WebUI.Auth.Username = util.GetRandomString2(6)
config.GlobalConfig.WebUI.Auth.Passwd = util.GetRandomString2(12)
log.Infof("初始管理员凭据已生成!登陆后台后请及时更改!用户名 [%s] 密码 [%s]", config.GlobalConfig.WebUI.Auth.Username, config.GlobalConfig.WebUI.Auth.Passwd)
_ = config.SaveConfig(config.ConfigFile)
}
chSig := make(chan os.Signal)
signal.Notify(chSig, syscall.SIGINT, syscall.SIGTERM)
log.Errorf("接收到 [%s] 信号,程序退出! ", <-chSig)
log.Infof("保存配置文件 [%s]", config.ConfigFile)
err = config.SaveConfig(config.ConfigFile)
if err != nil {
log.Errorf("无法保存配置文件 [%s]: %s", config.ConfigFile, err.Error())
return
}
}