1.14 IFTTT Demo
This example application demosntrates how we can generate a trigger to IFTTT web platform to make it perform a specific action like sending a mail/ sms etc using an applet.
Description
IFTTT is short for "If This Then That". IFTTT is a third-party web platform which uses applets for performing specific actions when they are triggered via a connection. This application demonstrates how a user can trigger a pre-existing applet. The application shall come up in STA mode, and will establish a TLS connection with maker.ifttt.com. It shall send a trigger every time the button (SW1) on the Curiosity Board is pressed.
Downloading and building the application
To download or clone this application from Github, go to the top level of the repository
Path of the application within the repository is apps/ifttt/firmware .
To build the application, refer to the following table and open the project using its IDE.
| Project Name | Description | 
|---|---|
| pic32mz_w1_curiosity_freertos.X | MPLABX project for PIC32MZ W1 Curiosity Board | 
Creating an Applet on IFTTT web platform
IFTTT is a third-party web platform, and one can create an applet of their own. More details on how one can use IFTTT and create their own applets can be found at https://help.ifttt.com/hc/en-us/articles/360021401373-Creating-your-own-Applet
More details on how to use a webhook applet in IFTTT can be found in the Appendix of this document.
Setting up PIC32MZ W1 Curiosity Board
- Connect the Debug USB port on the board to the computer using a micro USB cable to power on the board. 
- On the GPIO Header (J207), connect U1RX (PIN 13) and U1TX (PIN 23) to TX and RX pin of any USB to UART converter 
- Home AP (Wi-Fi Access Point with internet connection) 
Running the Application
- Open the project and launch Harmony3 configurator. 
- Configure home AP credentials for STA Mode.  
- Save configurations and generate code via MHC. 
- Currently application expects the user to create an applet at the IFTTT web platform and configure the relevant details related to the applet in the app.c file. These details will help in creating the trigger which we send to make the applet perform the action. 
- The user would need to populate the following - Parameter Name - Default Value - Description - IFTTT_EVENT_TYPE - IFTTT_EVENT_BUTTON_PRESS - The IFTTT applet can be triggered in two ways via this application - by pressing the button on the board (IFTTT_EVENT_BUTTON_PRESS), or by running a timer (IFTTT_EVENT_PERIODIC_TIMER) and sending the trigger periodically. The default event type is button press to trigger the applet. - IFTTT_EVENT_PERIOIDC_TIMER_TIMEOUT - 100 sec - This parameter is used for setting the timeperiod in sec, after which a periodic trigger will be generated. This is valid only when the IFTTT_EVENT_TYPE has been set to IFTTT_EVENT_PERIODIC_TIMER - IFTTT_EVENT - "YOUR_EVENT" - This is a mandatory parameter to be filled in by the user, and is the 'event' which triggers the applet. This 'event' was used while creating the applet at the IFTTT web platform. - IFTTT_KEY - "YOUR_KEY" - This is a mandatory parameter to be filled in by the user, and is the the 'key' which is generated after the creation of the applet at the IFTTT web platform. - IFTTT_NUM_OF_VALUES - 1 - The IFTTT applet can use upto 3 values/ data while performing an action. This parameter indicates the number of values which this application needs to send along with the trigger. - IFTTT_VALUE1 - "Value1" - Data Value1 that needs to be sent along with the trigger. - IFTTT_VALUE2 - "Value2" - Data Value2 that needs to be sent along with the trigger. - IFTTT_VALUE3 - "Value3" - Data Value3 that needs to be sent along with the trigger. - IFTTT_USER_CALLBACK - NULL - In case users want to process some data and based on the result want to dynamically decide if the trigger needs to be sent or not, they will need to map this parameter to APP_IFTTT_Callback() function and implement the action inside this function. This function is expected to return a true if the trigger needs to be sent, else false based on the processing of the data relevant to the user application. For example the user may be implementing a temperature sensor and would want to poll periodically for the temperature but send in a trigger only when the temperature crosses certain threshold. In such a case, implementing this function accordingly can help achive the above objective. Also, there can be requirement that the user needs to also send in the sensed temperature value with the trigger, which can be populated in the 'Value1' and sent. - IFTTT_USER_CALLBACK_CTX - NULL - Callback context/ parameter which will be passed on to APP_IFTTT_Callback(). This could a structure pointer which contains the data to be processed and decide if the trigger needs to be sent. 
- Build and program the generated image into the hardware using the IDE. 
- Open the terminal application(Ex:Tera term) on the computer. 
- Connect to the COM port related to the external USB-UART connected to the GPIO heade and configure the serial settings as follows: - Baud : 115200 
- Data : 8 Bits 
- Parity : None 
- Stop : 1 Bit 
- Flow Control : None 
 
- The Board will connect to Home AP.  
- Every time the button/ switch (SW1) is pressed , - it shall connect to maker.ifttt.com and send the trigger.  
- This Trigger will be received by the ifttt server which will invoke the applet. Let us assume the user created an applet using webhooks which shall 'send an email' as an action. The email could look something like this:  
- Every time a trigger is being sent by the Curiosity Board, the red LED on the board will be ON, and it will go OFF once the trigger request has been successfully trasmitted to IFTTT server. Any new request while the LED is ON will not be honoured. Hence, it is receommended to press the button for a new request only when the red LED has gone OFF. 
Appendix
Creating a Webhook applet on IFTTT web platform.
- Create an IFTTT account. 
- Sign in to the account. 
- Click "Create" on the right side toolbar to create an applet  
- Clock on 'Add' and choose "webhooks"   
- Choose a trigger - 'Receive a webrequest'  
- Fill in the event name and create a 'trigger'.Copy the event and past it to parameter IFTTT_EVENT in the demo code.  
- Add the action - could be sending an 'email'   
- Set the action fields. In case of 'email' it could be subject and body of the mail.  
- 'Finish' the applet.  
- Goto webhooks settings (https://ifttt.com/maker_webhooks/setting)  
- The string after the https://maker.ifttt.com/use/ in the URL is the 'Key' needed by the Demo Application. Copy the key and pasted it to parameter IFTTT_KEY in the demo code. 
