As the name implies, I am upgrading to ES5. My initial ES request looked like this:
my $response = $elastic->do_request_new( 
        {
            query       => {
                filtered    => {
                    filter  => {
                        or  => [
                            { term  => { _type  => { value => "some_val1" } } },
                            { term  => { _type  => { value => "some_val2" } } },
                        ]
                    },
                    query   => {
                        query_string    => {
                            query   => $qstring,
                            rewrite => "scoring_boolean", 
                            analyze_wildcard => "true",
                        }
                    }
                }
            },
            sort    => [ qw(_score) ],
            size => 50,
        },
    ); 
My updated looks like this:
my $response = $elastic->do_request_new(
    {
        query       => {
            bool    => {
                should  => [
                    { term  => { _type  => { value => "some_val1" } } },
                    { term  => { _type  => { value => "some_val2" } } },
                ],
                must   => {
                    query_string    => {
                        query   => $qstring,
                        rewrite => "scoring_boolean", 
                        analyze_wildcard => "true",
                    }
                }
            }
        },
        sort    => [ qw(_score) ],
        size => 50,
    },
); 
However, when searching for exact rows in my elastic database, I return null results:
{
  "took" : 3,
  "timed_out" : false,
  "_shards" : {
    "total" : 5,
    "successful" : 5,
    "failed" : 0
  },
  "hits" : {
    "total" : 0,
    "max_score" : null,
    "hits" : [ ]
  }
}
Any ideas on what could happen? I assume that I have the wrong request structure. Thank!