openreplay/backend/pkg/db/postgres/mobile.go
Alexander 45c956c489
Json logs format (#1952)
* feat(backend): try a new approach for logs formatting (http)

* feat(backend): added logger module

* feat(backend): added project/session info to /i endpoint

* feat(backend): found a solution for correct caller information

* feat(backend): finished logs for http handlers

* feat(backend): finished logs for mobile http handlers

* feat(backend): finished ender

* feat(backend): finished assets

* feat(backend): finished heuristics

* feat(backend): finished image-storage

* feat(backend): finished sink

* feat(backend): finished storage

* feat(backend): formatted logs in all services

* feat(backend): finished foss part

* feat(backend): added missed foss part

* feat(backend): fixed panic in memory manager and sink service

* feat(backend): connectors
2024-03-14 12:51:14 +01:00

125 lines
3.8 KiB
Go

package postgres
import (
"context"
"openreplay/backend/pkg/hashid"
"openreplay/backend/pkg/messages"
"openreplay/backend/pkg/sessions"
"openreplay/backend/pkg/url"
)
func (conn *Conn) InsertIOSEvent(session *sessions.Session, e *messages.IOSEvent) error {
if err := conn.InsertCustomEvent(session.SessionID, e.Timestamp, truncSqIdx(e.Index), e.Name, e.Payload); err != nil {
return err
}
conn.InsertAutocompleteValue(session.SessionID, session.ProjectID, "CUSTOM_IOS", e.Name)
return nil
}
func (conn *Conn) InsertIOSNetworkCall(sess *sessions.Session, e *messages.IOSNetworkCall) error {
err := conn.InsertRequest(sess.SessionID, e.Timestamp, truncSqIdx(e.Index), e.URL, e.Duration, e.Status < 400)
if err == nil {
conn.InsertAutocompleteValue(sess.SessionID, sess.ProjectID, "REQUEST_IOS", url.DiscardURLQuery(e.URL))
}
return err
}
func (conn *Conn) InsertIOSClickEvent(sess *sessions.Session, clickEvent *messages.IOSClickEvent) error {
if err := conn.Pool.Exec(`
INSERT INTO events_ios.taps (
session_id, timestamp, seq_index, label
) VALUES (
$1, $2, $3, $4
)`,
sess.SessionID, clickEvent.Timestamp, clickEvent.Index, clickEvent.Label,
); err != nil {
return err
}
conn.InsertAutocompleteValue(sess.SessionID, sess.ProjectID, "CLICK_IOS", clickEvent.Label)
return nil
}
func (conn *Conn) InsertIOSSwipeEvent(sess *sessions.Session, swipeEvent *messages.IOSSwipeEvent) error {
if err := conn.Pool.Exec(`
INSERT INTO events_ios.swipes (
session_id, timestamp, seq_index, label, direction
) VALUES (
$1, $2, $3, $4, $5
)`,
sess.SessionID, swipeEvent.Timestamp, swipeEvent.Index, swipeEvent.Label, swipeEvent.Direction,
); err != nil {
return err
}
conn.InsertAutocompleteValue(sess.SessionID, sess.ProjectID, "SWIPE_IOS", swipeEvent.Label)
return nil
}
func (conn *Conn) InsertIOSInputEvent(sess *sessions.Session, inputEvent *messages.IOSInputEvent) error {
if err := conn.Pool.Exec(`
INSERT INTO events_ios.inputs (
session_id, timestamp, seq_index, label
) VALUES (
$1, $2, $3, $4
)`,
sess.SessionID, inputEvent.Timestamp, inputEvent.Index, inputEvent.Label,
); err != nil {
return err
}
conn.InsertAutocompleteValue(sess.SessionID, sess.ProjectID, "INPUT_IOS", inputEvent.Label)
return nil
}
func (conn *Conn) InsertIOSCrash(sessionID uint64, projectID uint32, crash *messages.IOSCrash) error {
crashID := hashid.IOSCrashID(projectID, crash)
if err := conn.Pool.Exec(`
INSERT INTO public.crashes_ios (
project_id, crash_ios_id, name, reason, stacktrace
) VALUES (
$1, $2, $3, $4, $5
) ON CONFLICT DO NOTHING`,
projectID, crashID, crash.Name, crash.Reason, crash.Stacktrace,
); err != nil {
return err
}
if err := conn.Pool.Exec(`
INSERT INTO events_common.crashes (
session_id, timestamp, seq_index, crash_ios_id
) VALUES (
$1, $2, $3, $4
)`,
sessionID, crash.Timestamp, crash.Index, crashID,
); err != nil {
return err
}
return nil
}
func (conn *Conn) InsertIOSIssueEvent(sess *sessions.Session, e *messages.IOSIssueEvent) error {
issueID := hashid.IOSIssueID(sess.ProjectID, e)
payload := &e.Payload
if *payload == "" || *payload == "{}" {
payload = nil
}
ctx := context.WithValue(context.Background(), "sessionID", sess.SessionID)
if err := conn.bulks.Get("webIssues").Append(sess.ProjectID, issueID, e.Type, e.ContextString); err != nil {
conn.log.Error(ctx, "can't add web issue to PG, err: %s", err)
}
if err := conn.bulks.Get("webIssueEvents").Append(sess.SessionID, issueID, e.Timestamp, truncSqIdx(e.Index), payload); err != nil {
conn.log.Error(ctx, "can't add web issue event to PG, err: %s", err)
}
return nil
}
type IOSCrash struct {
Timestamp uint64 `json:"timestamp"`
Name string `json:"name"`
Reason string `json:"reason"`
Stacktrace string `json:"stacktrace"`
}
type WebCrash struct {
Timestamp uint64 `json:"timestamp"`
}