diff --git a/pkg/storage/internalstorage/features.go b/pkg/storage/internalstorage/features.go index b59ec093d..14643ab1b 100644 --- a/pkg/storage/internalstorage/features.go +++ b/pkg/storage/internalstorage/features.go @@ -12,6 +12,16 @@ const ( // owner: @cleverhu // alpha: v0.3.0 AllowRawSQLQuery featuregate.Feature = "AllowRawSQLQuery" + + // AllowParameterizedSQLQuery is a feature gate for the apiserver to allow querying by the parameterized SQL + // for better defense against SQL injection. + // + // Use either single whereSQLStatement field, a pair of whereSQLStatement with whereSQLParam, or + // whereSQLStatement with whereSQLJSONParams to pass the SQL it self and parameters. + // + // owner: @nekomeowww + // alpha: v0.8.0 + AllowParameterizedSQLQuery featuregate.Feature = "AllowParameterizedSQLQuery" ) func init() { @@ -21,5 +31,6 @@ func init() { // defaultInternalStorageFeatureGates consists of all known custom internalstorage feature keys. // To add a new feature, define a key for it above and add it here. var defaultInternalStorageFeatureGates = map[featuregate.Feature]featuregate.FeatureSpec{ - AllowRawSQLQuery: {Default: false, PreRelease: featuregate.Alpha}, + AllowRawSQLQuery: {Default: false, PreRelease: featuregate.Alpha}, + AllowParameterizedSQLQuery: {Default: false, PreRelease: featuregate.Alpha}, } diff --git a/pkg/storage/internalstorage/util.go b/pkg/storage/internalstorage/util.go index cfd5161c0..2ada4b940 100644 --- a/pkg/storage/internalstorage/util.go +++ b/pkg/storage/internalstorage/util.go @@ -205,7 +205,7 @@ func applyListOptionsToQuery(query *gorm.DB, opts *internal.ListOptions, applyFn query, err := applyListOptionsURLQueryToWhereClause( utilfeature.DefaultMutableFeatureGate.Enabled(AllowRawSQLQuery), - false, + utilfeature.DefaultMutableFeatureGate.Enabled((AllowParameterizedSQLQuery)), query, opts.URLQuery, )