代码拉取完成,页面将自动刷新
package template
import (
"strings"
"github.com/elastic/beats/libbeat/common"
)
var (
defaultType = "keyword"
)
type Fields []Field
func (f Fields) process(path string, esVersion common.Version) common.MapStr {
output := common.MapStr{}
for _, field := range f {
var mapping common.MapStr
field.path = path
field.esVersion = esVersion
// If not type is defined, it assumes keyword
if field.Type == "" {
field.Type = defaultType
}
switch field.Type {
case "ip":
mapping = field.ip()
case "scaled_float":
mapping = field.scaledFloat()
case "half_float":
mapping = field.halfFloat()
case "integer":
mapping = field.integer()
case "text":
mapping = field.text()
case "keyword":
mapping = field.keyword()
case "object":
mapping = field.object()
case "array":
mapping = field.array()
case "group":
var newPath string
if path == "" {
newPath = field.Name
} else {
newPath = path + "." + field.Name
}
mapping = common.MapStr{
"properties": field.Fields.process(newPath, esVersion),
}
default:
mapping = field.other()
}
if len(mapping) > 0 {
output.Put(generateKey(field.Name), mapping)
}
}
return output
}
// HasKey checks if inside fields the given key exists
// The key can be in the form of a.b.c and it will check if the nested field exist
// In case the key is `a` and there is a value `a.b` false is return as it only
// returns true if it's a leave node
func (f Fields) HasKey(key string) bool {
keys := strings.Split(key, ".")
return f.hasKey(keys)
}
func (f Fields) hasKey(keys []string) bool {
// Nothing to compare anymore
if len(keys) == 0 {
return false
}
key := keys[0]
keys = keys[1:]
for _, field := range f {
if field.Name == key {
if len(field.Fields) > 0 {
return field.Fields.hasKey(keys)
}
// Last entry in the tree but still more keys
if len(keys) > 0 {
return false
}
return true
}
}
return false
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。