Dreamforce 2014 Workshop Exercise - RFID Case Generator

Dependencies:   BufferedSerial C12832 EndpointMain-rfid EthernetInterface Logger StatusReporter-df2014 mbed-rtos mbed

Fork of df-2014-workshop-rfid-case-generator-k64f by Doug Anson

Overview

This code demonstrates how to use the mbed platform with a ID-12LA RFID reader and a Freescale K64F to get data into the SalesForce cloud.
This project was generated as a workshop for DreamForce 2014..

Details

The 2014 DreamForce workshop centers around an example scenario where you, as a street light technician, will "check in" to a given street light to service it. The street lights in this example are intelligent - they are connected, have knowledge about who/what they are, and in this example, contain an RFID sensor to allow technicians to "check in" during a service event.

The purpose of the workshop exercise is to provide exposure to new developers that the mbed IDE and development environment/ecosystem is very simple and easy to setup and use. Additionally, the workshop highlights that mbed devices can directly interact with SalesForce. The slides for the workshop can be found here.

For more information about the mbed SalesForce Interface API and its use, please see: http://developer.mbed.org/teams/MBED_DEMOS/code/SalesforceInterface/

Pretty Pictures

For the workshop the mbed team designed breakout boards to connect the ID12LA to the Freescale K64F for ease of use. Pictures of the boards can be found below. If you are interested in the breakout board you can order one from the OSHPark project page or use the eagle or gerber files as you see fit.

The ID-12LA sockets onto the RFID Brekout Board which then is put onto the Freescale K64F.

/media/uploads/mbedAustin/rfidboard_-8-.small.jpg

/media/uploads/mbedAustin/rfidboard_-9-.small.jpg

Definitions.h

Committer:
ansond
Date:
2014-09-17
Revision:
36:1318839f73f9
Parent:
29:a1067f9eb41c
Child:
46:68fc0a636266

File content as of revision 36:1318839f73f9:

/* Copyright C2014 ARM, MIT License
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
 * and associated documentation files the "Software", to deal in the Software without restriction,
 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all copies or
 * substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
 
 #ifndef _DEFINITIONS_H_
 #define _DEFINITIONS_H_
 
 // ----------------- WORKSHOP TUNABLES -----------------  
 
 // Tunables for RFID tags
 #define FIRST_WIDGET_RFID         9909120
 #define FIRST_WIDGET_NAME         "Tech 49"
 #define FIRST_WIDGET_DESCRIPTION  "Investigating Issue"
 #define SECOND_WIDGET_RFID        9909121
 #define SECOND_WIDGET_NAME        "Tech 49"
 #define SECOND_WIDGET_DESCRIPTION "Issue Resolved"
 #define THIRD_WIDGET_RFID         9909122
 #define THIRD_WIDGET_NAME         "Tech 49"
 #define THIRD_WIDGET_DESCRIPTION  "Issue Escalation"
 
 // ----------------- WORKSHOP TUNABLES ----------------- 
 
 // mbed 
 #include "mbed.h"
 
 // Our App version
 #define APP_VERSION               "1.0.0"
  
 // DF2014 CaseGenerator Relay for mbed - ties into the Salesforce APEX host for case generation
 #define DF_CASE_GEN_URL           "https://df2014-arm-developer-edition.na15.force.com/services/apexrest/CaseService"
 
 // Enable/Disable RFID ID12 usage
 #define ID12_ENABLE               true    // true - enable, false - disable
 
 // Buffer length for HTTPS requests
 #define BUFFER_LENGTH             256
 
 // maximum log message length
 #define MAX_LOG_MESSAGE           128
 
 // What platform we are compiling on
 #define _NXP_PLATFORM             false
 #define _UBLOX_PLATFORM           false
 #define _K64F_PLATFORM            true
 
 // K64F needs to launch the task in a thread with a large stack size...
 #if _K64F_PLATFORM
    #define STACK_SIZE 20000
 #endif
  
 // Wait Time for iterations (ms)
 #define WAIT_TIME_MS              500
 
 // Blink Time
 #define BLINK_TIME                250
 
 // Tunables for WidgetDB
 #define DB_MAX_NAME_LENGTH        64
 #define DB_MAX_DESCRIPTION_LENGTH 128
 #define DB_MAX_NUM_WIDGETS        3
 
 // convenience definitions for WidgetDB... 2 RFIDs/station  
 #define FIRST_WIDGET              0
 #define SECOND_WIDGET             1
 #define THIRD_WIDGET              2
 
 // PINS for RFID Reader
 #if _NXP_PLATFORM
    #define RFID_TX_PIN            p13
    #define RFID_RX_PIN            p14
 #endif
 #if _UBLOX_PLATFORM
    #define RFID_TX_PIN            P4_28
    #define RFID_RX_PIN            P4_29
 #endif
 #if _K64F_PLATFORM
    #define RFID_TX_PIN            D1
    #define RFID_RX_PIN            D0
 #endif
 
 // KEIL: our MAC address (debugging)
 //#define MAC_ADDRESS                   0xa0,0x12,0xAB,0xE3,0x4F,0x56

 #endif // _DEFINITIONS_H_