summaryrefslogtreecommitdiff
path: root/script/service/telemetry.lua
blob: 19fe86f13a430c109f6c38476600ec1bd7a0be2c (plain)
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
local net      = require 'service.net'
local timer    = require 'timer'
local config   = require 'config'
local client   = require 'provider.client'
local nonil    = require 'without-check-nil'
local util     = require 'utility'
local platform = require 'bee.platform'
local proto    = require 'proto.proto'
local lang     = require 'language'
local define   = require 'proto.define'
local await    = require 'await'

local tokenPath = (ROOT / 'log' / 'token'):string()
local token = util.loadFile(tokenPath)
if not token then
    token = ('%016X'):format(math.random(0, math.maxinteger))
    util.saveFile(tokenPath, token)
end

log.info('Telemetry Token:', token)

local function getClientName()
    nonil.enable()
    local clientName    = client.info.clientInfo.name
    local clientVersion = client.info.clientInfo.version
    nonil.disable()
    return table.concat({clientName, clientVersion}, ' ')
end

local function send(link, msg)
    link:write(('s4'):pack(msg))
end

local function pushClientInfo(link)
    send(link, string.pack('zzz'
        , 'pulse'
        , token
        , getClientName()
    ))
end

local function pushPlatformInfo(link)
    send(link, string.pack('zzzzz'
        , 'platform'
        , token
        , ('%s %s'):format(platform.OS, platform.Arch)
        , ('%s %s'):format(platform.CRT, platform.CRTVersion)
        , ('%s %s'):format(platform.Compiler, platform.CompilerVersion)
    ))
end

local function pushErrorLog(link)
    if not log.firstError then
        return
    end
    local err = log.firstError
    log.firstError = nil
    send(link, string.pack('zzzz'
        , 'error'
        , token
        , getClientName()
        , ('%q'):format(err)
    ))
end

timer.wait(5, function ()
    timer.loop(300, function ()
        if not config.Lua.telemetry.enable then
            return
        end
        local suc, link = pcall(net.connect, 'tcp', 'moe-moe.love', 11577)
        if not suc then
            suc, link = pcall(net.connect, 'tcp', '119.45.194.183', 11577)
        end
        if not suc or not link then
            return
        end
        function link:on_connect()
            pushClientInfo(link)
            pushPlatformInfo(link)
            pushErrorLog(link)
            self:close()
        end
    end)()
    timer.loop(1, function ()
        if not config.Lua.telemetry.enable then
            return
        end
        net.update()
    end)
end)

local m = {}

function m.updateConfig()
    if config.Lua.telemetry.enable ~= nil then
        return
    end
    if m.hasShowedMessage then
        return
    end
    m.hasShowedMessage = true

    await.call(function ()
        if client.isVSCode() then
            local enableTitle  = lang.script.WINDOW_TELEMETRY_ENABLE
            local disableTitle = lang.script.WINDOW_TELEMETRY_DISABLE
            local item = proto.awaitRequest('window/showMessageRequest', {
                message = lang.script.WINDOW_TELEMETRY_HINT,
                type    = define.MessageType.Info,
                actions = {
                    {
                        title = enableTitle,
                    },
                    {
                        title = disableTitle,
                    },
                }
            })
            if not item then
                return
            end
            if item.title == enableTitle then
                proto.notify('$/command', {
                    command   = 'lua.config',
                    data      = {
                        key    = 'Lua.telemetry.enable',
                        action = 'set',
                        value  = true,
                        global = true,
                    }
                })
            elseif item.title == disableTitle then
                proto.notify('$/command', {
                    command   = 'lua.config',
                    data      = {
                        key    = 'Lua.telemetry.enable',
                        action = 'set',
                        value  = false,
                        global = true,
                    }
                })
            end
        else
            proto.notify('window/showMessage', {
                message = lang.script.WINDOW_TELEMETRY_HINT,
                type    = define.MessageType.Info,
            })
        end
    end)
end

return m