-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.go
129 lines (113 loc) · 2.76 KB
/
app.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
package main
import (
"context"
"encoding/json"
"fmt"
"github.com/shirou/gopsutil/cpu"
"github.com/wailsapp/wails/v2/pkg/logger"
"github.com/wailsapp/wails/v2/pkg/runtime"
"math"
"time"
"wails_demo/pkg/sys"
)
// App struct
type App struct {
log logger.Logger
ctx context.Context
}
type CPUUsage struct {
Average int `json:"avg"`
}
// NewApp creates a new App application struct
func NewApp() *App {
return &App{}
}
// startup is called at application startup
func (a *App) startup(ctx context.Context) {
// Perform your setup here
a.ctx = ctx
// 监控 CPU
go func() {
for {
runtime.EventsEmit(a.ctx, "cpu_usage", a.GetCPUUsage())
time.Sleep(1 * time.Second)
}
}()
// 监控 内存
go func() {
for {
runtime.EventsEmit(a.ctx, "mem_usage", a.GetMemUsage())
time.Sleep(1 * time.Second)
}
}()
}
// domReady is called after front-end resources have been loaded
func (a App) domReady(ctx context.Context) {
// Add your action here
}
// beforeClose is called when the application is about to quit,
// either by clicking the window close button or calling runtime.Quit.
// Returning true will cause the application to continue, false will continue shutdown as normal.
func (a *App) beforeClose(ctx context.Context) (prevent bool) {
return false
}
// shutdown is called at application termination
func (a *App) shutdown(ctx context.Context) {
// Perform your teardown here
}
// Greet returns a greeting for the given name
func (a *App) Greet(name string) string {
return fmt.Sprintf("Hello %s, It's show time!", name)
}
// GetCPUUsage cpu 使用结果
func (a *App) GetCPUUsage() *CPUUsage {
percent, err := cpu.Percent(1*time.Second, false)
if err != nil {
a.log.Error("unable to get cpu stats: " + err.Error())
return nil
}
return &CPUUsage{
Average: int(math.Round(percent[0])),
}
}
func (a *App) GetMemUsage() *sys.MemoryInfo {
mem := sys.NewMemory()
return mem.MemInfo()
}
func (a *App) CpuInfo() string {
cpuSelf := sys.NewCpu()
cpuInfo := cpuSelf.CPUInfo()
cpuInfoStr, err := json.Marshal(cpuInfo)
if err != nil {
a.log.Error(err.Error())
}
return string(cpuInfoStr)
}
func (a *App) MemInfo() string {
memSelf := sys.NewMemory()
memInfo := memSelf.MemInfo()
memInfoStr, err := json.Marshal(memInfo)
if err != nil {
a.log.Error(err.Error())
}
return string(memInfoStr)
}
func (a *App) HostInfo() string {
hostSelf := sys.NewHost()
hostInfo := hostSelf.HostInfo()
hostInfoStr, err := json.Marshal(hostInfo)
if err != nil {
a.log.Error(err.Error())
}
return string(hostInfoStr)
}
func (a *App) DiskInfo() string {
diskSelf := sys.NewDisk()
diskInfo := diskSelf.DiskInfo()
diskInfoStr, err := json.Marshal(diskInfo)
if err != nil {
a.log.Error(err.Error())
}
fmt.Println(string(diskInfoStr))
return string(diskInfoStr)
}