2007-01-17 05:37:56 -05:00
|
|
|
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
|
|
# (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
2007-01-16 17:02:29 -05:00
|
|
|
module Solr
|
|
|
|
module Response
|
|
|
|
|
|
|
|
class Ruby < Solr::Response::Base
|
|
|
|
attr_reader :data
|
|
|
|
|
|
|
|
def initialize(ruby_code)
|
|
|
|
super(ruby_code)
|
|
|
|
begin
|
2007-01-17 02:55:00 -05:00
|
|
|
#TODO: what about pulling up data/header/response to ResponseBase,
|
|
|
|
# or maybe a new middle class like SelectResponseBase since
|
|
|
|
# all Select queries return this same sort of stuff??
|
|
|
|
# XML (&wt=xml) and Ruby (&wt=ruby) responses contain exactly the same structure.
|
|
|
|
# a goal of solrb is to make it irrelevant which gets used under the hood,
|
|
|
|
# but favor Ruby responses.
|
2007-01-16 17:02:29 -05:00
|
|
|
@data = eval(ruby_code)
|
|
|
|
@header = @data['responseHeader']
|
|
|
|
raise "response should be a hash" unless @data.kind_of? Hash
|
|
|
|
raise "response header missing" unless @header.kind_of? Hash
|
2007-01-21 15:42:14 -05:00
|
|
|
rescue SyntaxError => e
|
2007-01-16 17:02:29 -05:00
|
|
|
raise Solr::Exception.new("invalid ruby code: #{e}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def ok?
|
|
|
|
return @header['status'] == 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def query_time
|
|
|
|
return @header['QTime']
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|