-
Notifications
You must be signed in to change notification settings - Fork 807
/
json_sonic.go
59 lines (52 loc) · 1.7 KB
/
json_sonic.go
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
/*
* Copyright 2024 CloudWeGo Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package utils
import (
"runtime/debug"
"github.com/cloudwego/kitex/pkg/klog"
"github.com/bytedance/sonic"
)
var sonicConifg = sonic.Config{
EscapeHTML: true,
ValidateString: true,
}.Froze()
// Map2JSONStr transform map[string]string to json str, perf is better than use json lib directly
func Map2JSONStr(mapInfo map[string]string) (str string, err error) {
defer func() {
if r := recover(); r != nil {
str, err = _Map2JSONStr(mapInfo)
klog.Warnf("KITEX: panic when Map2JSONStr, msg=%v, stack=%s", r, string(debug.Stack()))
}
}()
if len(mapInfo) == 0 {
return "{}", nil
}
return sonicConifg.MarshalToString(mapInfo)
}
// JSONStr2Map transform json str to map[string]string, perf is better than use json lib directly
func JSONStr2Map(jsonStr string) (mapInfo map[string]string, err error) {
defer func() {
if r := recover(); r != nil {
mapInfo, err = _JSONStr2Map(jsonStr)
klog.Warnf("KITEX: panic when JSONStr2Map, msg=%v, stack=%s", r, string(debug.Stack()))
}
}()
err = sonicConifg.UnmarshalFromString(jsonStr, &mapInfo)
if len(mapInfo) == 0 {
mapInfo = nil
}
return mapInfo, err
}