mirror of
https://github.com/muety/wakapi.git
synced 2023-08-10 21:12:56 +03:00
fix: support user agents set by browser plugin (see #237)
This commit is contained in:
parent
c9f2518fbc
commit
bfeebafb2f
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,7 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/duke-git/lancet/v2/condition"
|
||||||
"github.com/go-chi/chi/v5"
|
"github.com/go-chi/chi/v5"
|
||||||
"github.com/muety/wakapi/helpers"
|
"github.com/muety/wakapi/helpers"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -87,11 +88,22 @@ func (h *HeartbeatApiHandler) Post(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
hb.OperatingSystem = opSys
|
// TODO: unit test this
|
||||||
hb.Editor = editor
|
if hb.UserAgent != "" {
|
||||||
hb.Machine = machineName
|
userAgent = hb.UserAgent
|
||||||
|
localOpSys, localEditor, _ := utils.ParseUserAgent(userAgent)
|
||||||
|
opSys = condition.TernaryOperator[bool, string](localOpSys != "", localOpSys, opSys)
|
||||||
|
editor = condition.TernaryOperator[bool, string](localEditor != "", localEditor, editor)
|
||||||
|
}
|
||||||
|
if hb.Machine != "" {
|
||||||
|
machineName = hb.Machine
|
||||||
|
}
|
||||||
|
|
||||||
hb.User = user
|
hb.User = user
|
||||||
hb.UserID = user.ID
|
hb.UserID = user.ID
|
||||||
|
hb.Machine = machineName
|
||||||
|
hb.OperatingSystem = opSys
|
||||||
|
hb.Editor = editor
|
||||||
hb.UserAgent = userAgent
|
hb.UserAgent = userAgent
|
||||||
|
|
||||||
if !hb.Valid() || !hb.Timely(h.config.App.HeartbeatsMaxAge()) {
|
if !hb.Valid() || !hb.Timely(h.config.App.HeartbeatsMaxAge()) {
|
||||||
|
@ -49,6 +49,12 @@ func TestCommon_ParseUserAgent(t *testing.T) {
|
|||||||
"emacs",
|
"emacs",
|
||||||
nil,
|
nil,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"Chrome/111.0.0.0 chrome-wakatime/3.0.6",
|
||||||
|
"",
|
||||||
|
"chrome",
|
||||||
|
nil,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
@ -78,7 +78,7 @@ func ParsePageParamsWithDefault(r *http.Request, page, size int) *PageParams {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func ParseUserAgent(ua string) (string, string, error) {
|
func ParseUserAgent(ua string) (string, string, error) {
|
||||||
re := regexp.MustCompile(`(?iU)^wakatime\/(?:v?[\d+.]+|unset)\s\((\w+)-.*\)\s.+\s([^\/\s]+)-wakatime\/.+$`)
|
re := regexp.MustCompile(`(?iU)^(?:(?:wakatime|chrome|firefox)\/(?:v?[\d+.]+|unset)\s)?(?:\((\w+)-.*\)\s.+\s)?([^\/\s]+)-wakatime\/.+$`)
|
||||||
groups := re.FindAllStringSubmatch(ua, -1)
|
groups := re.FindAllStringSubmatch(ua, -1)
|
||||||
if len(groups) == 0 || len(groups[0]) != 3 {
|
if len(groups) == 0 || len(groups[0]) != 3 {
|
||||||
return "", "", errors.New("failed to parse user agent string")
|
return "", "", errors.New("failed to parse user agent string")
|
||||||
|
Loading…
Reference in New Issue
Block a user