summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Rakefile2
-rw-r--r--VERSION2
-rw-r--r--lib/algorithm.rb1
-rw-r--r--lib/compound.rb10
-rw-r--r--lib/config/config_ru.rb (renamed from lib/tasks/config.rb)0
-rw-r--r--lib/dataset.rb2
-rw-r--r--lib/environment.rb22
-rw-r--r--lib/model.rb8
-rw-r--r--lib/task.rb41
-rw-r--r--opentox-ruby-api-wrapper.gemspec1
10 files changed, 65 insertions, 24 deletions
diff --git a/Rakefile b/Rakefile
index ba06640..e585ca6 100644
--- a/Rakefile
+++ b/Rakefile
@@ -10,7 +10,7 @@ begin
gem.email = "helma@in-silico.ch"
gem.homepage = "http://github.com/helma/opentox-ruby-api-wrapper"
gem.authors = ["Christoph Helma"]
- ["sinatra", "rest-client", "rack", "rack-contrib", "rack-flash", "thin", "emk-sinatra-url-for", "cehoffman-sinatra-respond_to", "dm-more", "dm-core", "sinatra-static-assets"].each do |dep|
+ ["sinatra", "rest-client", "rack", "rack-contrib", "rack-flash", "thin", "emk-sinatra-url-for", "cehoffman-sinatra-respond_to", "dm-more", "dm-core", "sinatra-static-assets", "do_sqlite3", "do_postgres"].each do |dep|
gem.add_dependency dep
end
gem.add_development_dependency "cucumber"
diff --git a/VERSION b/VERSION
index 3c43790..c04c650 100644
--- a/VERSION
+++ b/VERSION
@@ -1 +1 @@
-1.2.6
+1.2.7
diff --git a/lib/algorithm.rb b/lib/algorithm.rb
index c5d162a..25ae4cb 100644
--- a/lib/algorithm.rb
+++ b/lib/algorithm.rb
@@ -39,6 +39,7 @@ module OpenTox
end
def self.create_model(params)
+ LOGGER.debug params
@uri = RestClient.post File.join(@@config[:services]["opentox-algorithm"], "lazar"), :dataset_uri => params[:dataset_uri], :feature_uri => params[:feature_uri], :feature_generation_uri => File.join(@@config[:services]["opentox-algorithm"], "fminer")
end
diff --git a/lib/compound.rb b/lib/compound.rb
index 562baaa..56646c0 100644
--- a/lib/compound.rb
+++ b/lib/compound.rb
@@ -21,20 +21,20 @@ module OpenTox
@uri = File.join(@@config[:services]["opentox-compound"],URI.escape(@inchi))
elsif params[:uri]
@uri = params[:uri]
- if params[:uri].match(/InChI/) # shortcut for IST services
+ case params[:uri]
+ when /ambit/ # Ambit does not deliver InChIs reliably
+ smiles = RestClient.get @uri, :accept => 'chemical/x-daylight-smiles'
+ @inchi = obconversion(smiles,'smi','inchi')
+ when /InChI/ # shortcut for IST services
@inchi = params[:uri].sub(/^.*InChI/, 'InChI')
else
@inchi = RestClient.get @uri, :accept => 'chemical/x-inchi'
- # AMBIT does not provide InChIs
- #smiles = RestClient.get(@uri, :accept => 'chemical/x-daylight-smiles').split(/\s+/).first # fix ambit output
- #@inchi = obconversion(smiles,'smi','inchi')
end
end
end
# Get the (canonical) smiles
def smiles
- #RestClient.get(@uri, :accept => 'chemical/x-daylight-smiles').split(/\s+/).first # fix ambit output
obconversion(@inchi,'inchi','can')
end
diff --git a/lib/tasks/config.rb b/lib/config/config_ru.rb
index 3720ef3..3720ef3 100644
--- a/lib/tasks/config.rb
+++ b/lib/config/config_ru.rb
diff --git a/lib/dataset.rb b/lib/dataset.rb
index 0a49e87..bd523a3 100644
--- a/lib/dataset.rb
+++ b/lib/dataset.rb
@@ -87,7 +87,7 @@ module OpenTox
def self.find(uri)
dataset = Dataset.new
data = `curl "#{uri}"`
- #data = RestClient.get uri, :accept => 'application/rdf+xml' # unclear why this does not work for complex uris, Dataset.find works from irb
+ #data = RestClient.get(uri, :accept => 'application/rdf+xml') # unclear why this does not work for complex uris, Dataset.find works from irb
dataset.rdf = data
dataset
end
diff --git a/lib/environment.rb b/lib/environment.rb
index a9d0797..fedc3cf 100644
--- a/lib/environment.rb
+++ b/lib/environment.rb
@@ -2,7 +2,7 @@ require 'logger'
# set default environment
ENV['RACK_ENV'] = 'test' unless ENV['RACK_ENV']
-# load configuration
+# load/setup configuration
basedir = File.join(ENV['HOME'], ".opentox")
config_dir = File.join(basedir, "config")
config_file = File.join(config_dir, "#{ENV['RACK_ENV']}.yaml")
@@ -19,6 +19,26 @@ else
puts "Please edit #{config_file} and restart your application."
exit
end
+
+# database
+if @@config[:database]
+ ['dm-core', 'dm-serializer', 'dm-timestamps', 'dm-types'].each{|lib| require lib }
+ case @@config[:database][:adapter]
+ when /sqlite/i
+ db_dir = File.join(basedir, "db")
+ FileUtils.mkdir_p db_dir
+ DataMapper::setup(:default, "sqlite3://#{db_dir}/opentox.sqlite3")
+ else
+ DataMapper.setup(:default, {
+ :adapter => @@config[:database][:adapter],
+ :database => @@config[:database][:database],
+ :username => @@config[:database][:username],
+ :password => @@config[:database][:password],
+ :host => @@config[:database][:host]})
+ end
+end
+
+# logging
logfile = "#{LOG_DIR}/#{ENV["RACK_ENV"]}.log"
LOGGER = Logger.new(logfile,'daily') # daily rotation
LOGGER.level = Logger::DEBUG
diff --git a/lib/model.rb b/lib/model.rb
index bd9d546..a585b59 100644
--- a/lib/model.rb
+++ b/lib/model.rb
@@ -50,6 +50,14 @@ module OpenTox
RestClient.post(@@config[:services]["opentox-model"], data, :content_type => "application/x-yaml").to_s
end
+# def self.create(task)
+# @uri = RestClient.post(@@config[:services]["opentox-model"], :task_uri => task.uri)
+# end
+
+# def yaml=(data)
+# RestClient.put(@@uri, data, :content_type => "application/x-yaml").to_s
+# end
+
def endpoint
YAML.load(RestClient.get(uri))[:endpoint]
end
diff --git a/lib/task.rb b/lib/task.rb
index 24bd944..70d22bf 100644
--- a/lib/task.rb
+++ b/lib/task.rb
@@ -10,7 +10,7 @@ module OpenTox
end
def self.create
- uri = RestClient.post @@config[:services]["opentox-task"], nil
+ uri = RestClient.post @@config[:services]["opentox-task"], {}
Task.new(uri)
end
@@ -26,19 +26,6 @@ module OpenTox
task_uris = RestClient.get(@@config[:services]["opentox-task"]).split(/\n/)
task_uris.collect{|uri| Task.new(uri)}
end
-
- def started
- #LOGGER.info File.join(@uri,'started')
- RestClient.put File.join(@uri,'started'), {}
- end
-
- def cancel
- RestClient.put File.join(@uri,'cancelled'), {}
- end
-
- def completed(uri)
- RestClient.put File.join(@uri,'completed'), :resource => uri
- end
def created_at
RestClient.get File.join(@uri, 'created_at')
@@ -55,6 +42,26 @@ module OpenTox
def resource
RestClient.get File.join(@uri, 'resource')
end
+
+ def started
+ RestClient.put File.join(@uri,'started'), {}
+ end
+
+ def cancel
+ RestClient.put File.join(@uri,'cancelled'), {}
+ end
+
+ def failed
+ RestClient.put File.join(@uri,'failed'), {}
+ end
+
+ def parent=(task)
+ RestClient.put File.join(@uri,'parent'), {:uri => task.uri}
+ end
+
+ def completed(uri)
+ RestClient.put File.join(@uri,'completed'), :resource => uri
+ end
def pid=(pid)
RestClient.put File.join(@uri, 'pid'), :pid => pid
@@ -64,8 +71,12 @@ module OpenTox
self.status.to_s == 'completed'
end
+ def failed?
+ self.status.to_s == 'failed'
+ end
+
def wait_for_completion
- until self.completed?
+ until self.completed? or self.failed?
sleep 1
end
end
diff --git a/opentox-ruby-api-wrapper.gemspec b/opentox-ruby-api-wrapper.gemspec
index c8a0c1a..75f5d6b 100644
--- a/opentox-ruby-api-wrapper.gemspec
+++ b/opentox-ruby-api-wrapper.gemspec
@@ -26,6 +26,7 @@ Gem::Specification.new do |s|
"bin/yaml2owl.rb",
"lib/algorithm.rb",
"lib/compound.rb",
+ "lib/config/config_ru.rb",
"lib/config/database.rb",
"lib/dataset.rb",
"lib/environment.rb",