Академический Документы
Профессиональный Документы
Культура Документы
www.weforum.org
Businesses
Regulatory
Bodies
Governments
Individuals
Banks
Devices
• The "Things" in IoT usually refers to IoT devices which have unique
identities and can perform remote sensing, actuation and monitoring.
• IoT devices can:
• Exchange data with other connected devices and applications (directly or indirectly),
or
• Collect data from other devices and process the data locally or
• Send the data to centralized servers or cloud-based application back-ends for
processing the data, or
• Perform some tasks locally and other tasks within the IoT infrastructure, based on
temporal and space constraints
• Request-Response is a
communication model in which the
client sends requests to the server
and the server responds to the
requests.
• Publish-Subscribe is a
communication model that
involves publishers, brokers and
consumers.
• Publishers are the source of data.
Publishers send the data to the
topics which are managed by the
broker. Publishers are not aware
of the consumers.
• Consumers subscribe to the topics
which are managed by the broker.
• When the broker receives data for
a topic from the publisher, it sends
the data to all the subscribed
consumers.
• Push-Pull is a communication
model in which the data producers
push the data to queues and the
consumers pull the data from the
queues. Producers do not need to
be aware of the consumers.
• Queues help in decoupling the
messaging between the producers
and consumers.
• Queues also act as a buffer which
helps in situations when there is a
mismatch between the rate at
which the producers push data
and the rate rate at which the
consumers pull data.
• Exclusive Pair is a
bidirectional, fully duplex
communication model that
uses a persistent connection
between the client and
server.
• Once the connection is
setup it remains open until
the client sends a request to
close the connection.
• Client and server can send
messages to each other
after connection setup.
• Database: Database can be either local or in the cloud and stores the data
generated by the IoT device.
• Web Service: Web services serve as a link between the IoT device,
application, database and analysis components. Web service can be either
implemented using HTTP and REST principles (REST service) or using
WebSocket protocol (WebSocket service).
• Analysis Component: The Analysis Component is responsible for
analyzing the IoT data and generate results in a form which are easy for the
user to understand.
• Application: IoT applications provide an interface that the users can use to
control and monitor various aspects of the IoT system. Applications also
allow users to view the system status and view the processed data.
• A Device or "Thing" in Internet of Things (IoT) can be any object that has a
unique identifier and which can send/receive data (including user data)
over a network (such as a smartphone, smart TV, computer, refrigerator or
car).
• IoT devices are connected to the Internet and send information about
themselves or about their surroundings (e.g. information sensed by the
connected sensors) over a network (to other devices or servers/storage) or
allow actuation upon the physical entities/environment around them
remotely.
• Sensors
• Sensors can be either on-board the IoT device or attached to the device.
• Actuators
• IoT devices can have various types of actuators attached that allow taking actions upon
the physical entities in the vicinity of the device.
• Communication
• Communication modules are responsible for sending collected data to other devices or
cloud-based servers/storage and receiving data from other devices and commands from
remote applications.
• Analysis & Processing
• Analysis and processing modules are responsible for making sense of the collected data.
• Serial
• The serial interface on Raspberry Pi has receive (Rx) and transmit (Tx) pins for
communication with serial peripherals.
• SPI
• Serial Peripheral Interface (SPI) is a synchronous serial data protocol used for
communicating with one or more peripheral devices.
• I2C
• The I2C interface pins on Raspberry Pi allow you to connect hardware modules. I2C
interface allows synchronous data transfer with just two pins - SDA (data line) and
SCL (clock line).
#Switch Pin
GPIO.setup(25, GPIO.IN)
#LED Pin
GPIO.setup(18, GPIO.OUT)
state=false
def toggleLED(pin):
state = not state
GPIO.output(pin, state)
while True:
try:
if (GPIO.input(25) == True):
toggleLED(pin)
sleep(.01)
except KeyboardInterrupt:
exit()
• BeagleBone Black
• pcDuino
• Cubieboard
class Mode(models.Model):
name = models.CharField(max_length=50)
1. Map services to models. Model class State(models.Model):
fields store the states (on/off, name = models.CharField(max_length=50)
auto/manual)
# Serializers – serializers.py
from myapp.models import Mode, State
from rest_framework import serializers
class ModeSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = Mode
fields = ('url', 'name')
class StateSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = State
fields = ('url', 'name')
Presentation by Arshdeep Bahga - Internet of Things 54
Implementation: RESTful Web Services
# Views – views.py
# Models – models.py from myapp.models import Mode, State
from django.db import models
3. Write ViewSets for the Models which from rest_framework import viewsets
combine the logic for a set of related views from myapp.serializers import ModeSerializer,
class Mode(models.Model): in a single class. StateSerializer
name = models.CharField(max_length=50)
class ModeViewSet(viewsets.ModelViewSet):
class State(models.Model): queryset = Mode.objects.all()
name = models.CharField(max_length=50) serializer_class = ModeSerializer
class StateViewSet(viewsets.ModelViewSet):
queryset = State.objects.all()
serializer_class = StateSerializer
Screenshot of browsable
State REST API
Screenshot of browsable
Mode REST API
Template
{% if currentmode == 'auto' %}
<div class="js-lamp-state-toggle ui-toggle " data-toggle=".js-lamp-state">
{% else %}
<div class="js-lamp-state-toggle ui-toggle js-toggle-off" data-toggle=".js-lamp-state">
{% endif %}
<span class="ui-toggle-slide clearfix">
<form id="my_form11" action="" method="post">{% csrf_token %}
<input name="auto" value="auto" type="hidden" />
<a href="#" onclick="$(this).closest('form').submit()"><strong class="ui-toggle-off">OFF</strong></a>
</form>
<strong class="ui-toggle-handle brushed-metal"></strong>
<form id="my_form13" action="" method="post">{% csrf_token %}
<input name="manual" value="manual" type="hidden" />
<a href="#" onclick="$(this).closest('form').submit()"><strong class="ui-toggle-on">ON</strong></a>
</form></span>
</div></div>
<div class="field clearfix">
<label class="input-label icon-lamp" for="tv-state">Light</label>
<input id="tv-state" class="input js-tv-state hidden" type="checkbox">
{% if currentstate == 'on' %}
<div class="js-tv-state-toggle ui-toggle " data-toggle=".js-tv-state">
{% else %}
<div class="js-tv-state-toggle ui-toggle js-toggle-off" data-toggle=".js-tv-state">
{% endif %}
{% if currentmode == 'manual' %}
<span class="ui-toggle-slide clearfix">
<form id="my_form2" action="" method="post">{% csrf_token %}
<input name="on" value="on" type="hidden" />
<a href="#" onclick="$(this).closest('form').submit()"><strong class="ui-toggle-off">OFF</strong></a>
</form>
<strong class="ui-toggle-handle brushed-metal"></strong>
<form id="my_form3" action="" method="post">{% csrf_token %}
<input name="off" value="off" type="hidden" />
<a href="#" onclick="$(this).closest('form').submit()"><strong class="ui-toggle-on">ON</strong></a>
</form>
</span>
{% endif %}
{% if currentmode == 'auto' %}
{% if currentstate == 'on' %}
<strong class="ui-toggle-on"> ON</strong>
{% else %}
<strong class="ui-toggle-on"> OFF</strong>
{% endif %}{% endif %}
</div>
</div>
</fieldset></div></div></div>
Presentation by Arshdeep Bahga - Internet of Things 59
Finally - Integrate the System
• Setup the device
• Deploy and run the REST and Native services
• Deploy and run the Application
• Setup the database
Django Application
SQLite Database
OS running on Raspberry Pi
• Authentication
• Authentication refers to digitally confirming the identity of the entity requesting access to some protected
information.
• In IoT & Cloud, where applications and data are accessed over the internet, the complexity of digital
authentication mechanisms increases rapidly.
• Authorization
• Authorization refers to digitally specifying the access rights to the protected resources using access policies.
• Authorization in a IoT & Cloud requires the use of the cloud service providers services for specifying the
access policies.
• Security of data at rest
• Due to the multi-tenant environments used in the cloud, the application and database servers of different
applications belonging to different organizations can be provisioned side-by-side increasing the complexity of
securing the data.
• Appropriate separation mechanisms are required to ensure the isolation between applications and data from
different organizations.
lls PI
by paying Ether to the smart 6. Charging station is activated
Ca T A
R
ES al
contract when the transaction is
T ls
C
RE
processed
AP
I
5. User sends transaction to
the contract to activate a Mobile App IoT Device
charging station by paying in
SolarCoins
BeagleBone Black
Blockchain Network
on which smart contract for
solar charging stations is
deployed
Amazon
EC2
Custom Web application
dashboard Amazon EMR