tracking: insert basically working

This commit is contained in:
Helmut Merz 2024-03-25 14:59:50 +01:00
parent 4787e4ffce
commit 51401bf909
3 changed files with 37 additions and 5 deletions

View file

@ -36,7 +36,7 @@ insert into {{ $tablename }} (
{{- end -}}) {{- end -}})
values ( values (
{{- range $j, $c := .columns -}} {{- range $j, $c := .columns -}}
{{- if ne $j 0 -}}, {{ end }}${{ $j }} {{- if ne $j 0 -}}, {{ end }}${{ add1 $j }}
{{- end -}}) {{- end -}})
` `
) )

View file

@ -3,6 +3,7 @@
package tracking package tracking
import ( import (
"encoding/json"
"time" "time"
lib "git.sr.ht/~cco/go-scopes" lib "git.sr.ht/~cco/go-scopes"
@ -10,15 +11,16 @@ import (
sql "git.sr.ht/~cco/go-scopes/storage" sql "git.sr.ht/~cco/go-scopes/storage"
) )
type track struct { type Track struct {
TrackId uint TrackId uint
Head map[string]string Head map[string]string
TimeStamp *time.Time TimeStamp *time.Time
Data lib.Payload Data lib.Data
Container *container Container *container
} }
type container struct { type container struct {
tableName string
headFields []string headFields []string
indexes [][]string indexes [][]string
storage *sql.Storage storage *sql.Storage
@ -26,23 +28,47 @@ type container struct {
func Container(db *sql.Storage) *container { func Container(db *sql.Storage) *container {
return &container{ return &container{
tableName: "tracks",
headFields: []string{"taskId", "userName"}, headFields: []string{"taskId", "userName"},
indexes: [][]string{[]string{"taskId", "userName"}, []string{"userName"}}, indexes: [][]string{[]string{"taskId", "userName"}, []string{"userName"}},
storage: db, storage: db,
} }
} }
func Insert(cont *container, tr Track) int64 {
var columns []string
var values []any
for _, k := range cont.headFields {
columns = append(columns, k)
values = append(values, tr.Head[k])
}
columns = append(columns, "Data")
b, _ := json.Marshal(tr.Data)
values = append(values, b)
db := cont.storage
data := map[string]interface{}{
"schema": db.Schema,
"tablename": cont.tableName,
"columns": columns,
}
sql := storage.BuildSql(SqlInsert, data)
if n, err := db.Exec(sql, values...); err == nil {
return n
}
return 0
}
func Create(cont *container) *container { func Create(cont *container) *container {
db := cont.storage db := cont.storage
data := map[string]interface{}{ data := map[string]interface{}{
"schema": db.Schema, "schema": db.Schema,
"tablename": "tracks", "tablename": cont.tableName,
"headFields": cont.headFields, "headFields": cont.headFields,
"indexes": cont.indexes, "indexes": cont.indexes,
"params": db.Params, "params": db.Params,
} }
sql := storage.BuildSql(SqlCreate, data) sql := storage.BuildSql(SqlCreate, data)
println(sql) //println(sql)
_, err := db.Exec(sql) _, err := db.Exec(sql)
if err == nil { if err == nil {
return cont return cont

View file

@ -3,6 +3,7 @@ package scopes
import ( import (
tbase "testing" tbase "testing"
lib "git.sr.ht/~cco/go-scopes"
"git.sr.ht/~cco/go-scopes/common/testing" "git.sr.ht/~cco/go-scopes/common/testing"
"git.sr.ht/~cco/go-scopes/core/message" "git.sr.ht/~cco/go-scopes/core/message"
sql "git.sr.ht/~cco/go-scopes/storage" sql "git.sr.ht/~cco/go-scopes/storage"
@ -67,6 +68,11 @@ func BaseTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
func TrackingTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) { func TrackingTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {
cont := tracking.Container(db) cont := tracking.Container(db)
tracking.Create(cont) tracking.Create(cont)
track := tracking.Track{
Head: map[string]string{"taskId": "t01", "userName": "john"},
Data: lib.Map{},
}
tracking.Insert(cont, track)
} }
func MessageTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) { func MessageTest(t *testing.T, cfg *sql.Cfg, db *sql.Storage) {