aboutsummaryrefslogtreecommitdiffstats
path: root/src/chameleon/aai_processor.clj
blob: 7025c31539feda959018cc9973fe24e1963b60ff (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
(ns chameleon.aai-processor
  (:require [chameleon.txform :refer :all]
            [chameleon.route :refer :all]
            [cheshire.core :refer :all]
            [clojure.set :refer :all]))

(defn- gen-trim-relationship
  "Generates a trimmed down version of the relationship containing only the id, type, url, and target"
  [relationship]
  (let [id (relationship"_id")
        type (get-in relationship ["properties" "type"])
        src-id (get-in relationship ["source" "id"])
        src-type (get-in relationship ["source" "type"])
        target-id (get-in relationship ["target" "id"])
        target-type (get-in relationship ["target" "type"])]
    {"id" id
     "type" type
     "source" {"id" src-id "type" src-type}
     "target" {"id" target-id "type" target-type}})
  )

(defn from-gallifrey
  "Transforms Gallifrey response payloads into a format consumable by AAI-centric clients"
  [body]
  (let [resource-type (get-in body ["properties" "_type"])
        id (body "_id")
        type (get-in body ["properties" "type"])
        properties (body "properties")
        entity-response {
                         "id" id
                         "type" type
                         "properties" (dissoc properties "_type" "type")
                         }]
    (if (= resource-type "entity")
                                        ; Transform into an entity type
      (let [relationships (body "relationships")]
        (assoc entity-response
               "in" (into [] (map gen-trim-relationship (filter #(= (get-in % ["target" "id"]) id) relationships)))
               "out" (into [] (map gen-trim-relationship (filter #(= (get-in % ["source" "id"]) id) relationships)))))
      entity-response)))

(defn from-spike
  "Transforms Spike-based event payloads to a format accepted by Gallifrey for vertices and relationships"
  [gallifrey-host payload]
  (let [txpayload (map-keywords (parse-string payload))
        operation (:operation txpayload)
        parse-type (if (contains? txpayload :vertex)
                     :vertex
                     :relationship)
        entity-type (if (contains? txpayload :vertex)
                      :entity
                      :relationship)
        entity (map-keywords (parse-type txpayload))
        key (:key entity)
        properties (assoc (:properties entity) :type (:type entity))
        truth-time (:truth-time entity)
        entity-assertion {:meta {:key key
                                 :operation operation
                                 :time {:t-t truth-time}}}]
    (assert-gallifrey gallifrey-host "aai" (name entity-type) (if (= entity-type :entity)
                                                                (assoc entity-assertion :body (generate-string {:properties properties}))
                                                                (assoc entity-assertion :body (generate-string (conj {:properties properties}
                                                                                                                     {:source  (rename-keys (:source entity) {"key" "id"})}
                                                                                                                     {:target (rename-keys (:target entity) {"key" "id"})})))))))