SlideShare a Scribd company logo
1 of 41
Building your own IoT platform
using FIWARE GEis
José Manuel Cantera Fonseca
Technological Expert. Data Chapter.
josemanuel.canterafonseca@telefonica.com
Introduction
Talk Objectives
Illustrate how a secured IoT platform instance can be
implemented using FIWARE GEis on a container-based
environment (Docker)
Understand how to set up a security layer on top of a Context
Broker
Learn how to configure all the components at the different
layers
TargetArchitectureusingfiware
securitystack
Context Broker
(Orion)
mongoDB
Application
(Data Consumer)
Identity
Manager
(Keystone)
Authorization
PDP
(Keypass)
PEP
Proxy
(Steelskin)
Token
validation
(domain,
project,
role)
Is authorized?
Allow
or Deny
NGSIv2
Registration
App
NGSIv2
Add user
Domain, Project,
Roles
Token
Developer
Data
ingestionGet token
Internet / VPN
IoT platform
Infrastructure
I9 I8
IoT Devices
Open Data
Sources
Getting started
A basic context broker set up
4
BasicData&Controlbrokersetup
Data & Control
Broker
(Orion)
mongoDB
Application
(Data Consumer)
NGSIv2NGSIv2
Data
ingestion
Internet / VPN
Operator
Infrastructure
I8
IoT Devices
Open Data
Sources
Step1.-MongoDB(I)
mongoDB is the NoSQL database used to store context data
mongoDB is properly packaged as a docker container
Use mongoDB 3.2 docker container
Prepare a folder to store mongoDB data
Ex. $HOME/data/mongo
Run mongoDB
$ docker run --name mongo -v $HOME/data/mongo:/data/db -d
-h mongo -p 27017:27017 mongo:3.2
Step1.-mongoDB(II)
$ docker ps -a to list running containers
aa075751485b mongo:3.2 "/entrypoint.sh mongo" 5
seconds ago Up 4 seconds 0.0.0.0:27017->27017/tcp
mongo
run mongo client application to check everything is ok
You might need to install it
https://docs.mongodb.com/v3.2/tutorial/install-mongodb-on-ubuntu/
$ apt-get install mongodb-org-shell
$ mongo> show dbs
Or you can directly connect to the container
Step2.-Orioncontextbroker(I)
Orion is
an implementation of the “Data and Context Broker”
An open source project hosted by the FIWARE OSS
https://github.com/fiware/context.Orion (License Affero GPL v3.0)
properly packaged as a docker container running on CentOS 6
Orion uses mongoDB as the data storage
For running Orion …
$ docker run --name orion -d -p 1026:1026 --link mongo -h orion fiware/orion:1.4.1 -dbhost
mongo
$ docker ps -a
STEP2.-OrionContextbroker(II)
$ curl -s localhost:1026/version | python -mjson.tool
{
"orion" : {
"version" : "1.4.1",
"uptime" : "0 d, 0 h, 1 m, 17 s",
"git_hash" : "905d5fa58ace7fa4f14330ddc982b41cf9b30be6",
"compile_time" : "Mon Oct 10 15:06:02 UTC 2016",
"compiled_by" : "root",
"compiled_in" : "b99744612d0b"
}
}
$ mongo > show dbs > use orion
Now a DB named “orion” should appear if everything is ok
db.getCollectionNames()
[ "entities" ]
curl -s localhost:1026/v2/entities | python -mjson.tool
Step3.-Let’saddsomeentitiestoorion(I)
$ curl localhost:1026/v2/entities -s -S --header 'Content-Type: application/json' -d @- <<EOF
{
"id": "WeatherObserved-6789",
"type": "WeatherObserved",
"temperature": {
"value": 23,
"type": "Number"
},
"barometricPressure": {
"value": 720,
"type": "Number"
},
"dateObserved": {
"value": "2016-10-18T11:08:20.228Z",
"type": "DateTime"
},
"source": {
"value": "http://www.aemet.es",
"type": "URL"
}
}
EOF
Step3.-Let’saddsomeentitiestoorion(II)
$ curl localhost:1026/v2/entities?options=keyValues | python -mjson.tool
[
{
"barometricPressure": 720,
"dateObserved": "2016-10-18T11:08:20.00Z",
"id": "WeatherObserved-6789",
"source": "http://www.aemet.es",
"temperature": 23,
"type": "WeatherObserved"
}
]
$ mongo
> use orion
switched to db orion
> db.entities.find({})
{ "_id" : { "id" : "WeatherObserved-6789", "type" : "WeatherObserved", "servicePath" : "/" }, "attrNames" : [
"temperature", "barometricPressure", "dateObserved", "source" ], "attrs" : { "temperature" : { "type" :
"Number", "creDate" : 1476789680, "modDate" : 1476789680, "value" : 23, "mdNames" : [ ] },
"barometricPressure" : { "type" : "Number", "creDate" : 1476789680, "modDate" : 1476789680, "value" : 720,
"mdNames" : [ ] }, "dateObserved" : { "type" : "DateTime", "creDate" : 1476789680, "modDate" : 1476789680,
"value" : 1476788900, "mdNames" : [ ] }, "source" : { "type" : "URL", "creDate" : 1476789680, "modDate" :
1476789680, "value" : "http://www.aemet.es", "mdNames" : [ ] } }, "creDate" : 1476789680, "modDate" :
1476789680 }
Step4.-Multitenancy (I)
Orion Context Broker is multitenant
Logical databases isolated, each one containing data from
different organizations or domains
Tenant is a “service” in FIWARE terminology.
Aka a “Domain” in OpenStack terminology
A tenant can be composed by multiple child sub-
tenants
“subservice” in FIWARE terminology
Aka a “Project” in OpenStack terminology
Step4.-Multitenancy (II)
The way to address tenants are HTTP headers
Fiware-Service : <<Tenant_Name>>
Fiware-Servicepath: <<Subservice_Name>>
Subtenants follow a hierarchical structure and there is
a default subtenant, root one (‘/’)
Example:
Fiware-service: weather
Fiware-servicepath: /Spain
A pair (service, subservice) is used for security
Step4.-Multitenancy (III)
TENANT="Fiware-Service:$1"
SUBSERVICE="Fiware-ServicePath:/$2"
curl localhost:1026/v2/entities --header $TENANT --header $SUBSERVICE -s -S --header
'Content-Type: application/json' -d @- <<EOF
{
"id": "WeatherObserved-6789",
"type": "WeatherObserved",
"temperature": {
"value": 23,
"type": "Number"
},
……
}
EOF
● Creating an entity in a (tenant , subtenant)
Step4.-Multitenancy (IV)
$mongo
> show dbs
local 0.000GB
orion 0.000GB
orion-example_a 0.000GB
orion-london 0.000GB
orion-weather 0.000GB
There will be as many databases as tenants available
“orion” is the DB which stores data in the default tenant
DB name is “orion-” + <<tenant_name>>
To query data of a tenant just issue regular NGSIv2 requests using Fiware-Service and
Fiware-Servicepath headers
Deeping dive
Adding a security layer to the data & control broker
16
TargetArchitectureusingfiwaresecuritystack
Data &
Control Broker
(Orion)
mongoDB
Application
(Data Consumer)
Identity
Manager
(Keystone)
Authorization
PDP
(Keypass)
PEP
Proxy
(Steelskin)
Token
validation
(domain,
project,
role)
Is authorized?
Allow
or Deny
NGSIv2
Registration
App
NGSIv2
Add user
Domain, Project,
Roles
Token
Developer
Data
ingestionGet token
Internet / VPN
Operator
Infrastructure
I9 I8
IoT Devices
Open Data
Sources
Step4.-Securitystack-preparation
Security stack uses MySQL to store configuration data
$ docker run --name mysql -d -p 3306:3306 -h mysql -v $HOME/data/mysql:/var/lib/mysql -e
"MYSQL_ROOT_PASSWORD=gsma" -e "MYSQL_DATABASE=keypass" -e "MYSQL_USER=keypass" -e
"MYSQL_PASSWORD=keypass" mysql:5.5
Check that everything is ok. Above command creates a database named “keypass” used later.
$ docker exec -it mysql bash
mysql --user=root --password=gsma
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| keypass |
| mysql |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)
Step4.1.-keystone(I)
Keystone is an open source project hosted by OpenStack OSS
Community
https://github.com/openstack/keystone
(Apache 2.0 license)
Keystone is an Identity Manager service capable of storing
information about domains, project, users, groups or
roles
Keystone is in charge of generating tokens which can be
used to get access to services requiring credentials
For this exercise we will be using a keystone image
Step4.1.-keystone(II)
Running keystone
$ docker run --name keystone -d -p 5001:5001 --link mysql -h keystone
telefonicaiot/fiware-keystone-spassword -dbhost mysql -default_pwd 4pass1w0rd -mysql_pwd
gsma
Sanity check operations
$ docker logs keystone
$ docker exec -it keystone bash (to open a shell session on the container)
$ curl -s -S http://localhost:5001/v3 | python -mjson.tool
Once we have a keystone instance up and running different REST requests can
be issued
http://developer.openstack.org/api-ref/identity/v3/index.html
$ docker exec -it mysql bash
root@mysql:/# mysql --user=root --password=gsma
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| keypass |
| keystone |
| mysql |
| performance_schema |
+--------------------+
mysql> use keystone;
Step4.1.-keystone(II-B)
show tables;
+-----------------------+
| Tables_in_keystone |
+-----------------------+
| assignment |
| credential |
| domain |
| endpoint |
| group |
| migrate_version |
| policy |
| project |
| region |
| role |
| service |
| spassword |
| token |
| trust |
| trust_role |
| user |
| user_group_membership |
+-----------------------+
Checking keystone has created its database properly
Step4.1.-keystone(III)
Remember:
Fiware-Service → Domain in Keystone
Fiware-Servicepath → Project in Keystone
A developer will register in Keystone as user in a domain
<-> Developer can get access to the data offered by the
corresponding FIWARE service (tenant)
We will later show how this works in practice
Step4.1.-keystone(IV)
List all domains
curl -s -S --header x-auth-token:4pass1w0rd http://localhost:5001/v3/domains/ | python -
mjson.tool
{
"domains": [
{
"enabled": true,
"id": "8b883aaa740e4d75b91095eaa550b35c",
"links": {
"self": "http://localhost:5001/v3/domains/8b883aaa740e4d75b91095eaa550b35c"
},
"name": "admin_domain"
},
{
"description": "Owns users and tenants (i.e. projects) available on Identity API v2.",
"enabled": true,
"id": "default",
"links": {
"self": "http://localhost:5001/v3/domains/default"
},
"name": "Default"
}
]
Step4.1.-keystone(V)
List all users
curl -s -S --header x-auth-token:4pass1w0rd http://localhost:5001/v3/users/ | python -
mjson.tool
"users": [
{
"description": "Cloud service",
"domain_id": "8b883aaa740e4d75b91095eaa550b35c",
"enabled": true,
"id": "02cd3dbb6ceb48eb92588c7885bbcc1f",
"links": {
"self": "http://localhost:5001/v3/users/02cd3dbb6ceb48eb92588c7885bbcc1f"
},
"name": "pep"
},
{
"description": "Cloud administrator",
"domain_id": "8b883aaa740e4d75b91095eaa550b35c",
"enabled": true,
"id": "177cf5a4d12e4f85b7b65cbcac6d9697",
"links": {
"self": "http://localhost:5001/v3/users/177cf5a4d12e4f85b7b65cbcac6d9697"
},
"name": "cloud_admin"
}
Step4.1.-keystone(VI)
Get a token for the cloud_admin user
curl localhost:5001/v3/auth/tokens -s -S --header 'Content-Type: application/json' -d @- <<EOF
{ "auth": {
"identity": {
"methods": ["password"],
"password": {
"user": {
"name": "cloud_admin",
"domain": { "name": "admin_domain" },
"password": "4pass1w0rd"
}
}
}
}
}
EOF
HTTP/1.1 201 Created
X-Subject-Token: 19e200834a3f4e149c7f4033a003a8f4
Step4.2.-keypass.-authPDP(I)
keypass is an implementation of the FIWARE Authorization
PDP (Policy Decision Point)
Keypass is an open source project hosted at
https://github.com/telefonicaid/fiware-keypass
License is Apache 2.0
It complies with XACML (eXtensible Access Control Markup
Language) v3.0.
It provides an API to get authorization decisions based on
authorization policies
Step4.2.-keypass.-AuthPDP(II)
Running keypass
$ docker run --name keypass -d -p 7070:7070 -h keypass --link mysql telefonicaiot/fiware-
keypass -dbhost mysql
$ docker logs keypass
$ curl --header 'Fiware-Service: dummy' localhost:7070/version
1.2.1
Step4.3.-Steelskin.-PEPproxy (I)
Steelskin is an implementation of the FIWARE PEP (Policy
Enforcement Point)
Steelskin is an open source project hosted at
https://github.com/telefonicaid/fiware-pep-steelskin
License is Affero GPL 3.0
A proxy which ensures that only authorized users are able
to perform requests against the Data & Control Broker
https://github.com/telefonicaid/fiware-pep-steelskin#-rules-to-determine-the-
context-broker-action-from-the-request
Step4.3.-Steelskin.-PEPproxy (II)
Running:
$ docker run -d --name pep -p 1027:1026 --link orion --link keystone --link keypass -e
LOG_LEVEL=DEBUG -e AUTHENTICATION_HOST=keystone -e AUTHENTICATION_PORT=5001 -e ACCESS_HOST=keypass
-e ACCESS_PORT=7070 -e TARGET_HOST=orion -e TARGET_PORT=1026 -e PROXY_USERNAME=pep -e
PROXY_PASSWORD=4pass1w0rd telefonicaiot/fiware-pep-steelskin
$ docker logs pep
$ docker exec -it pep bash → $ curl localhost:11211/version
{ "version": "1.2.0-next", "port":1026 }
Step4.3.-Steelskin.-PEPproxy(III)
Remember: Given an HTTP Request (x-auth-token, fiware-
service, fiware-servicepath)
First PEP queries keystone to validate the auth token and obtain (user,
domain, role in project)
Then, PEP queries keypass to obtain the authorization policies for the
role in question
A match between subject policies and the requested operation is done
If the requested operation is allowed, the HTTP request is forwarded to
the Data & Control Broker
If not a non-authorized error is raised
curl localhost:1027/v2/entities
STEP5.-Usingthemalltogether
$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED
STATUS PORTS NAMES
d18f7dbe7f75 telefonicaiot/fiware-pep-steelskin "/bin/sh -c bin/pepPr" 16 minutes ago
Up 16 minutes 11211/tcp, 0.0.0.0:1027->1026/tcp pep
7e1853f0e2c4 telefonicaiot/fiware-keypass "/opt/keypass/keypass" 45 minutes ago
Up 45 minutes 0.0.0.0:7070-7071->7070-7071/tcp keypass
c4f6ab6c390f telefonicaiot/fiware-keystone-spassword "/opt/keystone/keysto" About an hour
ago Up About an hour 0.0.0.0:5001->5001/tcp keystone
5bf5d7e8b284 mysql:5.5 "docker-entrypoint.sh" 18 hours ago
Up 18 hours 0.0.0.0:3307->3306/tcp mysql
6c63cee20ae2 fiware/orion:1.4.1 "/usr/bin/contextBrok" 24 hours ago
Up 24 hours 0.0.0.0:1026->1026/tcp orion
4f1d9298fb70 mongo:3.2 "/entrypoint.sh mongo" 24 hours ago
Up 24 hours 0.0.0.0:27017->27017/tcp mongo
Step5.1.-Orchestratortotherescue
Manual provision of configurations of the three security
components can be cumbersome
TEF has developed an open source project (named orchestrator)
that helps to provide security configurations
https://github.com/telefonicaid/orchestrator
License is Affero GPL 3.0
It can be instantiated as a service but there are some useful
scripts which can be used
https://github.com/telefonicaid/orchestrator/blob/master/SCRIPTS.md
Step5.2.-configuringaservice(tenant)
$ git clone https://github.com/telefonicaid/orchestrator
$ cd orchestrator
$ pip install -r requirements.txt
$ export PYTHONPATH=$PYTHONPATH:$HOME/gsma/orchestrator/src
cd $HOME/gsma/orchestrator/src
./orchestrator/commands/createNewService.py http localhost 5001 admin_domain cloud_admin
4pass1w0rd weatherdata "Weather Data" weather_admin weather_admin_PWD http localhost 7070
Checking that everything went ok
./orchestrator/commands/printServices.py http localhost 5001 admin_domain cloud_admin
4pass1w0rd
Step5.3.-configuringaSub-service
$ export PYTHONPATH=$PYTHONPATH:$HOME/gsma/orchestrator/src
cd $HOME/gsma/orchestrator/src
./orchestrator/commands/createNewSubService.py http localhost 5001 weatherdata
weather_admin weather_admin_PWD "Spain" "Weather in Spain"
Checking that everything went ok
./orchestrator/commands/printSubServices.py http localhost 5001 weatherdata weather_admin
weather_admin_PWD
Now we have a pair (Fiware-Service, Fiware-Servicepath) → (‘weatherdata’, ‘/Spain`)
We can check that we can get access to data
1/ obtain a token for the `weather_admin’ user Ex. `5bb5c6e310814b93a01d74385fe52bef`
2/ issue a GET request through the PEP proxy
curl localhost:1027/v2/entities --header 'Fiware-Service:weatherdata' --header 'Fiware-Servicepath:
Step5.4.-addingadeveloperwithconsumerpermissions
$ ./orchestrator/commands/createNewServiceUser.py http localhost 5001 weatherdata
weather_admin weather_admin_PWD developer1 developer1_PWD
Checking that everything went ok
./orchestrator/commands/printServiceUsers.py http localhost 5001 weatherdata weather_admin
weather_admin_PWD
Now we need to assign the role “SubServiceCustomer” to the user ‘developer1’
./orchestrator/commands/assignRoleSubServiceUser.py http localhost 5001 weatherdata Spain
weather_admin weather_admin_PWD SubServiceCustomer developer1
Checking that everything went ok
./orchestrator/commands/listSubServiceRoleAssignments.py http localhost 5001 weatherdata
weather_admin weather_admin_PWD Spain True
Now ‘developer1’ is able to query weather data on the sub-service ‘Spain’. However he cannot provide data as his role
is ‘SubServiceCustomer’
Step5.5.-gettingaccesstodatawith‘developer1’ (I)
First of all a token must be obtained . Then :
$ curl -s -S localhost:1027/v2/entities --header 'Fiware-service:weatherdata' --header
'Fiware-servicepath:/Spain' --header 'x-auth-token:36a1d0558612473da438c93d74d4aefc' |
python -mjson.tool
[
{
"barometricPressure": {
"metadata": {},
"type": "Number",
"value": 720
},
"dateObserved": {
"metadata": {},
"type": "DateTime",
"value": "2016-10-18T11:08:20.00Z"
},
"id": "WeatherObserved-6789",
"type": "WeatherObserved"
}
]
Step5.5.-gettingaccesstodatawith‘developer1’ (II)
An attempt to create a new entity on (weatherdata,/Spain) will fail
curl localhost:1027/v2/entities -s -S --header 'Content-Type: application/json' --header 'Fiware-
Service:weatherdata' 
--header 'Fiware-servicepath:/Spain' --header 'x-auth-token:36a1d0558612473da438c93d74d4aefc' -d @- <<EOF
{
"id": "WeatherObserved-4567",
….
}
EOF
{
"name": "ACCESS_DENIED",
"message": "The user does not have the appropriate permissions to access the selected action"
}
Developer will need to be assigned the role ‘SubServiceAdmin’ in order to be able to post new data
What’shappeningbehindthescenes
A set of predefined policies have been pre-populated to the ‘keypass’ database
docker exec -it mysql mysql --user=keypass --password=keypass
mysql> use keypass; select policy from Policies;
Relevant policies are
https://github.com/telefonicaid/orchestrator/blob/master/src/orchestrator/core
/policies/policy-orion-customer.xml
https://github.com/telefonicaid/orchestrator/blob/master/src/orchestrator/core
/policies/policy-orion-admin.xml
Andfinally...
Remember to remove old docker containers (exited)
$ docker rm <container>
You should only expose the IdM (for tokens) and the PEP
Proxy (ports) to the developer
Ensure the mounted volumes for database data have enough
space for the data to be stored
Remember, you can open a shell session on a container
$ docker exec -it <<container_name> bash
And then get access to the logs, databases, local services, ….
Questions
40
Thank you!
http://fiware.org
Follow @FIWARE on Twitter

More Related Content

What's hot

Fiware IoT_IDAS_intro_ul20_v2
Fiware IoT_IDAS_intro_ul20_v2Fiware IoT_IDAS_intro_ul20_v2
Fiware IoT_IDAS_intro_ul20_v2FIWARE
 
FIWARE NGSI: Managing Context Information at Large Scale
FIWARE NGSI: Managing Context Information at Large ScaleFIWARE NGSI: Managing Context Information at Large Scale
FIWARE NGSI: Managing Context Information at Large ScaleFIWARE
 
Session 5 - NGSI-LD Advanced Operations | Train the Trainers Program
Session 5 -  NGSI-LD Advanced Operations | Train the Trainers ProgramSession 5 -  NGSI-LD Advanced Operations | Train the Trainers Program
Session 5 - NGSI-LD Advanced Operations | Train the Trainers ProgramFIWARE
 
FIWARE Training: JSON-LD and NGSI-LD
FIWARE Training: JSON-LD and NGSI-LDFIWARE Training: JSON-LD and NGSI-LD
FIWARE Training: JSON-LD and NGSI-LDFIWARE
 
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...FIWARE
 
FIWARE Wednesday Webinars - FIWARE Overview
FIWARE Wednesday Webinars - FIWARE OverviewFIWARE Wednesday Webinars - FIWARE Overview
FIWARE Wednesday Webinars - FIWARE OverviewFIWARE
 
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...FIWARE
 
Flink powered stream processing platform at Pinterest
Flink powered stream processing platform at PinterestFlink powered stream processing platform at Pinterest
Flink powered stream processing platform at PinterestFlink Forward
 
OpenId Connect Protocol
OpenId Connect ProtocolOpenId Connect Protocol
OpenId Connect ProtocolMichael Furman
 
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...Flink Forward
 
Creating a Context-Aware solution, Complex Event Processing with FIWARE Perseo
Creating a Context-Aware solution, Complex Event Processing with FIWARE PerseoCreating a Context-Aware solution, Complex Event Processing with FIWARE Perseo
Creating a Context-Aware solution, Complex Event Processing with FIWARE PerseoFernando Lopez Aguilar
 
Using the New Apache Flink Kubernetes Operator in a Production Deployment
Using the New Apache Flink Kubernetes Operator in a Production DeploymentUsing the New Apache Flink Kubernetes Operator in a Production Deployment
Using the New Apache Flink Kubernetes Operator in a Production DeploymentFlink Forward
 
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTs
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTsFIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTs
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTsFIWARE
 
Integrating microservices with apache camel on kubernetes
Integrating microservices with apache camel on kubernetesIntegrating microservices with apache camel on kubernetes
Integrating microservices with apache camel on kubernetesClaus Ibsen
 
Data persistency (draco, cygnus, sth comet, quantum leap)
Data persistency (draco, cygnus, sth comet, quantum leap)Data persistency (draco, cygnus, sth comet, quantum leap)
Data persistency (draco, cygnus, sth comet, quantum leap)Fernando Lopez Aguilar
 
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다Arawn Park
 
ML Infrastracture @ Dropbox
ML Infrastracture @ Dropbox ML Infrastracture @ Dropbox
ML Infrastracture @ Dropbox Tsahi Glik
 
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...Fermin Galan
 
FIWARE Tech Summit - FIWARE Cygnus and STH-Comet
FIWARE Tech Summit - FIWARE Cygnus and STH-CometFIWARE Tech Summit - FIWARE Cygnus and STH-Comet
FIWARE Tech Summit - FIWARE Cygnus and STH-CometFIWARE
 

What's hot (20)

Fiware IoT_IDAS_intro_ul20_v2
Fiware IoT_IDAS_intro_ul20_v2Fiware IoT_IDAS_intro_ul20_v2
Fiware IoT_IDAS_intro_ul20_v2
 
FIWARE NGSI: Managing Context Information at Large Scale
FIWARE NGSI: Managing Context Information at Large ScaleFIWARE NGSI: Managing Context Information at Large Scale
FIWARE NGSI: Managing Context Information at Large Scale
 
Session 5 - NGSI-LD Advanced Operations | Train the Trainers Program
Session 5 -  NGSI-LD Advanced Operations | Train the Trainers ProgramSession 5 -  NGSI-LD Advanced Operations | Train the Trainers Program
Session 5 - NGSI-LD Advanced Operations | Train the Trainers Program
 
FIWARE Training: JSON-LD and NGSI-LD
FIWARE Training: JSON-LD and NGSI-LDFIWARE Training: JSON-LD and NGSI-LD
FIWARE Training: JSON-LD and NGSI-LD
 
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...
FIWARE Global Summit - The Scorpio NGSI-LD Broker: Features and Supported Arc...
 
FIWARE Wednesday Webinars - FIWARE Overview
FIWARE Wednesday Webinars - FIWARE OverviewFIWARE Wednesday Webinars - FIWARE Overview
FIWARE Wednesday Webinars - FIWARE Overview
 
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...
FIWARE Wednesday Webinars - Performing Big Data Analysis Using Cosmos With Sp...
 
Flink powered stream processing platform at Pinterest
Flink powered stream processing platform at PinterestFlink powered stream processing platform at Pinterest
Flink powered stream processing platform at Pinterest
 
OpenId Connect Protocol
OpenId Connect ProtocolOpenId Connect Protocol
OpenId Connect Protocol
 
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...
Squirreling Away $640 Billion: How Stripe Leverages Flink for Change Data Cap...
 
Creating a Context-Aware solution, Complex Event Processing with FIWARE Perseo
Creating a Context-Aware solution, Complex Event Processing with FIWARE PerseoCreating a Context-Aware solution, Complex Event Processing with FIWARE Perseo
Creating a Context-Aware solution, Complex Event Processing with FIWARE Perseo
 
Using the New Apache Flink Kubernetes Operator in a Production Deployment
Using the New Apache Flink Kubernetes Operator in a Production DeploymentUsing the New Apache Flink Kubernetes Operator in a Production Deployment
Using the New Apache Flink Kubernetes Operator in a Production Deployment
 
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTs
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTsFIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTs
FIWARE Wednesday Webinars - Integrating FIWARE with Blockchain/DLTs
 
Integrating microservices with apache camel on kubernetes
Integrating microservices with apache camel on kubernetesIntegrating microservices with apache camel on kubernetes
Integrating microservices with apache camel on kubernetes
 
Data persistency (draco, cygnus, sth comet, quantum leap)
Data persistency (draco, cygnus, sth comet, quantum leap)Data persistency (draco, cygnus, sth comet, quantum leap)
Data persistency (draco, cygnus, sth comet, quantum leap)
 
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다
잘 키운 모노리스 하나 열 마이크로서비스 안 부럽다
 
ML Infrastracture @ Dropbox
ML Infrastracture @ Dropbox ML Infrastracture @ Dropbox
ML Infrastracture @ Dropbox
 
FIWARE Generic Enablers introduction
FIWARE Generic Enablers introductionFIWARE Generic Enablers introduction
FIWARE Generic Enablers introduction
 
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...
Orion Context Broker NGSI-v2 Overview for Developers That Already Know NGSI-v...
 
FIWARE Tech Summit - FIWARE Cygnus and STH-Comet
FIWARE Tech Summit - FIWARE Cygnus and STH-CometFIWARE Tech Summit - FIWARE Cygnus and STH-Comet
FIWARE Tech Summit - FIWARE Cygnus and STH-Comet
 

Viewers also liked

Welcome to the 1st FIWARE Summit
Welcome to the 1st FIWARE SummitWelcome to the 1st FIWARE Summit
Welcome to the 1st FIWARE SummitFIWARE
 
How to Contribute to FIWARE
How to Contribute to FIWAREHow to Contribute to FIWARE
How to Contribute to FIWAREFIWARE
 
What, Why and What for FIWARE?
What, Why and What for FIWARE?What, Why and What for FIWARE?
What, Why and What for FIWARE?forumvirium
 
An introduction to the IoTC
An introduction to the IoTCAn introduction to the IoTC
An introduction to the IoTCNewell Thompson
 
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece symbiote-h2020
 
IoT Platforms Interoperability and the symbIoTe Vision
IoT Platforms Interoperability and the symbIoTe VisionIoT Platforms Interoperability and the symbIoTe Vision
IoT Platforms Interoperability and the symbIoTe Visionsymbiote-h2020
 
Semantic Interoperability as Key to IoT Platform Federation
Semantic Interoperability as Key to IoT Platform FederationSemantic Interoperability as Key to IoT Platform Federation
Semantic Interoperability as Key to IoT Platform Federationsymbiote-h2020
 
IoT on the Edge
IoT on the EdgeIoT on the Edge
IoT on the EdgeFIWARE
 
Interoperability with Standardless IoT (Global IoT Day Wien)
Interoperability with Standardless IoT (Global IoT Day Wien)Interoperability with Standardless IoT (Global IoT Day Wien)
Interoperability with Standardless IoT (Global IoT Day Wien)David Janes
 
Spanish AgriFood Cooperatives
Spanish AgriFood CooperativesSpanish AgriFood Cooperatives
Spanish AgriFood CooperativesFIWARE
 
IoT Platform Meetup - Oracle
IoT Platform Meetup - OracleIoT Platform Meetup - Oracle
IoT Platform Meetup - OracleFilip Kolář
 
FIWARE: the best is yet to come
FIWARE: the best is yet to comeFIWARE: the best is yet to come
FIWARE: the best is yet to comeFIWARE
 
The Future of IoT: Why We Need the Open Interconnect Consortium
The Future of IoT: Why We Need the Open Interconnect ConsortiumThe Future of IoT: Why We Need the Open Interconnect Consortium
The Future of IoT: Why We Need the Open Interconnect ConsortiumSamsung Open Source Group
 
Oies_IoT_Platform_Selection_Services_2017
Oies_IoT_Platform_Selection_Services_2017Oies_IoT_Platform_Selection_Services_2017
Oies_IoT_Platform_Selection_Services_2017Francisco Maroto
 
The FIWARE Marketplace
The FIWARE MarketplaceThe FIWARE Marketplace
The FIWARE MarketplaceFIWARE
 
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT Platform
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT PlatformCreating end-to-end IoT applications with Eclipse Kura & Solair IoT Platform
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT PlatformSolair
 
IoT World Forum Press Conference - 10.14.2014
IoT World Forum Press Conference - 10.14.2014IoT World Forum Press Conference - 10.14.2014
IoT World Forum Press Conference - 10.14.2014Bessie Wang
 

Viewers also liked (20)

Welcome to the 1st FIWARE Summit
Welcome to the 1st FIWARE SummitWelcome to the 1st FIWARE Summit
Welcome to the 1st FIWARE Summit
 
How to Contribute to FIWARE
How to Contribute to FIWAREHow to Contribute to FIWARE
How to Contribute to FIWARE
 
What, Why and What for FIWARE?
What, Why and What for FIWARE?What, Why and What for FIWARE?
What, Why and What for FIWARE?
 
An introduction to the IoTC
An introduction to the IoTCAn introduction to the IoTC
An introduction to the IoTC
 
X-GSN in OpenIoT SummerSchool
X-GSN in OpenIoT SummerSchoolX-GSN in OpenIoT SummerSchool
X-GSN in OpenIoT SummerSchool
 
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece
symbIoTe - AIOTI Open Day @ NDC, 08 Feb 2016, Athens, Greece
 
IoT Platforms Interoperability and the symbIoTe Vision
IoT Platforms Interoperability and the symbIoTe VisionIoT Platforms Interoperability and the symbIoTe Vision
IoT Platforms Interoperability and the symbIoTe Vision
 
Semantic Interoperability as Key to IoT Platform Federation
Semantic Interoperability as Key to IoT Platform FederationSemantic Interoperability as Key to IoT Platform Federation
Semantic Interoperability as Key to IoT Platform Federation
 
IoT on the Edge
IoT on the EdgeIoT on the Edge
IoT on the Edge
 
Interoperability with Standardless IoT (Global IoT Day Wien)
Interoperability with Standardless IoT (Global IoT Day Wien)Interoperability with Standardless IoT (Global IoT Day Wien)
Interoperability with Standardless IoT (Global IoT Day Wien)
 
Spanish AgriFood Cooperatives
Spanish AgriFood CooperativesSpanish AgriFood Cooperatives
Spanish AgriFood Cooperatives
 
IoT Platform Meetup - Oracle
IoT Platform Meetup - OracleIoT Platform Meetup - Oracle
IoT Platform Meetup - Oracle
 
FIWARE: the best is yet to come
FIWARE: the best is yet to comeFIWARE: the best is yet to come
FIWARE: the best is yet to come
 
The Future of IoT: Why We Need the Open Interconnect Consortium
The Future of IoT: Why We Need the Open Interconnect ConsortiumThe Future of IoT: Why We Need the Open Interconnect Consortium
The Future of IoT: Why We Need the Open Interconnect Consortium
 
Introduction to FIWARE Open Ecosystem
Introduction to FIWARE Open EcosystemIntroduction to FIWARE Open Ecosystem
Introduction to FIWARE Open Ecosystem
 
Oies_IoT_Platform_Selection_Services_2017
Oies_IoT_Platform_Selection_Services_2017Oies_IoT_Platform_Selection_Services_2017
Oies_IoT_Platform_Selection_Services_2017
 
The FIWARE Marketplace
The FIWARE MarketplaceThe FIWARE Marketplace
The FIWARE Marketplace
 
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT Platform
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT PlatformCreating end-to-end IoT applications with Eclipse Kura & Solair IoT Platform
Creating end-to-end IoT applications with Eclipse Kura & Solair IoT Platform
 
Internet of Things (IoT) and Google
Internet of Things (IoT) and GoogleInternet of Things (IoT) and Google
Internet of Things (IoT) and Google
 
IoT World Forum Press Conference - 10.14.2014
IoT World Forum Press Conference - 10.14.2014IoT World Forum Press Conference - 10.14.2014
IoT World Forum Press Conference - 10.14.2014
 

Similar to Build your own IoT platform using FIWARE GEIs

Gr8conf EU 2018 - Bring you infrastructure under control with Infrastructor
Gr8conf EU 2018 - Bring you infrastructure under control with InfrastructorGr8conf EU 2018 - Bring you infrastructure under control with Infrastructor
Gr8conf EU 2018 - Bring you infrastructure under control with InfrastructorStanislav Tiurikov
 
FIWARE Primer - Learn FIWARE in 60 Minutes
FIWARE Primer - Learn FIWARE in 60 MinutesFIWARE Primer - Learn FIWARE in 60 Minutes
FIWARE Primer - Learn FIWARE in 60 MinutesFederico Michele Facca
 
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 Minutes
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 MinutesFederico Michele Facca - FIWARE Primer - Learn FIWARE in 60 Minutes
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 MinutesCodemotion
 
Bring your infrastructure under control with Infrastructor
Bring your infrastructure under control with InfrastructorBring your infrastructure under control with Infrastructor
Bring your infrastructure under control with InfrastructorStanislav Tiurikov
 
Fiware io t_ul20_cpbr8
Fiware io t_ul20_cpbr8Fiware io t_ul20_cpbr8
Fiware io t_ul20_cpbr8FIWARE
 
Node Interactive: Node.js Performance and Highly Scalable Micro-Services
Node Interactive: Node.js Performance and Highly Scalable Micro-ServicesNode Interactive: Node.js Performance and Highly Scalable Micro-Services
Node Interactive: Node.js Performance and Highly Scalable Micro-ServicesChris Bailey
 
Nko workshop - node js crud & deploy
Nko workshop - node js crud & deployNko workshop - node js crud & deploy
Nko workshop - node js crud & deploySimon Su
 
Burn down the silos! Helping dev and ops gel on high availability websites
Burn down the silos! Helping dev and ops gel on high availability websitesBurn down the silos! Helping dev and ops gel on high availability websites
Burn down the silos! Helping dev and ops gel on high availability websitesLindsay Holmwood
 
Do you know what your drupal is doing? Observe it!
Do you know what your drupal is doing? Observe it!Do you know what your drupal is doing? Observe it!
Do you know what your drupal is doing? Observe it!Luca Lusso
 
Hopping in clouds - phpuk 17
Hopping in clouds - phpuk 17Hopping in clouds - phpuk 17
Hopping in clouds - phpuk 17Michele Orselli
 
Ato2019 weave-services-istio
Ato2019 weave-services-istioAto2019 weave-services-istio
Ato2019 weave-services-istioLin Sun
 
Weave Your Microservices with Istio
Weave Your Microservices with IstioWeave Your Microservices with Istio
Weave Your Microservices with IstioAll Things Open
 
All Things Open 2019 weave-services-istio
All Things Open 2019 weave-services-istioAll Things Open 2019 weave-services-istio
All Things Open 2019 weave-services-istioLin Sun
 
Capture, record, clip, embed and play, search: video from newbie to ninja
Capture, record, clip, embed and play, search: video from newbie to ninjaCapture, record, clip, embed and play, search: video from newbie to ninja
Capture, record, clip, embed and play, search: video from newbie to ninjaVito Flavio Lorusso
 
[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho
[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho
[CB16] Esoteric Web Application Vulnerabilities by Andrés RianchoCODE BLUE
 
Strata London 2018: Multi-everything with Apache Pulsar
Strata London 2018:  Multi-everything with Apache PulsarStrata London 2018:  Multi-everything with Apache Pulsar
Strata London 2018: Multi-everything with Apache PulsarStreamlio
 
FIWARE Training: Connecting to Legacy Systems, IoT and other Systems
FIWARE Training: Connecting to Legacy Systems, IoT and other SystemsFIWARE Training: Connecting to Legacy Systems, IoT and other Systems
FIWARE Training: Connecting to Legacy Systems, IoT and other SystemsFIWARE
 
IBM Cloud University: Build, Deploy and Scale Node.js Microservices
IBM Cloud University: Build, Deploy and Scale Node.js MicroservicesIBM Cloud University: Build, Deploy and Scale Node.js Microservices
IBM Cloud University: Build, Deploy and Scale Node.js MicroservicesChris Bailey
 
Build Your Own CaaS (Container as a Service)
Build Your Own CaaS (Container as a Service)Build Your Own CaaS (Container as a Service)
Build Your Own CaaS (Container as a Service)HungWei Chiu
 

Similar to Build your own IoT platform using FIWARE GEIs (20)

Gr8conf EU 2018 - Bring you infrastructure under control with Infrastructor
Gr8conf EU 2018 - Bring you infrastructure under control with InfrastructorGr8conf EU 2018 - Bring you infrastructure under control with Infrastructor
Gr8conf EU 2018 - Bring you infrastructure under control with Infrastructor
 
FIWARE Primer - Learn FIWARE in 60 Minutes
FIWARE Primer - Learn FIWARE in 60 MinutesFIWARE Primer - Learn FIWARE in 60 Minutes
FIWARE Primer - Learn FIWARE in 60 Minutes
 
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 Minutes
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 MinutesFederico Michele Facca - FIWARE Primer - Learn FIWARE in 60 Minutes
Federico Michele Facca - FIWARE Primer - Learn FIWARE in 60 Minutes
 
Bring your infrastructure under control with Infrastructor
Bring your infrastructure under control with InfrastructorBring your infrastructure under control with Infrastructor
Bring your infrastructure under control with Infrastructor
 
Fiware io t_ul20_cpbr8
Fiware io t_ul20_cpbr8Fiware io t_ul20_cpbr8
Fiware io t_ul20_cpbr8
 
Node Interactive: Node.js Performance and Highly Scalable Micro-Services
Node Interactive: Node.js Performance and Highly Scalable Micro-ServicesNode Interactive: Node.js Performance and Highly Scalable Micro-Services
Node Interactive: Node.js Performance and Highly Scalable Micro-Services
 
Simple docker hosting in FIWARE Lab
Simple docker hosting in FIWARE LabSimple docker hosting in FIWARE Lab
Simple docker hosting in FIWARE Lab
 
Nko workshop - node js crud & deploy
Nko workshop - node js crud & deployNko workshop - node js crud & deploy
Nko workshop - node js crud & deploy
 
Burn down the silos! Helping dev and ops gel on high availability websites
Burn down the silos! Helping dev and ops gel on high availability websitesBurn down the silos! Helping dev and ops gel on high availability websites
Burn down the silos! Helping dev and ops gel on high availability websites
 
Do you know what your drupal is doing? Observe it!
Do you know what your drupal is doing? Observe it!Do you know what your drupal is doing? Observe it!
Do you know what your drupal is doing? Observe it!
 
Hopping in clouds - phpuk 17
Hopping in clouds - phpuk 17Hopping in clouds - phpuk 17
Hopping in clouds - phpuk 17
 
Ato2019 weave-services-istio
Ato2019 weave-services-istioAto2019 weave-services-istio
Ato2019 weave-services-istio
 
Weave Your Microservices with Istio
Weave Your Microservices with IstioWeave Your Microservices with Istio
Weave Your Microservices with Istio
 
All Things Open 2019 weave-services-istio
All Things Open 2019 weave-services-istioAll Things Open 2019 weave-services-istio
All Things Open 2019 weave-services-istio
 
Capture, record, clip, embed and play, search: video from newbie to ninja
Capture, record, clip, embed and play, search: video from newbie to ninjaCapture, record, clip, embed and play, search: video from newbie to ninja
Capture, record, clip, embed and play, search: video from newbie to ninja
 
[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho
[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho
[CB16] Esoteric Web Application Vulnerabilities by Andrés Riancho
 
Strata London 2018: Multi-everything with Apache Pulsar
Strata London 2018:  Multi-everything with Apache PulsarStrata London 2018:  Multi-everything with Apache Pulsar
Strata London 2018: Multi-everything with Apache Pulsar
 
FIWARE Training: Connecting to Legacy Systems, IoT and other Systems
FIWARE Training: Connecting to Legacy Systems, IoT and other SystemsFIWARE Training: Connecting to Legacy Systems, IoT and other Systems
FIWARE Training: Connecting to Legacy Systems, IoT and other Systems
 
IBM Cloud University: Build, Deploy and Scale Node.js Microservices
IBM Cloud University: Build, Deploy and Scale Node.js MicroservicesIBM Cloud University: Build, Deploy and Scale Node.js Microservices
IBM Cloud University: Build, Deploy and Scale Node.js Microservices
 
Build Your Own CaaS (Container as a Service)
Build Your Own CaaS (Container as a Service)Build Your Own CaaS (Container as a Service)
Build Your Own CaaS (Container as a Service)
 

More from FIWARE

Behm_Herne_NeMo_akt.pptx
Behm_Herne_NeMo_akt.pptxBehm_Herne_NeMo_akt.pptx
Behm_Herne_NeMo_akt.pptxFIWARE
 
Katharina Hogrebe Herne Digital Days.pdf
 Katharina Hogrebe Herne Digital Days.pdf Katharina Hogrebe Herne Digital Days.pdf
Katharina Hogrebe Herne Digital Days.pdfFIWARE
 
Christoph Mertens_IDSA_Introduction to Data Spaces.pptx
Christoph Mertens_IDSA_Introduction to Data Spaces.pptxChristoph Mertens_IDSA_Introduction to Data Spaces.pptx
Christoph Mertens_IDSA_Introduction to Data Spaces.pptxFIWARE
 
Behm_Herne_NeMo.pptx
Behm_Herne_NeMo.pptxBehm_Herne_NeMo.pptx
Behm_Herne_NeMo.pptxFIWARE
 
Evangelists + iHubs Promo Slides.pptx
Evangelists + iHubs Promo Slides.pptxEvangelists + iHubs Promo Slides.pptx
Evangelists + iHubs Promo Slides.pptxFIWARE
 
Lukas Künzel Smart City Operating System.pptx
Lukas Künzel Smart City Operating System.pptxLukas Künzel Smart City Operating System.pptx
Lukas Künzel Smart City Operating System.pptxFIWARE
 
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptx
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptxPierre Golz Der Transformationsprozess im Konzern Stadt.pptx
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptxFIWARE
 
Dennis Wendland_The i4Trust Collaboration Programme.pptx
Dennis Wendland_The i4Trust Collaboration Programme.pptxDennis Wendland_The i4Trust Collaboration Programme.pptx
Dennis Wendland_The i4Trust Collaboration Programme.pptxFIWARE
 
Ulrich Ahle_FIWARE.pptx
Ulrich Ahle_FIWARE.pptxUlrich Ahle_FIWARE.pptx
Ulrich Ahle_FIWARE.pptxFIWARE
 
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptx
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptxAleksandar Vrglevski _FIWARE DACH_OSIH.pptx
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptxFIWARE
 
Water Quality - Lukas Kuenzel.pdf
Water Quality - Lukas Kuenzel.pdfWater Quality - Lukas Kuenzel.pdf
Water Quality - Lukas Kuenzel.pdfFIWARE
 
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptx
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptxCameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptx
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptxFIWARE
 
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptx
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptxFiWareSummit.msGIS-Data-to-Value.2023.06.12.pptx
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptxFIWARE
 
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptx
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptxBoris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptx
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptxFIWARE
 
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....FIWARE
 
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdf
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdfAbdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdf
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdfFIWARE
 
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdf
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdfFGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdf
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdfFIWARE
 
HTAG_Skalierung_Plattform_lokal_final_versand.pptx
HTAG_Skalierung_Plattform_lokal_final_versand.pptxHTAG_Skalierung_Plattform_lokal_final_versand.pptx
HTAG_Skalierung_Plattform_lokal_final_versand.pptxFIWARE
 
WE_LoRaWAN _ IoT.pptx
WE_LoRaWAN  _ IoT.pptxWE_LoRaWAN  _ IoT.pptx
WE_LoRaWAN _ IoT.pptxFIWARE
 
EU Opp_Clara Pezuela - German chapter.pptx
EU Opp_Clara Pezuela - German chapter.pptxEU Opp_Clara Pezuela - German chapter.pptx
EU Opp_Clara Pezuela - German chapter.pptxFIWARE
 

More from FIWARE (20)

Behm_Herne_NeMo_akt.pptx
Behm_Herne_NeMo_akt.pptxBehm_Herne_NeMo_akt.pptx
Behm_Herne_NeMo_akt.pptx
 
Katharina Hogrebe Herne Digital Days.pdf
 Katharina Hogrebe Herne Digital Days.pdf Katharina Hogrebe Herne Digital Days.pdf
Katharina Hogrebe Herne Digital Days.pdf
 
Christoph Mertens_IDSA_Introduction to Data Spaces.pptx
Christoph Mertens_IDSA_Introduction to Data Spaces.pptxChristoph Mertens_IDSA_Introduction to Data Spaces.pptx
Christoph Mertens_IDSA_Introduction to Data Spaces.pptx
 
Behm_Herne_NeMo.pptx
Behm_Herne_NeMo.pptxBehm_Herne_NeMo.pptx
Behm_Herne_NeMo.pptx
 
Evangelists + iHubs Promo Slides.pptx
Evangelists + iHubs Promo Slides.pptxEvangelists + iHubs Promo Slides.pptx
Evangelists + iHubs Promo Slides.pptx
 
Lukas Künzel Smart City Operating System.pptx
Lukas Künzel Smart City Operating System.pptxLukas Künzel Smart City Operating System.pptx
Lukas Künzel Smart City Operating System.pptx
 
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptx
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptxPierre Golz Der Transformationsprozess im Konzern Stadt.pptx
Pierre Golz Der Transformationsprozess im Konzern Stadt.pptx
 
Dennis Wendland_The i4Trust Collaboration Programme.pptx
Dennis Wendland_The i4Trust Collaboration Programme.pptxDennis Wendland_The i4Trust Collaboration Programme.pptx
Dennis Wendland_The i4Trust Collaboration Programme.pptx
 
Ulrich Ahle_FIWARE.pptx
Ulrich Ahle_FIWARE.pptxUlrich Ahle_FIWARE.pptx
Ulrich Ahle_FIWARE.pptx
 
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptx
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptxAleksandar Vrglevski _FIWARE DACH_OSIH.pptx
Aleksandar Vrglevski _FIWARE DACH_OSIH.pptx
 
Water Quality - Lukas Kuenzel.pdf
Water Quality - Lukas Kuenzel.pdfWater Quality - Lukas Kuenzel.pdf
Water Quality - Lukas Kuenzel.pdf
 
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptx
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptxCameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptx
Cameron Brooks_FGS23_FIWARE Summit_Keynote_Cameron.pptx
 
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptx
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptxFiWareSummit.msGIS-Data-to-Value.2023.06.12.pptx
FiWareSummit.msGIS-Data-to-Value.2023.06.12.pptx
 
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptx
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptxBoris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptx
Boris Otto_FGS2023_Opening- EU Innovations from Data_PUB_V1_BOt.pptx
 
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....
Bjoern de Vidts_FGS23_Opening_athumi - bjord de vidts - personal data spaces....
 
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdf
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdfAbdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdf
Abdulrahman Ibrahim_FGS23 Opening - Abdulrahman Ibrahim.pdf
 
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdf
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdfFGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdf
FGS2023_Opening_Red Hat Keynote Andrea Battaglia.pdf
 
HTAG_Skalierung_Plattform_lokal_final_versand.pptx
HTAG_Skalierung_Plattform_lokal_final_versand.pptxHTAG_Skalierung_Plattform_lokal_final_versand.pptx
HTAG_Skalierung_Plattform_lokal_final_versand.pptx
 
WE_LoRaWAN _ IoT.pptx
WE_LoRaWAN  _ IoT.pptxWE_LoRaWAN  _ IoT.pptx
WE_LoRaWAN _ IoT.pptx
 
EU Opp_Clara Pezuela - German chapter.pptx
EU Opp_Clara Pezuela - German chapter.pptxEU Opp_Clara Pezuela - German chapter.pptx
EU Opp_Clara Pezuela - German chapter.pptx
 

Recently uploaded

VIP Kolkata Call Girl Dum Dum 👉 8250192130 Available With Room
VIP Kolkata Call Girl Dum Dum 👉 8250192130  Available With RoomVIP Kolkata Call Girl Dum Dum 👉 8250192130  Available With Room
VIP Kolkata Call Girl Dum Dum 👉 8250192130 Available With Roomdivyansh0kumar0
 
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...Diya Sharma
 
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...APNIC
 
Low Rate Call Girls Kolkata Avani 🤌 8250192130 🚀 Vip Call Girls Kolkata
Low Rate Call Girls Kolkata Avani 🤌  8250192130 🚀 Vip Call Girls KolkataLow Rate Call Girls Kolkata Avani 🤌  8250192130 🚀 Vip Call Girls Kolkata
Low Rate Call Girls Kolkata Avani 🤌 8250192130 🚀 Vip Call Girls Kolkataanamikaraghav4
 
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)Dana Luther
 
VIP Kolkata Call Girl Kestopur 👉 8250192130 Available With Room
VIP Kolkata Call Girl Kestopur 👉 8250192130  Available With RoomVIP Kolkata Call Girl Kestopur 👉 8250192130  Available With Room
VIP Kolkata Call Girl Kestopur 👉 8250192130 Available With Roomdivyansh0kumar0
 
Hot Service (+9316020077 ) Goa Call Girls Real Photos and Genuine Service
Hot Service (+9316020077 ) Goa  Call Girls Real Photos and Genuine ServiceHot Service (+9316020077 ) Goa  Call Girls Real Photos and Genuine Service
Hot Service (+9316020077 ) Goa Call Girls Real Photos and Genuine Servicesexy call girls service in goa
 
VIP Kolkata Call Girl Alambazar 👉 8250192130 Available With Room
VIP Kolkata Call Girl Alambazar 👉 8250192130  Available With RoomVIP Kolkata Call Girl Alambazar 👉 8250192130  Available With Room
VIP Kolkata Call Girl Alambazar 👉 8250192130 Available With Roomdivyansh0kumar0
 
Radiant Call girls in Dubai O56338O268 Dubai Call girls
Radiant Call girls in Dubai O56338O268 Dubai Call girlsRadiant Call girls in Dubai O56338O268 Dubai Call girls
Radiant Call girls in Dubai O56338O268 Dubai Call girlsstephieert
 
Russian Call Girls in Kolkata Samaira 🤌 8250192130 🚀 Vip Call Girls Kolkata
Russian Call Girls in Kolkata Samaira 🤌  8250192130 🚀 Vip Call Girls KolkataRussian Call Girls in Kolkata Samaira 🤌  8250192130 🚀 Vip Call Girls Kolkata
Russian Call Girls in Kolkata Samaira 🤌 8250192130 🚀 Vip Call Girls Kolkataanamikaraghav4
 
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝soniya singh
 
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...aditipandeya
 
AWS Community DAY Albertini-Ellan Cloud Security (1).pptx
AWS Community DAY Albertini-Ellan Cloud Security (1).pptxAWS Community DAY Albertini-Ellan Cloud Security (1).pptx
AWS Community DAY Albertini-Ellan Cloud Security (1).pptxellan12
 
On Starlink, presented by Geoff Huston at NZNOG 2024
On Starlink, presented by Geoff Huston at NZNOG 2024On Starlink, presented by Geoff Huston at NZNOG 2024
On Starlink, presented by Geoff Huston at NZNOG 2024APNIC
 
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...SofiyaSharma5
 
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Delivery
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on DeliveryCall Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Delivery
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Deliverybabeytanya
 
Moving Beyond Twitter/X and Facebook - Social Media for local news providers
Moving Beyond Twitter/X and Facebook - Social Media for local news providersMoving Beyond Twitter/X and Facebook - Social Media for local news providers
Moving Beyond Twitter/X and Facebook - Social Media for local news providersDamian Radcliffe
 
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girlsstephieert
 

Recently uploaded (20)

VIP Kolkata Call Girl Dum Dum 👉 8250192130 Available With Room
VIP Kolkata Call Girl Dum Dum 👉 8250192130  Available With RoomVIP Kolkata Call Girl Dum Dum 👉 8250192130  Available With Room
VIP Kolkata Call Girl Dum Dum 👉 8250192130 Available With Room
 
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...
₹5.5k {Cash Payment}New Friends Colony Call Girls In [Delhi NIHARIKA] 🔝|97111...
 
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...
'Future Evolution of the Internet' delivered by Geoff Huston at Everything Op...
 
Low Rate Call Girls Kolkata Avani 🤌 8250192130 🚀 Vip Call Girls Kolkata
Low Rate Call Girls Kolkata Avani 🤌  8250192130 🚀 Vip Call Girls KolkataLow Rate Call Girls Kolkata Avani 🤌  8250192130 🚀 Vip Call Girls Kolkata
Low Rate Call Girls Kolkata Avani 🤌 8250192130 🚀 Vip Call Girls Kolkata
 
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)
Packaging the Monolith - PHP Tek 2024 (Breaking it down one bite at a time)
 
VIP Kolkata Call Girl Kestopur 👉 8250192130 Available With Room
VIP Kolkata Call Girl Kestopur 👉 8250192130  Available With RoomVIP Kolkata Call Girl Kestopur 👉 8250192130  Available With Room
VIP Kolkata Call Girl Kestopur 👉 8250192130 Available With Room
 
Hot Service (+9316020077 ) Goa Call Girls Real Photos and Genuine Service
Hot Service (+9316020077 ) Goa  Call Girls Real Photos and Genuine ServiceHot Service (+9316020077 ) Goa  Call Girls Real Photos and Genuine Service
Hot Service (+9316020077 ) Goa Call Girls Real Photos and Genuine Service
 
VIP Kolkata Call Girl Alambazar 👉 8250192130 Available With Room
VIP Kolkata Call Girl Alambazar 👉 8250192130  Available With RoomVIP Kolkata Call Girl Alambazar 👉 8250192130  Available With Room
VIP Kolkata Call Girl Alambazar 👉 8250192130 Available With Room
 
Radiant Call girls in Dubai O56338O268 Dubai Call girls
Radiant Call girls in Dubai O56338O268 Dubai Call girlsRadiant Call girls in Dubai O56338O268 Dubai Call girls
Radiant Call girls in Dubai O56338O268 Dubai Call girls
 
Russian Call Girls in Kolkata Samaira 🤌 8250192130 🚀 Vip Call Girls Kolkata
Russian Call Girls in Kolkata Samaira 🤌  8250192130 🚀 Vip Call Girls KolkataRussian Call Girls in Kolkata Samaira 🤌  8250192130 🚀 Vip Call Girls Kolkata
Russian Call Girls in Kolkata Samaira 🤌 8250192130 🚀 Vip Call Girls Kolkata
 
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝
Call Girls In Model Towh Delhi 💯Call Us 🔝8264348440🔝
 
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...
VIP 7001035870 Find & Meet Hyderabad Call Girls Dilsukhnagar high-profile Cal...
 
AWS Community DAY Albertini-Ellan Cloud Security (1).pptx
AWS Community DAY Albertini-Ellan Cloud Security (1).pptxAWS Community DAY Albertini-Ellan Cloud Security (1).pptx
AWS Community DAY Albertini-Ellan Cloud Security (1).pptx
 
On Starlink, presented by Geoff Huston at NZNOG 2024
On Starlink, presented by Geoff Huston at NZNOG 2024On Starlink, presented by Geoff Huston at NZNOG 2024
On Starlink, presented by Geoff Huston at NZNOG 2024
 
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...
Low Rate Young Call Girls in Sector 63 Mamura Noida ✔️☆9289244007✔️☆ Female E...
 
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Delivery
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on DeliveryCall Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Delivery
Call Girls In Mumbai Central Mumbai ❤️ 9920874524 👈 Cash on Delivery
 
Moving Beyond Twitter/X and Facebook - Social Media for local news providers
Moving Beyond Twitter/X and Facebook - Social Media for local news providersMoving Beyond Twitter/X and Facebook - Social Media for local news providers
Moving Beyond Twitter/X and Facebook - Social Media for local news providers
 
Rohini Sector 26 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
Rohini Sector 26 Call Girls Delhi 9999965857 @Sabina Saikh No AdvanceRohini Sector 26 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
Rohini Sector 26 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
 
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls
10.pdfMature Call girls in Dubai +971563133746 Dubai Call girls
 
Rohini Sector 22 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
Rohini Sector 22 Call Girls Delhi 9999965857 @Sabina Saikh No AdvanceRohini Sector 22 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
Rohini Sector 22 Call Girls Delhi 9999965857 @Sabina Saikh No Advance
 

Build your own IoT platform using FIWARE GEIs

  • 1. Building your own IoT platform using FIWARE GEis José Manuel Cantera Fonseca Technological Expert. Data Chapter. josemanuel.canterafonseca@telefonica.com
  • 2. Introduction Talk Objectives Illustrate how a secured IoT platform instance can be implemented using FIWARE GEis on a container-based environment (Docker) Understand how to set up a security layer on top of a Context Broker Learn how to configure all the components at the different layers
  • 3. TargetArchitectureusingfiware securitystack Context Broker (Orion) mongoDB Application (Data Consumer) Identity Manager (Keystone) Authorization PDP (Keypass) PEP Proxy (Steelskin) Token validation (domain, project, role) Is authorized? Allow or Deny NGSIv2 Registration App NGSIv2 Add user Domain, Project, Roles Token Developer Data ingestionGet token Internet / VPN IoT platform Infrastructure I9 I8 IoT Devices Open Data Sources
  • 4. Getting started A basic context broker set up 4
  • 5. BasicData&Controlbrokersetup Data & Control Broker (Orion) mongoDB Application (Data Consumer) NGSIv2NGSIv2 Data ingestion Internet / VPN Operator Infrastructure I8 IoT Devices Open Data Sources
  • 6. Step1.-MongoDB(I) mongoDB is the NoSQL database used to store context data mongoDB is properly packaged as a docker container Use mongoDB 3.2 docker container Prepare a folder to store mongoDB data Ex. $HOME/data/mongo Run mongoDB $ docker run --name mongo -v $HOME/data/mongo:/data/db -d -h mongo -p 27017:27017 mongo:3.2
  • 7. Step1.-mongoDB(II) $ docker ps -a to list running containers aa075751485b mongo:3.2 "/entrypoint.sh mongo" 5 seconds ago Up 4 seconds 0.0.0.0:27017->27017/tcp mongo run mongo client application to check everything is ok You might need to install it https://docs.mongodb.com/v3.2/tutorial/install-mongodb-on-ubuntu/ $ apt-get install mongodb-org-shell $ mongo> show dbs Or you can directly connect to the container
  • 8. Step2.-Orioncontextbroker(I) Orion is an implementation of the “Data and Context Broker” An open source project hosted by the FIWARE OSS https://github.com/fiware/context.Orion (License Affero GPL v3.0) properly packaged as a docker container running on CentOS 6 Orion uses mongoDB as the data storage For running Orion … $ docker run --name orion -d -p 1026:1026 --link mongo -h orion fiware/orion:1.4.1 -dbhost mongo $ docker ps -a
  • 9. STEP2.-OrionContextbroker(II) $ curl -s localhost:1026/version | python -mjson.tool { "orion" : { "version" : "1.4.1", "uptime" : "0 d, 0 h, 1 m, 17 s", "git_hash" : "905d5fa58ace7fa4f14330ddc982b41cf9b30be6", "compile_time" : "Mon Oct 10 15:06:02 UTC 2016", "compiled_by" : "root", "compiled_in" : "b99744612d0b" } } $ mongo > show dbs > use orion Now a DB named “orion” should appear if everything is ok db.getCollectionNames() [ "entities" ] curl -s localhost:1026/v2/entities | python -mjson.tool
  • 10. Step3.-Let’saddsomeentitiestoorion(I) $ curl localhost:1026/v2/entities -s -S --header 'Content-Type: application/json' -d @- <<EOF { "id": "WeatherObserved-6789", "type": "WeatherObserved", "temperature": { "value": 23, "type": "Number" }, "barometricPressure": { "value": 720, "type": "Number" }, "dateObserved": { "value": "2016-10-18T11:08:20.228Z", "type": "DateTime" }, "source": { "value": "http://www.aemet.es", "type": "URL" } } EOF
  • 11. Step3.-Let’saddsomeentitiestoorion(II) $ curl localhost:1026/v2/entities?options=keyValues | python -mjson.tool [ { "barometricPressure": 720, "dateObserved": "2016-10-18T11:08:20.00Z", "id": "WeatherObserved-6789", "source": "http://www.aemet.es", "temperature": 23, "type": "WeatherObserved" } ] $ mongo > use orion switched to db orion > db.entities.find({}) { "_id" : { "id" : "WeatherObserved-6789", "type" : "WeatherObserved", "servicePath" : "/" }, "attrNames" : [ "temperature", "barometricPressure", "dateObserved", "source" ], "attrs" : { "temperature" : { "type" : "Number", "creDate" : 1476789680, "modDate" : 1476789680, "value" : 23, "mdNames" : [ ] }, "barometricPressure" : { "type" : "Number", "creDate" : 1476789680, "modDate" : 1476789680, "value" : 720, "mdNames" : [ ] }, "dateObserved" : { "type" : "DateTime", "creDate" : 1476789680, "modDate" : 1476789680, "value" : 1476788900, "mdNames" : [ ] }, "source" : { "type" : "URL", "creDate" : 1476789680, "modDate" : 1476789680, "value" : "http://www.aemet.es", "mdNames" : [ ] } }, "creDate" : 1476789680, "modDate" : 1476789680 }
  • 12. Step4.-Multitenancy (I) Orion Context Broker is multitenant Logical databases isolated, each one containing data from different organizations or domains Tenant is a “service” in FIWARE terminology. Aka a “Domain” in OpenStack terminology A tenant can be composed by multiple child sub- tenants “subservice” in FIWARE terminology Aka a “Project” in OpenStack terminology
  • 13. Step4.-Multitenancy (II) The way to address tenants are HTTP headers Fiware-Service : <<Tenant_Name>> Fiware-Servicepath: <<Subservice_Name>> Subtenants follow a hierarchical structure and there is a default subtenant, root one (‘/’) Example: Fiware-service: weather Fiware-servicepath: /Spain A pair (service, subservice) is used for security
  • 14. Step4.-Multitenancy (III) TENANT="Fiware-Service:$1" SUBSERVICE="Fiware-ServicePath:/$2" curl localhost:1026/v2/entities --header $TENANT --header $SUBSERVICE -s -S --header 'Content-Type: application/json' -d @- <<EOF { "id": "WeatherObserved-6789", "type": "WeatherObserved", "temperature": { "value": 23, "type": "Number" }, …… } EOF ● Creating an entity in a (tenant , subtenant)
  • 15. Step4.-Multitenancy (IV) $mongo > show dbs local 0.000GB orion 0.000GB orion-example_a 0.000GB orion-london 0.000GB orion-weather 0.000GB There will be as many databases as tenants available “orion” is the DB which stores data in the default tenant DB name is “orion-” + <<tenant_name>> To query data of a tenant just issue regular NGSIv2 requests using Fiware-Service and Fiware-Servicepath headers
  • 16. Deeping dive Adding a security layer to the data & control broker 16
  • 17. TargetArchitectureusingfiwaresecuritystack Data & Control Broker (Orion) mongoDB Application (Data Consumer) Identity Manager (Keystone) Authorization PDP (Keypass) PEP Proxy (Steelskin) Token validation (domain, project, role) Is authorized? Allow or Deny NGSIv2 Registration App NGSIv2 Add user Domain, Project, Roles Token Developer Data ingestionGet token Internet / VPN Operator Infrastructure I9 I8 IoT Devices Open Data Sources
  • 18. Step4.-Securitystack-preparation Security stack uses MySQL to store configuration data $ docker run --name mysql -d -p 3306:3306 -h mysql -v $HOME/data/mysql:/var/lib/mysql -e "MYSQL_ROOT_PASSWORD=gsma" -e "MYSQL_DATABASE=keypass" -e "MYSQL_USER=keypass" -e "MYSQL_PASSWORD=keypass" mysql:5.5 Check that everything is ok. Above command creates a database named “keypass” used later. $ docker exec -it mysql bash mysql --user=root --password=gsma mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | keypass | | mysql | | performance_schema | +--------------------+ 4 rows in set (0.00 sec)
  • 19. Step4.1.-keystone(I) Keystone is an open source project hosted by OpenStack OSS Community https://github.com/openstack/keystone (Apache 2.0 license) Keystone is an Identity Manager service capable of storing information about domains, project, users, groups or roles Keystone is in charge of generating tokens which can be used to get access to services requiring credentials For this exercise we will be using a keystone image
  • 20. Step4.1.-keystone(II) Running keystone $ docker run --name keystone -d -p 5001:5001 --link mysql -h keystone telefonicaiot/fiware-keystone-spassword -dbhost mysql -default_pwd 4pass1w0rd -mysql_pwd gsma Sanity check operations $ docker logs keystone $ docker exec -it keystone bash (to open a shell session on the container) $ curl -s -S http://localhost:5001/v3 | python -mjson.tool Once we have a keystone instance up and running different REST requests can be issued http://developer.openstack.org/api-ref/identity/v3/index.html
  • 21. $ docker exec -it mysql bash root@mysql:/# mysql --user=root --password=gsma mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | keypass | | keystone | | mysql | | performance_schema | +--------------------+ mysql> use keystone; Step4.1.-keystone(II-B) show tables; +-----------------------+ | Tables_in_keystone | +-----------------------+ | assignment | | credential | | domain | | endpoint | | group | | migrate_version | | policy | | project | | region | | role | | service | | spassword | | token | | trust | | trust_role | | user | | user_group_membership | +-----------------------+ Checking keystone has created its database properly
  • 22. Step4.1.-keystone(III) Remember: Fiware-Service → Domain in Keystone Fiware-Servicepath → Project in Keystone A developer will register in Keystone as user in a domain <-> Developer can get access to the data offered by the corresponding FIWARE service (tenant) We will later show how this works in practice
  • 23. Step4.1.-keystone(IV) List all domains curl -s -S --header x-auth-token:4pass1w0rd http://localhost:5001/v3/domains/ | python - mjson.tool { "domains": [ { "enabled": true, "id": "8b883aaa740e4d75b91095eaa550b35c", "links": { "self": "http://localhost:5001/v3/domains/8b883aaa740e4d75b91095eaa550b35c" }, "name": "admin_domain" }, { "description": "Owns users and tenants (i.e. projects) available on Identity API v2.", "enabled": true, "id": "default", "links": { "self": "http://localhost:5001/v3/domains/default" }, "name": "Default" } ]
  • 24. Step4.1.-keystone(V) List all users curl -s -S --header x-auth-token:4pass1w0rd http://localhost:5001/v3/users/ | python - mjson.tool "users": [ { "description": "Cloud service", "domain_id": "8b883aaa740e4d75b91095eaa550b35c", "enabled": true, "id": "02cd3dbb6ceb48eb92588c7885bbcc1f", "links": { "self": "http://localhost:5001/v3/users/02cd3dbb6ceb48eb92588c7885bbcc1f" }, "name": "pep" }, { "description": "Cloud administrator", "domain_id": "8b883aaa740e4d75b91095eaa550b35c", "enabled": true, "id": "177cf5a4d12e4f85b7b65cbcac6d9697", "links": { "self": "http://localhost:5001/v3/users/177cf5a4d12e4f85b7b65cbcac6d9697" }, "name": "cloud_admin" }
  • 25. Step4.1.-keystone(VI) Get a token for the cloud_admin user curl localhost:5001/v3/auth/tokens -s -S --header 'Content-Type: application/json' -d @- <<EOF { "auth": { "identity": { "methods": ["password"], "password": { "user": { "name": "cloud_admin", "domain": { "name": "admin_domain" }, "password": "4pass1w0rd" } } } } } EOF HTTP/1.1 201 Created X-Subject-Token: 19e200834a3f4e149c7f4033a003a8f4
  • 26. Step4.2.-keypass.-authPDP(I) keypass is an implementation of the FIWARE Authorization PDP (Policy Decision Point) Keypass is an open source project hosted at https://github.com/telefonicaid/fiware-keypass License is Apache 2.0 It complies with XACML (eXtensible Access Control Markup Language) v3.0. It provides an API to get authorization decisions based on authorization policies
  • 27. Step4.2.-keypass.-AuthPDP(II) Running keypass $ docker run --name keypass -d -p 7070:7070 -h keypass --link mysql telefonicaiot/fiware- keypass -dbhost mysql $ docker logs keypass $ curl --header 'Fiware-Service: dummy' localhost:7070/version 1.2.1
  • 28. Step4.3.-Steelskin.-PEPproxy (I) Steelskin is an implementation of the FIWARE PEP (Policy Enforcement Point) Steelskin is an open source project hosted at https://github.com/telefonicaid/fiware-pep-steelskin License is Affero GPL 3.0 A proxy which ensures that only authorized users are able to perform requests against the Data & Control Broker https://github.com/telefonicaid/fiware-pep-steelskin#-rules-to-determine-the- context-broker-action-from-the-request
  • 29. Step4.3.-Steelskin.-PEPproxy (II) Running: $ docker run -d --name pep -p 1027:1026 --link orion --link keystone --link keypass -e LOG_LEVEL=DEBUG -e AUTHENTICATION_HOST=keystone -e AUTHENTICATION_PORT=5001 -e ACCESS_HOST=keypass -e ACCESS_PORT=7070 -e TARGET_HOST=orion -e TARGET_PORT=1026 -e PROXY_USERNAME=pep -e PROXY_PASSWORD=4pass1w0rd telefonicaiot/fiware-pep-steelskin $ docker logs pep $ docker exec -it pep bash → $ curl localhost:11211/version { "version": "1.2.0-next", "port":1026 }
  • 30. Step4.3.-Steelskin.-PEPproxy(III) Remember: Given an HTTP Request (x-auth-token, fiware- service, fiware-servicepath) First PEP queries keystone to validate the auth token and obtain (user, domain, role in project) Then, PEP queries keypass to obtain the authorization policies for the role in question A match between subject policies and the requested operation is done If the requested operation is allowed, the HTTP request is forwarded to the Data & Control Broker If not a non-authorized error is raised curl localhost:1027/v2/entities
  • 31. STEP5.-Usingthemalltogether $ docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES d18f7dbe7f75 telefonicaiot/fiware-pep-steelskin "/bin/sh -c bin/pepPr" 16 minutes ago Up 16 minutes 11211/tcp, 0.0.0.0:1027->1026/tcp pep 7e1853f0e2c4 telefonicaiot/fiware-keypass "/opt/keypass/keypass" 45 minutes ago Up 45 minutes 0.0.0.0:7070-7071->7070-7071/tcp keypass c4f6ab6c390f telefonicaiot/fiware-keystone-spassword "/opt/keystone/keysto" About an hour ago Up About an hour 0.0.0.0:5001->5001/tcp keystone 5bf5d7e8b284 mysql:5.5 "docker-entrypoint.sh" 18 hours ago Up 18 hours 0.0.0.0:3307->3306/tcp mysql 6c63cee20ae2 fiware/orion:1.4.1 "/usr/bin/contextBrok" 24 hours ago Up 24 hours 0.0.0.0:1026->1026/tcp orion 4f1d9298fb70 mongo:3.2 "/entrypoint.sh mongo" 24 hours ago Up 24 hours 0.0.0.0:27017->27017/tcp mongo
  • 32. Step5.1.-Orchestratortotherescue Manual provision of configurations of the three security components can be cumbersome TEF has developed an open source project (named orchestrator) that helps to provide security configurations https://github.com/telefonicaid/orchestrator License is Affero GPL 3.0 It can be instantiated as a service but there are some useful scripts which can be used https://github.com/telefonicaid/orchestrator/blob/master/SCRIPTS.md
  • 33. Step5.2.-configuringaservice(tenant) $ git clone https://github.com/telefonicaid/orchestrator $ cd orchestrator $ pip install -r requirements.txt $ export PYTHONPATH=$PYTHONPATH:$HOME/gsma/orchestrator/src cd $HOME/gsma/orchestrator/src ./orchestrator/commands/createNewService.py http localhost 5001 admin_domain cloud_admin 4pass1w0rd weatherdata "Weather Data" weather_admin weather_admin_PWD http localhost 7070 Checking that everything went ok ./orchestrator/commands/printServices.py http localhost 5001 admin_domain cloud_admin 4pass1w0rd
  • 34. Step5.3.-configuringaSub-service $ export PYTHONPATH=$PYTHONPATH:$HOME/gsma/orchestrator/src cd $HOME/gsma/orchestrator/src ./orchestrator/commands/createNewSubService.py http localhost 5001 weatherdata weather_admin weather_admin_PWD "Spain" "Weather in Spain" Checking that everything went ok ./orchestrator/commands/printSubServices.py http localhost 5001 weatherdata weather_admin weather_admin_PWD Now we have a pair (Fiware-Service, Fiware-Servicepath) → (‘weatherdata’, ‘/Spain`) We can check that we can get access to data 1/ obtain a token for the `weather_admin’ user Ex. `5bb5c6e310814b93a01d74385fe52bef` 2/ issue a GET request through the PEP proxy curl localhost:1027/v2/entities --header 'Fiware-Service:weatherdata' --header 'Fiware-Servicepath:
  • 35. Step5.4.-addingadeveloperwithconsumerpermissions $ ./orchestrator/commands/createNewServiceUser.py http localhost 5001 weatherdata weather_admin weather_admin_PWD developer1 developer1_PWD Checking that everything went ok ./orchestrator/commands/printServiceUsers.py http localhost 5001 weatherdata weather_admin weather_admin_PWD Now we need to assign the role “SubServiceCustomer” to the user ‘developer1’ ./orchestrator/commands/assignRoleSubServiceUser.py http localhost 5001 weatherdata Spain weather_admin weather_admin_PWD SubServiceCustomer developer1 Checking that everything went ok ./orchestrator/commands/listSubServiceRoleAssignments.py http localhost 5001 weatherdata weather_admin weather_admin_PWD Spain True Now ‘developer1’ is able to query weather data on the sub-service ‘Spain’. However he cannot provide data as his role is ‘SubServiceCustomer’
  • 36. Step5.5.-gettingaccesstodatawith‘developer1’ (I) First of all a token must be obtained . Then : $ curl -s -S localhost:1027/v2/entities --header 'Fiware-service:weatherdata' --header 'Fiware-servicepath:/Spain' --header 'x-auth-token:36a1d0558612473da438c93d74d4aefc' | python -mjson.tool [ { "barometricPressure": { "metadata": {}, "type": "Number", "value": 720 }, "dateObserved": { "metadata": {}, "type": "DateTime", "value": "2016-10-18T11:08:20.00Z" }, "id": "WeatherObserved-6789", "type": "WeatherObserved" } ]
  • 37. Step5.5.-gettingaccesstodatawith‘developer1’ (II) An attempt to create a new entity on (weatherdata,/Spain) will fail curl localhost:1027/v2/entities -s -S --header 'Content-Type: application/json' --header 'Fiware- Service:weatherdata' --header 'Fiware-servicepath:/Spain' --header 'x-auth-token:36a1d0558612473da438c93d74d4aefc' -d @- <<EOF { "id": "WeatherObserved-4567", …. } EOF { "name": "ACCESS_DENIED", "message": "The user does not have the appropriate permissions to access the selected action" } Developer will need to be assigned the role ‘SubServiceAdmin’ in order to be able to post new data
  • 38. What’shappeningbehindthescenes A set of predefined policies have been pre-populated to the ‘keypass’ database docker exec -it mysql mysql --user=keypass --password=keypass mysql> use keypass; select policy from Policies; Relevant policies are https://github.com/telefonicaid/orchestrator/blob/master/src/orchestrator/core /policies/policy-orion-customer.xml https://github.com/telefonicaid/orchestrator/blob/master/src/orchestrator/core /policies/policy-orion-admin.xml
  • 39. Andfinally... Remember to remove old docker containers (exited) $ docker rm <container> You should only expose the IdM (for tokens) and the PEP Proxy (ports) to the developer Ensure the mounted volumes for database data have enough space for the data to be stored Remember, you can open a shell session on a container $ docker exec -it <<container_name> bash And then get access to the logs, databases, local services, ….