You can provide configuration data for multiple Microvisor-empowered IoT devices using the Config resource. Configs are intended as a way to upload data such as API keys, PKI certificates, and other items to the Twilio cloud so they need not be baked into application code. Instead, the application code running on the device retrieves the Config when it needs the information.
Each Config is a key:value pair which your application code can access using Microvisor System Calls.
Keys are text identifiers of up to 100 characters in length. They must be unique for a given account.
Values must also be supplied as text, of up to 4096 characters in length. If you wish to make binary data available to your devices, you will need to encode it as text before creating the Config. For example, you might used base64 encoding. Your application must decode the value back to binary after acquiring it from the Twilio cloud.
Config resources are accessed at this endpoint:
https://microvisor.twilio.com/v1/Configs
Config resources are accessible from all devices associated with an account. For Configs that are made available to specific devices, please see Device Configs.
It is possible for anyone with account access to read back the value of any Config. If you have information which, once created, you would not like to be accessible to other account holders, use Secrets, which are, from the API perspective, write- and delete-only.
POST https://microvisor.twilio.com/v1/Configs
application/x-www-form-urlencoded
1// Download the helper library from https://www.twilio.com/docs/node/install2const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";34// Find your Account SID and Auth Token at twilio.com/console5// and set the environment variables. See http://twil.io/secure6const accountSid = process.env.TWILIO_ACCOUNT_SID;7const authToken = process.env.TWILIO_AUTH_TOKEN;8const client = twilio(accountSid, authToken);910async function createAccountConfig() {11const accountConfig = await client.microvisor.v1.accountConfigs.create({12key: "key_name",13value: "value",14});1516console.log(accountConfig.key);17}1819createAccountConfig();
1{2"key": "key_name",3"value": "value",4"date_updated": "2021-01-01T12:34:56Z",5"url": "https://microvisor.twilio.com/v1/Configs/first"6}
GET https://microvisor.twilio.com/v1/Configs/{Key}
The config key; up to 100 characters.
1// Download the helper library from https://www.twilio.com/docs/node/install2const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";34// Find your Account SID and Auth Token at twilio.com/console5// and set the environment variables. See http://twil.io/secure6const accountSid = process.env.TWILIO_ACCOUNT_SID;7const authToken = process.env.TWILIO_AUTH_TOKEN;8const client = twilio(accountSid, authToken);910async function fetchAccountConfig() {11const accountConfig = await client.microvisor.v112.accountConfigs("Key_name")13.fetch();1415console.log(accountConfig.key);16}1718fetchAccountConfig();
1{2"key": "Key_name",3"value": "place",4"date_updated": "2021-01-01T12:34:57Z",5"url": "https://microvisor.twilio.com/v1/Configs/first"6}
DELETE https://microvisor.twilio.com/v1/Configs/{Key}
The config key; up to 100 characters.
1// Download the helper library from https://www.twilio.com/docs/node/install2const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";34// Find your Account SID and Auth Token at twilio.com/console5// and set the environment variables. See http://twil.io/secure6const accountSid = process.env.TWILIO_ACCOUNT_SID;7const authToken = process.env.TWILIO_AUTH_TOKEN;8const client = twilio(accountSid, authToken);910async function deleteAccountConfig() {11await client.microvisor.v1.accountConfigs("key_name").remove();12}1314deleteAccountConfig();