MBED_DEMOS / Mbed 2 deprecated df-2014-rfid-case-gen-k64f-exercise

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

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

main.cpp

Committer:
ansond
Date:
2014-08-27
Revision:
3:03108e424931
Parent:
0:df2aa79c64f2
Child:
4:46459ed734f3

File content as of revision 3:03108e424931:

/* 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.
 */
 
 // our definitions
 #include "Definitions.h"

 // RFID Reader - on P14 pin 
 //#include "ID12RFID.h"
 //ID12RFID rfid_reader(p14); 

 // Salesforce Case Generator
 #include "SalesForceCaseGenerator.h"
 
 // our Logger
 #include "Logger.h"
 
 // our WidgetDB
 #include "WidgetDB.h"
 
 // our LCD Panel
 #include "C12832_lcd.h"
 C12832_LCD lcd;
 
 // our Serial port
 #include "Serial.h"
 Serial pc(USBTX, USBRX);
 
 // Ethernet
 #include "EthernetInterface.h"
 EthernetInterface ethernet;
 
 // Main Entry...
 int main() {
    // create our object instances
    Logger logger(&pc,&lcd);
    
    // announce
    logger.log("DF 2014 RFID Reader\r\nVersion: %s",APP_VERSION);
    
    // initialize Ethernet
    logger.log("Initializing Ethernet...");
    ethernet.init();
    
    // get a DHCP address and bring the network interface up
    logger.log("Getting IP Address...");
    if (ethernet.connect() == 0) {
        // log our IP address (DHCP)
        logger.log("IP Address: %s",ethernet.getIPAddress());
        
        // create the WidgetDB
        WidgetDB db;
        
        // create the Salesforce Case Generator
        SalesForceCaseGenerator case_generator(&logger);
        
        /*
        // Enter the main loop
        while(true) {
            // look for a readable RFID tag
            if(rfid_reader.readable()) {
                // capture the RFID id...
                int rfid = rfid_reader.read();
                logger.log("RFID: %d found...\r\nProcessing...",rfid);
                
                // look it up in our WidgetDB... proceed only if we find something we know about...
                //char *name = db.lookupWidgetName(rfid);
                if (name != NULL) {
                    // build out a simple subject for the case
                    char subject[MAX_NAME_LENGTH+1];
                    memset(subject,0,MAX_NAME_LENGTH+1);
                    sprintf(subject,"Widget %s detected",name);
                    
                    // create and dispatch a case
                    bool success = case_generator.createCase(subject,db.lookupWidgetDescription(rfid));
                    if (success == true) {
                        logger.log("Case Generated!");
                    }
                    else {
                        logger.log("Case Generation FAILED");
                    }
                }
                else {
                    // unrecognized RFID
                    logger.log("RFID unknown. Ignoring...");
                }
             }
          
             // wait a bit and look again
             wait_ms(WAIT_TIME_MS);
          }
          
          */
          
          logger.log("Generating Sample Case...");
          bool success = case_generator.createCase("hello doug","this is a mbed case dispatch");
          if (success == true) {
            logger.log("Case Generated!");
          }
          else {
            logger.log("Case Generation FAILED");
          }
     }
     else {
         logger.log("No Network... Exiting...");
     }
     
     // disconnect
     ethernet.disconnect();
  }