aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPjotr Prins2023-07-22 11:41:24 +0200
committerPjotr Prins2023-07-22 11:41:24 +0200
commit9cd3e8a4729920794cd8c14be6f7bf280910378c (patch)
treefdb5eb6ae664fdc9f477f10b304b74d5d275c309
parent3349ce0a5817e7c3cbc9caf5db8b0ca45d984214 (diff)
downloadgenenetwork3-9cd3e8a4729920794cd8c14be6f7bf280910378c.tar.gz
This works
-rwxr-xr-xgn3-guile/web/webserver.scm35
1 files changed, 28 insertions, 7 deletions
diff --git a/gn3-guile/web/webserver.scm b/gn3-guile/web/webserver.scm
index 6451dc5..db9eb62 100755
--- a/gn3-guile/web/webserver.scm
+++ b/gn3-guile/web/webserver.scm
@@ -139,16 +139,30 @@ SELECT ?species ?p ?o WHERE {
(let* ([s (car r)]
[v (cdr (cdr r))]
[p (car (cdr r))]
- [nrec (sloppy-assoc s recs)]) ; find record to fill based on subject
- (if (nrec)
- (begin
- (set! nrec (assoc-set! nrec p v))
- (set! recs (assoc-set! recs s nrec)))
- (set! nrec (assoc-set! nrec s '())) ;; start with empty list
- )))
+ [nrec '()]
+ [kv (assoc s recs)]) ; find record to fill based on subject
+ (if (not kv)
+ (set! nrec '())
+ (set! nrec (cdr kv))
+ )
+ (set! nrec (assoc-set! nrec p v))
+ (set! recs (assoc-set! recs s nrec))
+ ))
rows)
recs)
+;; result should be a vector of list of pair
+(define (tojson recs)
+ (for-each (lambda (r)
+ (let ([k (car r)]
+ [v (cdr r)])
+ (display k)
+ (newline)
+ (display r)
+ (newline)
+ )) recs
+ ))
+
(define (get-species-api-str)
(scm->json-string #("https://genenetwork.org/api/v2/mouse/"
"https://genenetwork.org/api/v2/rat/")))
@@ -169,10 +183,17 @@ SELECT ?species ?p ?o WHERE {
(lambda (port)
(scm->json json port))))
+(define (render-json-string2 json)
+ (list '((content-type . (application/json)))
+ (lambda (port)
+ (display "ThthEST" port))))
+
(define (controller request body)
(match-lambda
(('GET)
(render-json info))
+ (('GET "meh")
+ (render-json-string2 "ITEST"))
(('GET "meta")
(render-json info-meta))
(('GET "version")