JavaScript
Learn how to connect to the Arduino Cloud via JavaScript (node.js).
The arduino-iot-js library allows you to interact with the Arduino Cloud via MQTT. It supports basic authentication using the device ID as well as secret key that is obtained from the Arduino Cloud when configuring a manual device.
Overview
In this guide we will:
- Configure a manual device in the Arduino Cloud,
- install the arduino-iot-js library,
- create a JavaScript example code that connects to the Arduino Cloud.
Requirements
To follow this guide, make sure to have:
- An Arduino account,
- a version of node.js installed (confirmed to work with 
 ),v16.15.0
- arduino-iot-js installed.
- A code editor (we recommend VSCode).
Cloud Setup
To begin with, we need to create a manual device, and create a new Thing. Navigate to the Arduino Cloud and to the "Things" tab.
Thing & Device Configuration
- Create a new Thing, by clicking on the "Create Thing" button.
- Click on the "Select Device" in the "Associated Devices" section of your Thing.
- Click on "Set Up New Device", and select the bottom category ("Manual Device"). Click continue in the next window, and choose a name for your device.
- Finally, you will see a new Device ID and a Secret Key generate. You can download them as a PDF. Make sure to save it as you cannot access your Secret Key again.
- Learn more about Things in the Things documentation
- Learn more about Devices in the Devices documentation
Create Variable
Next step is to create a Cloud variable, which we will later interact with in our JavaScript code.
- While in Thing configuration, click on "Add Variable" which will open a new window.
- Name your variable 
 and select it to be of antest_value
 type.int
- Click on "Add Variable" at the bottom of the window.
You should now have a variable named
test_value- Learn more about how variables work in the Variables documentation
Variables that we create here can also be synchronized with variables running on any other device in the platform. This makes it possible to link an Arduino boards with a Python or JavaScript project without writing any connection code!
JavaScript Setup
Before continuing, make sure you have a version of node.js installed. You can check that it is installed by opening a terminal and running:
1node -vInstall NPM Package
The arduino-iot-js library can be installed by running the following command:
1npm install arduino-iot-jsThis will install the library in your current directory. You can check that the library is installed by running
npm listExample Script
Create a file with a
.jscloud_first_test.jsBelow is a script that connects to the Cloud using the device ID and secret key that we obtained in the cloud setup section. Copy the contents into your
.js1const { ArduinoIoTCloud } = require('arduino-iot-js');2
3(async () => {4  const client = await ArduinoIoTCloud.connect({5    deviceId: 'YOUR_DEVICE_ID',6    secretKey: 'YOUR_SECRET_KEY',7    onDisconnect: (message) => console.error(message),8  });9
10  const value = 20;11  let cloudVar = "test_value"12
13  client.sendProperty(cloudVar, value);14  console.log(cloudVar, ":", value);15
16  client.onPropertyValue(cloudVar, (value) => console.log(cloudVar, ":", value));17})();
 - update a variable in the Cloud,- sendProperty(cloudVar, value)
 - when receiving an update from the Arduino Cloud, updates the- onPropertyValue(cloudVar, (value))
 variable.- value
This example simply sends an update to the Arduino Cloud (updating the value of
test_value20You can test out the
test_valueWhen entering a new number, you should see the following command being printed in the terminal:
1test_value : <value>For creating dashboards and linking variables, check out the Dashboard & Widgets documentation.
Troubleshooting
 - the package is not installed/accessible from your current directory. Double check that your directory is correct and that you have successfully installed the package.- Error: Cannot find module
 - likely due to wrong credentials (device ID / secret key). Double check these parameters.- Error: connection failed: client not connected
Suggested changes
The content on docs.arduino.cc is facilitated through a public GitHub repository. You can read more on how to contribute in the contribution policy.
License
The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.
 
   
  