mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-09 19:48:45 +01:00
2f7cce294c
* sync schema.sql with running schema * remove incognito field from history table. also don't add empty FeState vars * history updates, add festate, durationms, exitcode, status, and tags into history table * update screen/session delete, and clear to no longer purge history items. move deleted screens/sessions into a tombstone table. * update schema * fix alias -> fn * quiet the security warning about an unchecked byte conversion. no real security issue here, but add a range check for good measure.
236 lines
3.9 KiB
Go
236 lines
3.9 KiB
Go
// Copyright 2023, Command Line Inc.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package dbutil
|
|
|
|
import (
|
|
"database/sql/driver"
|
|
"encoding/json"
|
|
"fmt"
|
|
"reflect"
|
|
"strconv"
|
|
)
|
|
|
|
func QuickSetStr(strVal *string, m map[string]interface{}, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
return
|
|
}
|
|
ival, ok := v.(int64)
|
|
if ok {
|
|
*strVal = strconv.FormatInt(ival, 10)
|
|
return
|
|
}
|
|
str, ok := v.(string)
|
|
if !ok {
|
|
return
|
|
}
|
|
*strVal = str
|
|
}
|
|
|
|
func QuickSetInt(ival *int, m map[string]interface{}, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
return
|
|
}
|
|
sqlInt, ok := v.(int)
|
|
if ok {
|
|
*ival = sqlInt
|
|
return
|
|
}
|
|
sqlInt64, ok := v.(int64)
|
|
if ok {
|
|
*ival = int(sqlInt64)
|
|
return
|
|
}
|
|
}
|
|
|
|
func QuickSetNullableInt64(ival **int64, m map[string]any, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
// set to nil
|
|
return
|
|
}
|
|
sqlInt64, ok := v.(int64)
|
|
if ok {
|
|
*ival = &sqlInt64
|
|
return
|
|
}
|
|
sqlInt, ok := v.(int)
|
|
if ok {
|
|
sqlInt64 = int64(sqlInt)
|
|
*ival = &sqlInt64
|
|
return
|
|
}
|
|
}
|
|
|
|
func QuickSetInt64(ival *int64, m map[string]interface{}, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
// leave as zero
|
|
return
|
|
}
|
|
sqlInt64, ok := v.(int64)
|
|
if ok {
|
|
*ival = sqlInt64
|
|
return
|
|
}
|
|
sqlInt, ok := v.(int)
|
|
if ok {
|
|
*ival = int64(sqlInt)
|
|
return
|
|
}
|
|
}
|
|
|
|
func QuickSetBool(bval *bool, m map[string]interface{}, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
return
|
|
}
|
|
sqlInt, ok := v.(int64)
|
|
if ok {
|
|
if sqlInt > 0 {
|
|
*bval = true
|
|
}
|
|
return
|
|
}
|
|
sqlBool, ok := v.(bool)
|
|
if ok {
|
|
*bval = sqlBool
|
|
}
|
|
}
|
|
|
|
func QuickSetBytes(bval *[]byte, m map[string]interface{}, name string) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
return
|
|
}
|
|
sqlBytes, ok := v.([]byte)
|
|
if ok {
|
|
*bval = sqlBytes
|
|
}
|
|
}
|
|
|
|
func getByteArr(m map[string]any, name string, def string) ([]byte, bool) {
|
|
v, ok := m[name]
|
|
if !ok {
|
|
return nil, false
|
|
}
|
|
barr, ok := v.([]byte)
|
|
if !ok {
|
|
str, ok := v.(string)
|
|
if !ok {
|
|
return nil, false
|
|
}
|
|
barr = []byte(str)
|
|
}
|
|
if len(barr) == 0 {
|
|
barr = []byte(def)
|
|
}
|
|
return barr, true
|
|
}
|
|
|
|
func QuickSetJson(ptr interface{}, m map[string]interface{}, name string) {
|
|
barr, ok := getByteArr(m, name, "{}")
|
|
if !ok {
|
|
return
|
|
}
|
|
json.Unmarshal(barr, ptr)
|
|
}
|
|
|
|
func QuickSetNullableJson(ptr interface{}, m map[string]interface{}, name string) {
|
|
barr, ok := getByteArr(m, name, "null")
|
|
if !ok {
|
|
return
|
|
}
|
|
json.Unmarshal(barr, ptr)
|
|
}
|
|
|
|
func QuickSetJsonArr(ptr interface{}, m map[string]interface{}, name string) {
|
|
barr, ok := getByteArr(m, name, "[]")
|
|
if !ok {
|
|
return
|
|
}
|
|
json.Unmarshal(barr, ptr)
|
|
}
|
|
|
|
func CheckNil(v interface{}) bool {
|
|
rv := reflect.ValueOf(v)
|
|
if !rv.IsValid() {
|
|
return true
|
|
}
|
|
switch rv.Kind() {
|
|
case reflect.Chan, reflect.Func, reflect.Interface, reflect.Map, reflect.Pointer, reflect.Slice:
|
|
return rv.IsNil()
|
|
|
|
default:
|
|
return false
|
|
}
|
|
}
|
|
|
|
func QuickNullableJson(v interface{}) string {
|
|
if CheckNil(v) {
|
|
return "null"
|
|
}
|
|
barr, _ := json.Marshal(v)
|
|
return string(barr)
|
|
}
|
|
|
|
func QuickJson(v interface{}) string {
|
|
if CheckNil(v) {
|
|
return "{}"
|
|
}
|
|
barr, _ := json.Marshal(v)
|
|
return string(barr)
|
|
}
|
|
|
|
func QuickJsonBytes(v interface{}) []byte {
|
|
if CheckNil(v) {
|
|
return []byte("{}")
|
|
}
|
|
barr, _ := json.Marshal(v)
|
|
return barr
|
|
}
|
|
|
|
func QuickJsonArr(v interface{}) string {
|
|
if CheckNil(v) {
|
|
return "[]"
|
|
}
|
|
barr, _ := json.Marshal(v)
|
|
return string(barr)
|
|
}
|
|
|
|
func QuickJsonArrBytes(v interface{}) []byte {
|
|
if CheckNil(v) {
|
|
return []byte("[]")
|
|
}
|
|
barr, _ := json.Marshal(v)
|
|
return barr
|
|
}
|
|
|
|
func QuickScanJson(ptr interface{}, val interface{}) error {
|
|
barrVal, ok := val.([]byte)
|
|
if !ok {
|
|
strVal, ok := val.(string)
|
|
if !ok {
|
|
return fmt.Errorf("cannot scan '%T' into '%T'", val, ptr)
|
|
}
|
|
barrVal = []byte(strVal)
|
|
}
|
|
if len(barrVal) == 0 {
|
|
barrVal = []byte("{}")
|
|
}
|
|
return json.Unmarshal(barrVal, ptr)
|
|
}
|
|
|
|
func QuickValueJson(v interface{}) (driver.Value, error) {
|
|
if CheckNil(v) {
|
|
return "{}", nil
|
|
}
|
|
barr, err := json.Marshal(v)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return string(barr), nil
|
|
}
|