restheart 2 - 聚合错误

时间:2016-10-04 15:34:25

标签: mongodb mongodb-query aggregation-framework mongodb-aggregation restheart

我们有一个在restheart 1.1.0中运行的聚合操作,但现在它不在2.0.2中。我们一直在聚合操作中使用变量来处理动态代码生成。下面是一个简单的例子。这个问题有解决方法吗?

这是聚合操作:

 {
      "type" : "pipeline", 
      "uri" : "agg_companies", 
      "stages" : [
          {
              "_$match" : {
                  "_$var" : "filter_query"
              }
          }, 
          {
              "_$group" : {
                  "_id" : "$organization._id", 
                  "name" : {
                      "_$first" : "$organization.name"
                  }
              }
          }, 
          {
              "_$sort" : {
                  "name" : NumberInt(1)
              }
          }
      ]
  }

我正在使用具有以下内容的节点向聚合发出请求:

这有效:

var avars = {filter_query: {travelerLastName: "Brewer"}};

这失败了:

var avars = {filter_query: {travelerLastName: {$and: ["Brewer"]}}};

错误:

{ "_links" : { "self" : { "href" : "/foresiteamo/flight/_aggrs/agg_companies2"}} , "http status code" : 400 , "http status description" : "Bad Request" , "message" : "illegal avars paramenter: {\'filter_query\':{\'travelerLastName\':{\'$and\':[\'Brewer\']}}}" , "_embedded" : { "rh:exception" : [ { "exception" : "java.lang.SecurityException" , "exception message" : "aggregation variables cannot include operators"}]}}

1 个答案:

答案 0 :(得分:0)

RESTHeart不允许avars包含运算符(任何以$开头的键)。

这是为了避免客户端将逻辑注入聚合并最终修改它。

考虑可能用于监听受限数据的$ lookup运算符......