summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/authorization.rb5
-rw-r--r--lib/error.rb6
-rw-r--r--lib/model.rb9
-rw-r--r--lib/parser.rb42
-rw-r--r--lib/rest_client_wrapper.rb10
-rw-r--r--lib/task.rb10
-rw-r--r--lib/validation.rb2
7 files changed, 49 insertions, 35 deletions
diff --git a/lib/authorization.rb b/lib/authorization.rb
index b647bca..1942e95 100644
--- a/lib/authorization.rb
+++ b/lib/authorization.rb
@@ -195,7 +195,6 @@ module OpenTox
resource = RestClient::Resource.new("#{AA_SERVER}/Pol/opensso-pol")
LOGGER.debug "OpenTox::Authorization.create_policy policy: #{policy[168,43]} with token:" + subjectid.to_s + " length: " + subjectid.length.to_s
return true if resource.post(policy, :subjectid => subjectid, :content_type => "application/xml")
- #return true if RestClientWrapper.post("#{AA_SERVER}/pol", {:subjectid => subjectid, :content_type => "application/xml"}, policy)
rescue
return false
end
@@ -379,6 +378,4 @@ module OpenTox
end
end
-end
-
-
+end \ No newline at end of file
diff --git a/lib/error.rb b/lib/error.rb
index d086928..7ca9767 100644
--- a/lib/error.rb
+++ b/lib/error.rb
@@ -55,7 +55,7 @@ module OpenTox
end
def self.from_rdf(rdf)
- metadata = OpenTox::Parser::Owl.metadata_from_rdf( rdf, OT.ErrorReport )
+ metadata = OpenTox::Parser::Owl.from_rdf( rdf, OT.ErrorReport ).metadata
ErrorReport.new(metadata[OT.statusCode], metadata[OT.errorCode], metadata[OT.message], metadata[OT.actor], metadata[OT.errorCause])
end
@@ -78,10 +78,6 @@ module OpenTox
c[OT.errorCause] = @errorCause.rdf_content if @errorCause
c
end
-
- def self.from_rdf(rdf)
- raise "not yet implemented"
- end
def to_rdfxml
s = Serializer::Owl.new
diff --git a/lib/model.rb b/lib/model.rb
index 64d178f..9622d65 100644
--- a/lib/model.rb
+++ b/lib/model.rb
@@ -43,9 +43,11 @@ module OpenTox
@algorithm = OpenTox::Algorithm::Generic.find(@metadata[OT.algorithm], subjectid) unless @algorithm
algorithm_title = @algorithm ? @algorithm.metadata[DC.title] : nil
+ algorithm_type = @algorithm ? @algorithm.metadata[OT.isA] : nil
@dependentVariable = OpenTox::Feature.find( @metadata[OT.dependentVariables],subjectid ) unless @dependentVariable
-
- [@dependentVariable.feature_type, @metadata[OT.isA], @metadata[DC.title], @uri, algorithm_title].each do |type|
+ type_indicators = [@dependentVariable.feature_type, @metadata[OT.isA], @metadata[DC.title],
+ @uri, algorithm_type, algorithm_title]
+ type_indicators.each do |type|
case type
when /(?i)classification/
return "classification"
@@ -53,8 +55,7 @@ module OpenTox
return "regression"
end
end
- raise "unknown model "+[@dependentVariable.feature_type, @metadata[OT.isA],
- @metadata[DC.title], @uri, algorithm_title].inspect
+ raise "unknown model "+type_indicators.inspect
end
end
diff --git a/lib/parser.rb b/lib/parser.rb
index 1a872a0..2f59d15 100644
--- a/lib/parser.rb
+++ b/lib/parser.rb
@@ -30,7 +30,6 @@ module OpenTox
# Read metadata from opentox service
# @return [Hash] Object metadata
def load_metadata(subjectid=nil)
-
if @dataset
uri = File.join(@uri,"metadata")
else
@@ -42,17 +41,17 @@ module OpenTox
##uri += "?subjectid=#{CGI.escape(subjectid)}" if subjectid
## `rapper -i rdfxml -o ntriples #{uri} 2>/dev/null`.each_line do |line|
file = Tempfile.new("ot-rdfxml")
- file.puts OpenTox::RestClientWrapper.get @uri,{:subjectid => subjectid,:accept => "application/rdf+xml"}
+ file.puts OpenTox::RestClientWrapper.get @uri,{:subjectid => subjectid,:accept => "application/rdf+xml"},nil,false
file.close
- file = "file://"+file.path
statements = []
parameter_ids = []
- `rapper -i rdfxml -o ntriples #{file} 2>/dev/null`.each_line do |line|
+ `rapper -i rdfxml -o ntriples file://#{file.path} 2>/dev/null`.each_line do |line|
triple = line.to_triple
@metadata[triple[1]] = triple[2].split('^^').first if triple[0] == @uri and triple[1] != RDF['type']
statements << triple
parameter_ids << triple[2] if triple[1] == OT.parameters
end
+ File.delete(file.path)
unless parameter_ids.empty?
@metadata[OT.parameters] = []
parameter_ids.each do |p|
@@ -64,18 +63,17 @@ module OpenTox
@metadata
end
- # loads metadata from rdf-data
+ # creates owl object from rdf-data
# @param [String] rdf
# @param [String] type of the info (e.g. OT.Task, OT.ErrorReport) needed to get the subject-uri
- # @return [Hash] metadata
- def self.metadata_from_rdf( rdf, type )
+ # @return [Owl] with uri and metadata set
+ def self.from_rdf( rdf, type )
# write to file and read convert with rapper into tripples
file = Tempfile.new("ot-rdfxml")
file.puts rdf
file.close
- file = "file://"+file.path
#puts "cmd: rapper -i rdfxml -o ntriples #{file} 2>/dev/null"
- triples = `rapper -i rdfxml -o ntriples #{file} 2>/dev/null`
+ triples = `rapper -i rdfxml -o ntriples file://#{file.path} 2>/dev/null`
# load uri via type
uri = nil
@@ -86,19 +84,23 @@ module OpenTox
uri = triple[0]
end
end
-
+ File.delete(file)
# load metadata
metadata = {}
triples.each_line do |line|
triple = line.to_triple
metadata[triple[1]] = triple[2].split('^^').first if triple[0] == uri and triple[1] != RDF['type']
end
- metadata
+ owl = Owl::Generic.new(uri)
+ owl.metadata = metadata
+ owl
end
-
+
# Generic parser for all OpenTox classes
class Generic
include Owl
+
+ attr_accessor :uri, :metadata
end
# OWL-DL parser for datasets
@@ -129,12 +131,21 @@ module OpenTox
# @return [Hash] Internal dataset representation
def load_uri(subjectid=nil)
uri = @uri
- uri += "?subjectid=#{CGI.escape(subjectid)}" if subjectid
+
+ # avoid using rapper directly because of 2 reasons:
+ # * http errors wont be noticed
+ # * subjectid cannot be sent as header
+ ##uri += "?subjectid=#{CGI.escape(subjectid)}" if subjectid
+ ##`rapper -i rdfxml -o ntriples #{file} 2>/dev/null`.each_line do |line|
+ file = Tempfile.new("ot-rdfxml")
+ file.puts OpenTox::RestClientWrapper.get @uri,{:subjectid => subjectid,:accept => "application/rdf+xml"},nil,false
+ file.close
+
data = {}
feature_values = {}
feature = {}
other_statements = {}
- `rapper -i rdfxml -o ntriples #{uri} 2>/dev/null`.each_line do |line|
+ `rapper -i rdfxml -o ntriples file://#{file.path} 2>/dev/null`.each_line do |line|
triple = line.chomp.split(' ',3)
triple = triple[0..2].collect{|i| i.sub(/\s+.$/,'').gsub(/[<>"]/,'')}
case triple[1]
@@ -151,6 +162,7 @@ module OpenTox
else
end
end
+ File.delete(file.path)
data.each do |id,entry|
entry[:values].each do |value_id|
value = feature_values[value_id].split(/\^\^/).first # remove XSD.type
@@ -158,7 +170,7 @@ module OpenTox
end
end
load_features
- @dataset.metadata = load_metadata
+ @dataset.metadata = load_metadata(subjectid)
@dataset
end
diff --git a/lib/rest_client_wrapper.rb b/lib/rest_client_wrapper.rb
index 658f111..7a6ed2a 100644
--- a/lib/rest_client_wrapper.rb
+++ b/lib/rest_client_wrapper.rb
@@ -61,6 +61,8 @@ module OpenTox
raise "__waiting_task__ must be 'nil' or '(sub)task', is "+waiting_task.class.to_s if
waiting_task!=nil and !(waiting_task.is_a?(Task) || waiting_task.is_a?(SubTask))
headers.each{ |k,v| headers.delete(k) if v==nil } if headers #remove keys with empty values, as this can cause problems
+ ## PENDING partner services accept subjectid only in header
+ headers[:subjectid] = payload.delete(:subjectid) if payload and payload.is_a?(Hash) and payload.has_key?(:subjectid)
# PENDING needed for NUTA, until we finally agree on how to send subjectid
headers[:subjectid] = payload.delete(:subjectid) if uri=~/ntua/ and payload and payload.is_a?(Hash) and payload.has_key?(:subjectid)
@@ -94,6 +96,8 @@ module OpenTox
rescue RestClient::RequestTimeout => ex
received_error ex.message, 408, nil, {:rest_uri => uri, :headers => headers, :payload => payload}
+ rescue Errno::ECONNREFUSED => ex
+ received_error ex.message, 500, nil, {:rest_uri => uri, :headers => headers, :payload => payload}
rescue RestClient::ExceptionWithResponse => ex
# error comming from a different webservice,
received_error ex.http_body, ex.http_code, ex.response.net_http_res.content_type, {:rest_uri => uri, :headers => headers, :payload => payload}
@@ -107,7 +111,9 @@ module OpenTox
end
def self.wait_for_task( res, base_uri, waiting_task=nil )
-
+ #TODO remove TUM hack
+ res.content_type = "text/uri-list" if base_uri =~/tu-muenchen/ and res.content_type == "application/x-www-form-urlencoded;charset=UTF-8"
+
task = nil
case res.content_type
when /application\/rdf\+xml/
@@ -118,7 +124,7 @@ module OpenTox
raise "uri list has more than one entry, should be a task" if res.content_type=~/text\/uri-list/ and res.split("\n").size > 1 #if uri list contains more then one uri, its not a task
task = OpenTox::Task.find(res.to_s.chomp) if res.to_s.uri?
else
- raise "unknown content-type for task: '"+res.content_type.to_s+"'" #+"' content: "+res[0..200].to_s
+ raise "unknown content-type for task : '"+res.content_type.to_s+"'"+" base-uri: "+base_uri.to_s+" content: "+res[0..200].to_s
end
LOGGER.debug "result is a task '"+task.uri.to_s+"', wait for completion"
diff --git a/lib/task.rb b/lib/task.rb
index 7aa3dd5..0ee3a11 100644
--- a/lib/task.rb
+++ b/lib/task.rb
@@ -104,7 +104,6 @@ module OpenTox
def self.from_yaml(yaml)
@metadata = YAML.load(yaml)
end
-
def self.from_rdfxml(rdfxml)
owl = OpenTox::Parser::Owl.from_rdf(rdfxml, OT.Task)
@@ -175,7 +174,7 @@ module OpenTox
end
def load_metadata
- if (CONFIG[:yaml_hosts].include?(URI.parse(uri).host))
+ if (CONFIG[:yaml_hosts].include?(URI.parse(@uri).host))
result = RestClientWrapper.get(@uri, {:accept => 'application/x-yaml'}, nil, false)
@metadata = YAML.load result.to_s
@http_code = result.code
@@ -183,6 +182,7 @@ module OpenTox
@metadata = Parser::Owl::Generic.new(@uri).load_metadata
@http_code = RestClientWrapper.get(uri, {:accept => 'application/rdf+xml'}, nil, false).code
end
+ raise "could not load task metadata for task "+@uri.to_s if @metadata==nil || @metadata.size==0
end
# create is private now, use OpenTox::Task.as_task
@@ -273,11 +273,14 @@ module OpenTox
end
private
+ VALID_TASK_STATES = ["Cancelled", "Completed", "Running", "Error"]
+
def check_state
begin
+ raise "illegal task state, invalid status: '"+@metadata[OT.hasStatus].to_s+"'" unless
+ @metadata[OT.hasStatus] unless VALID_TASK_STATES.include?(@metadata[OT.hasStatus])
raise "illegal task state, task is completed, resultURI is no URI: '"+@metadata[OT.resultURI].to_s+
"'" unless @metadata[OT.resultURI] and @metadata[OT.resultURI].to_s.uri? if completed?
-
if @http_code == 202
raise "#{@uri}: illegal task state, code is 202, but hasStatus is not Running: '"+@metadata[OT.hasStatus]+"'" unless running?
elsif @http_code == 201
@@ -289,7 +292,6 @@ module OpenTox
raise OpenTox::BadRequestError.new ex.message+" (task-uri:"+@uri+")"
end
end
-
end
# Convenience class to split a (sub)task into subtasks
diff --git a/lib/validation.rb b/lib/validation.rb
index 2ea19a9..a47a554 100644
--- a/lib/validation.rb
+++ b/lib/validation.rb
@@ -88,7 +88,7 @@ module OpenTox
# looks for report for this crossvalidation, creates a report if no report is found
# @param [String,optional] subjectid
# @param [OpenTox::Task,optional] waiting_task (can be a OpenTox::Subtask as well), progress is updated accordingly
- # @return [OpenTox::CrossvalidationReport]
+ # @return [String] report uri
def find_or_create_report( subjectid=nil, waiting_task=nil )
@report = CrossvalidationReport.find_for_crossvalidation(@uri, subjectid) unless @report
@report = CrossvalidationReport.create(@uri, subjectid, waiting_task) unless @report