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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
# dataset.rb
# Loads libraries and webapps
# Author: Christoph Helma, Andreas Maunz
require 'roo'
require 'opentox-server'
require_relative 'helper.rb'
require_relative 'compound.rb'
# TODO: remove and find a better way to test task errors
require_relative 'test.rb'
# Library code
$logger.debug "Dataset booting: #{$dataset.collect{|k,v| "#{k}: '#{v}'"} }"
# Entry point
module OpenTox
class Application < Service
before "/#{SERVICE}/:id/:property" do
@uri = uri("/#{SERVICE}/#{params[:id]}")
end
# Create a new resource
post "/dataset/?" do
@uri = uri("/#{SERVICE}/#{SecureRandom.uuid}")
parse_put
end
head "/dataset/?" do
end
head '/dataset/:id/?' do
halt 404 unless FourStore.head(@uri.split('?').first)
end
get "/dataset/:id/?" do
case @accept
when "application/rdf+xml", "text/turtle", "text/plain", /html/
r = FourStore.get(@uri.split('?').first, @accept)
else
case @accept
when "text/csv"
r = to_csv
#when "application/vnd.ms-excel"
#to_spreadsheet Excel
#when "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
#to_xlsx
#when "application/vnd.oasis.opendocument.spreadsheet"
#to_spreadsheet Openoffice
#when "chemical/x-mdl-sdfile"
else
bad_request_error "'#{@accept}' is not a supported content type."
end
end
r
end
# Create or update a resource
put "/dataset/:id/?" do
parse_put
end
# Get metadata of the dataset
# @return [application/rdf+xml] Metadata OWL-DL
get '/dataset/:id/metadata' do
case @accept
#{ ?s ?p ?o. ?s <#{RDF.type}> <#{RDF::OT.Dataset}> .}
when "application/rdf+xml", "text/turtle", "text/plain"
sparql = "CONSTRUCT {?s ?p ?o.} FROM <#{@uri}> WHERE {
{ ?s <#{RDF.type}> <#{RDF::OT.Dataset}> ; ?p ?o}
UNION { ?s <#{RDF.type}> <#{RDF::OT.Parameter}> ; ?p ?o }
MINUS { <#{@uri}> <#{RDF::OT.dataEntry}> ?o. }
} "
FourStore.query sparql, @accept
else
bad_request_error "'#{@accept}' is not a supported content type."
end
end
# Get a list of all features
# @param [Header] Accept one of `application/rdf+xml, text/turtle, text/plain, text/uri-list` (default application/rdf+xml)
# @return [application/rdf+xml, text/turtle, text/plain, text/uri-list] Feature data
get '/dataset/:id/features' do
case @accept
when "application/rdf+xml", "text/turtle", "text/plain"
sparql = "CONSTRUCT {?s ?p ?o.} FROM <#{@uri}> WHERE {?s <#{RDF.type}> <#{RDF::OT.Feature}>; ?p ?o. }"
when "text/uri-list"
sparql = "SELECT DISTINCT ?s FROM <#{@uri}> WHERE {?s <#{RDF.type}> <#{RDF::OT.Feature}>. ?s <#{RDF::OLO.index}> ?idx } ORDER BY ?idx"
else
bad_request_error "'#{@accept}' is not a supported content type."
end
FourStore.query sparql, @accept
end
# Get a list of all compounds
# @param [Header] Accept one of `application/rdf+xml, text/turtle, text/plain, text/uri-list` (default application/rdf+xml)
# @return [application/rdf+xml, text/turtle, text/plain, text/uri-list] Compound data
get '/dataset/:id/compounds' do
case @accept
when "application/rdf+xml", "text/turtle", "text/plain"
sparql = "CONSTRUCT {?s ?p ?o.} FROM <#{@uri}> WHERE {?s <#{RDF.type}> <#{RDF::OT.Compound}>; ?p ?o. }"
when "text/uri-list"
sparql = "SELECT ?s FROM <#{@uri}> WHERE {?s <#{RDF.type}> <#{RDF::OT.Compound}>. ?s <#{RDF::OLO.index}> ?idx } ORDER BY ?idx"
else
bad_request_error "'#{@accept}' is not a supported content type."
end
FourStore.query sparql, @accept
end
end
end
|