diff --git a/netmap/policy.go b/netmap/policy.go index 5d85897b..e28c89ed 100644 --- a/netmap/policy.go +++ b/netmap/policy.go @@ -940,10 +940,14 @@ func operationFromString(s string) (op netmap.Operation) { return } -// escapeString returns single quote wrapped string if it contains special -// characters '-' and whitespace. +// escapeString returns single quote wrapped string. +// Wrapping rules must be kept in sync with QueryLexer.g4. +// Currently only ASCII letters, digits and underscore can be parsed without quotes. func escapeString(s string) string { - if strings.ContainsAny(s, " -\t") { + for _, r := range s { + if 'a' <= r && r <= 'z' || 'A' <= r && r <= 'Z' || '0' <= r && r <= '9' || r == '_' { + continue + } return "'" + s + "'" } return s diff --git a/netmap/policy_decode_test.go b/netmap/policy_decode_test.go index c38b608a..0c78fa8a 100644 --- a/netmap/policy_decode_test.go +++ b/netmap/policy_decode_test.go @@ -36,6 +36,11 @@ FILTER City EQ SPB AND SSD EQ true OR City EQ SPB AND Rating GE 5 AS SPBSSD`, SELECT 1 IN City FROM SPBSSD AS SPB FILTER NOT (NOT (City EQ SPB) AND SSD EQ true OR City EQ SPB AND Rating GE 5) AS SPBSSD`, + `REP 1 IN FNODE +CBF 1 +SELECT 1 FROM F AS FNODE +FILTER Node EQ '10.78.8.11' AS F`, + `UNIQUE REP 1 REP 1`,