From 674a50124d33c8efef8462e226253ed4caad4563 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Strzali=C5=84ski?= Date: Tue, 12 Nov 2024 13:55:13 +0100 Subject: [PATCH] Fix using '=' operator against an array (#973) It fixes "[Logs] Web Traffic" dashboard panel: Before: Screenshot 2024-11-12 at 12 14 35 After: Screenshot 2024-11-12 at 12 15 30 --- quesma/quesma/schema_array_transformer.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/quesma/quesma/schema_array_transformer.go b/quesma/quesma/schema_array_transformer.go index 9a0752ddd..0ccf39c92 100644 --- a/quesma/quesma/schema_array_transformer.go +++ b/quesma/quesma/schema_array_transformer.go @@ -49,6 +49,7 @@ func NewArrayTypeVisitor(resolver arrayTypeResolver) model.ExprVisitor { dbType := resolver.dbColumnType(column.ColumnName) if strings.HasPrefix(dbType, "Array") { op := strings.ToUpper(e.Op) + op = strings.TrimSpace(op) switch { case (op == "ILIKE" || op == "LIKE") && dbType == "Array(String)": @@ -56,11 +57,11 @@ func NewArrayTypeVisitor(resolver arrayTypeResolver) model.ExprVisitor { lambda := model.NewLambdaExpr([]string{variableName}, model.NewInfixExpr(model.NewLiteral(variableName), op, e.Right.Accept(b).(model.Expr))) return model.NewFunction("arrayExists", lambda, e.Left) - case e.Op == "=": + case op == "=": return model.NewFunction("has", e.Left, e.Right.Accept(b).(model.Expr)) default: - logger.Error().Msgf("Unhandled array infix operation %s, column %v (%v)", e.Op, column.ColumnName, dbType) + logger.Error().Msgf("Unhandled array infix operation '%s', column '%v' ('%v')", e.Op, column.ColumnName, dbType) } } }