Skip to content

Latest commit

 

History

History
195 lines (159 loc) · 3.2 KB

README.md

File metadata and controls

195 lines (159 loc) · 3.2 KB

FIWARE Meteoroid Demo

We demonstrated concept of Meteoroid

Why integration FIWARE Orion and OpenWhisk

When using FIWARE Orion, notification destination business logic may be required. We plan to make it easy to register business logic using a combination of FIWARE Orion and FaaS (Function as a Service).


Installation OpenWhisk

$ git clone https://github.com/apache/incubator-openwhisk-devtools.git
$ cd incubator-openwhisk-devtools/docker-compose
$ make quick-start

Installation CLI (Using Homebrew)

$ brew update
$ brew install wsk

Create fiware directory

$ mkdir fiware
$ cd fiware

Create Docker-Compose file for Orion

Create a new file called docker-compose.yml inside your directory with the following contents.

 mongo:
   image: mongo:3.6
   command: --nojournal
 orion:
   image: fiware/orion
   links:
     - mongo
   ports:
     - "1026:1026"
   command: -dbhost mongo

Deploy Orion

$ sudo docker-compose up

Create AirConditioner entity

$ curl localhost:1026/v2/entities -s -S -H 'Content-Type: application/json' -d @- <<EOF
{
  "id": "AirConditioner1",
  "type": "AirConditioner",
  "status": {
    "value": "OFF",
    "type": "string"
  }
}
EOF

Create Room entity

$ curl localhost:1026/v2/entities -s -S -H 'Content-Type: application/json' -d @- <<EOF
{
  "id": "Room1",
  "type": "Room",
  "temperature": {
    "value": 20,
    "type": "float"
  }
}
EOF

Clone action script using git

$ git clone https://github.com/OkinawaOpenLaboratory/fiware-meteoroid-demo.git
$ cd fiware-meteoroid-demo

Create action

Set orion_endpoint and threshold as a parameter

$ wsk -i action create switchAC switch_ac.py --param orion_endpoint http://xxx.xxx.xxx.xxx:1026 --param threshold 30

Update action

$ wsk -i action update "/_/switchAC" --web true

Create api

Get api endpoint.

$ wsk -i api create /switchAC post switchAC --response-type json

Create subscription

$ curl -v localhost:1026/v2/subscriptions -s -S -H 'Content-Type: application/json' -d @- <<EOF
{
  "description": "A subscription to get info about Room1",
  "subject": {
    "entities": [
      {
        "id": "Room1",
        "type": "Room"
      }
    ],
    "condition": {
      "attrs": [
        "temperature"
      ]
    }
  },
  "notification": {
    "http": {
      "url": "http://xxxxxxxxx:9090/api/xxxxxxxxxxxxxxx/switchAC"
    },
    "attrs": [
      "temperature"
    ]
  },
  "expires": "2040-01-01T14:00:00.00Z",
  "throttling": 5
}
EOF

Update temperature of Room1

$ curl -v localhost:1026/v2/op/update -s -S -H 'Content-Type: application/json' -d @- <<EOF
{
  "actionType": "update",
  "entities": [
    {
      "type": "Room",
      "id": "Room1",
      "temperature": {
        "value": 40,
        "type": "float"
      }
    }
  ]
}
EOF

Make sure state of AirConditioner1

$ curl -v  localhost:1026/v2/entities/ | jq
[
  {
    "id": "AirConditioner1",
    "type": "AirConditioner",
    "status": {
      "type": "string",
      "value": "ON",
      "metadata": {}
    }
  },
  {
    "id": "Room1",
    "type": "Room",
    "temperature": {
      "type": "float",
      "value": 40,
      "metadata": {}
    }
  }
]