Я использую Go для настройки собственного API. Я как бы застрял прямо сейчас из-за того, как я написал код для динамического создания / применения фильтра запросов. Это работает, но мне интересно, есть ли лучший способ сделать сценарий ниже.
Например, у меня есть страница поиска с флажками (1 для электронной почты и 1 для имени), чтобы сузить поиск.
// If I checked the email, the query would be like this
query findOne() {
user(func: type(user)) @filter(eq(email, "john.doe@email.com")) {
name
email
age
home_address
}
}
// If name checkedbox is also checked, it would be like this
query findOne() {
user(func: type(user)) @filter(eq(email, "john") OR eq(name, "john")) {
name
email
age
home_address
}
}
Это то, что я получил до сих пор, и я думаю, что есть лучший способ сделать это:
func (s *Service) GetUser(email, name string) (*Users, error) {
c := db.NewClient()
defer db.Close()
var u Users
var filter string
if email != "" && mobileNumber != "" {
filter = fmt.Sprintf(`eq(email, "%s") OR eq(mobileNumber, "%s")`, email, mobileNumber)
} else if email != "" && mobileNumber == "" {
filter = fmt.Sprintf(`eq(email, "%s")`, email)
} else if email == "" && mobileNumber != "" {
filter = fmt.Sprintf(`eq(mobileNumber, "%s")`, mobileNumber)
}
q := fmt.Sprintf(`query findOne() {
users(func: type("user")) @filter(%s) {
name
email
home_address
contact_number
}
}`, filter)
ctx := context.Background()
res, err := c.NewTxn().Query(ctx, q)
if err != nil {
return nil, err
}
if err = json.Unmarshal(res.Json, &u); err != nil {
return nil, err
}
return &u, nil
}
Есть ли лучший способ сделать это вместо создания длинного условия