summaryrefslogtreecommitdiff
path: root/application.rb
blob: e0e469db1b281d1d0a68c36af36da14128b7b3f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# Java environment
ENV["JAVA_HOME"] = "/usr/lib/jvm/java-6-sun" unless ENV["JAVA_HOME"]
java_dir = File.join File.expand_path(File.dirname(__FILE__)),"public/java"
cdk = File.join java_dir, "cdk-1.3.5.jar"
jchempaint = File.join java_dir, "cdk-jchempaint-15.jar"
ENV["CLASSPATH"] = "#{ENV["CLASSPATH"]}:#{java_dir}:#{cdk}:#{jchempaint}"

require 'rubygems'
require 'rjb'
gem "opentox-ruby-api-wrapper", "= 1.6.0"
require 'opentox-ruby-api-wrapper'

post "/display" do
  content_type "image/png"
  attachment "#{params["smiles"]}.png"
  s = Rjb::import('Structure').new(params["smiles"],200)
  s.match_activating(params["smarts"])
  s.match_deactivating(["CC"])
  s.show
end

get %r{/smiles/(.+)/smarts/(.*)} do |smiles,smarts| 
  content_type "image/png"
  attachment "#{smiles}.png"
  s = Rjb::import('Structure').new(smiles,200)
  s.match(smarts)
  s.show
end

get %r{/smiles/(.+)} do |smiles| 
  content_type "image/png"
  attachment "#{smiles}.png"
  Rjb::import('Structure').new(smiles,200).show
end

get %r{/(.+)/image} do |inchi| # catches all remaining get requests
   smiles = OpenTox::Compound.new(:inchi => inchi).smiles
   content_type "image/png"
   attachment "#{smiles}.png"
   Rjb::import('Structure').new(smiles,200).show
end

get %r{/(.+)} do |inchi| # catches all remaining get requests
  inchi = URI.unescape request.env['REQUEST_URI'].sub(/^\//,'').sub(/.*compound\//,'') # hack to avoid sinatra's URI/CGI unescaping, splitting, ..."
  case request.env['HTTP_ACCEPT']
  when "*/*"
    response['Content-Type'] = "chemical/x-daylight-smiles"
    OpenTox::Compound.new(:inchi => inchi).smiles
  when "chemical/x-daylight-smiles"
    response['Content-Type'] = "chemical/x-daylight-smiles"
    OpenTox::Compound.new(:inchi => inchi).smiles
  when "chemical/x-inchi"
    response['Content-Type'] = "chemical/x-inchi"
    inchi 
  when "chemical/x-mdl-sdfile"
    response['Content-Type'] = "chemical/x-mdl-sdfile"
    OpenTox::Compound.new(:inchi => inchi).sdf
  when "image/gif"
    response['Content-Type'] = "image/gif"
    OpenTox::Compound.new(:inchi => inchi).gif
  when "image/png"
    response['Content-Type'] = "image/png"
    OpenTox::Compound.new(:inchi => inchi).png
  when "text/plain"
    response['Content-Type'] = "text/plain"
    uri = File.join @@cactus_uri,inchi,"names"
    RestClient.get(uri).body
  else
    halt 400, "Unsupported MIME type '#{request.env['HTTP_ACCEPT']}'"
  end
end

post '/?' do 

  input = request.env["rack.input"].read
  response['Content-Type'] = 'text/uri-list'
  begin
    case request.content_type
    when /chemical\/x-daylight-smiles/
      OpenTox::Compound.new(:smiles => input).uri + "\n"
    when /chemical\/x-inchi/
      OpenTox::Compound.new(:inchi => input).uri + "\n"
    when /chemical\/x-mdl-sdfile|chemical\/x-mdl-molfile/
      OpenTox::Compound.new(:sdf => input).uri + "\n"
    when /text\/plain/
      OpenTox::Compound.new(:name => input).uri + "\n"
    else
      status 400
      "Unsupported MIME type '#{request.content_type}'"
    end
  rescue
    status 400
    "Cannot process request '#{input}' for content type '#{request.content_type}'"
  end
end