This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.

Dependencies:   NDefLib X_NUCLEO_NFC01A1 mbed

Fork of X-MBED-NFC1 by Giovanni Visentini

This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.

The available demos are:

  • SAMPLE_WRITE_URL: write a tag with the ST home page URL
  • SAMPLE_COUNT_CLICK: create a custom tag to count and report the user button clicks.
  • SAMPLE_WRITE_AND_CHANGE_ALL: write a tag with all the supported records and update the tag contents when the user button is pressed.
  • SAMPLE_LOCK_TAG_CONTENT: use the M24SR component API to set the NFC tag as read-only.

To enable the different demos comment/uncomment the SAMPLE_* macros provided in main.cpp .

Samples/SampleSync_lockWriteTag.cpp

Committer:
giovannivisentini
Date:
2016-08-31
Revision:
15:94c98d2aa235
Parent:
14:3b604972b89f
Child:
17:d8d3d2088cac

File content as of revision 15:94c98d2aa235:

/**
  ******************************************************************************
  * @file       Sample_lockWriteTag.cpp
  * @author     ST / Central Labs
  * @date       03 Dic 2015
  * @brief      This demo define a lock/unlock the tag content when the user press
  *  the user button
  ******************************************************************************
  *
  * COPYRIGHT(c) 2015 STMicroelectronics
  *
  * Redistribution and use in source and binary forms, with or without modification,
  * are permitted provided that the following conditions are met:
  *   1. Redistributions of source code must retain the above copyright notice,
  *      this list of conditions and the following disclaimer.
  *   2. Redistributions in binary form must reproduce the above copyright notice,
  *      this list of conditions and the following disclaimer in the documentation
  *      and/or other materials provided with the distribution.
  *   3. Neither the name of STMicroelectronics nor the names of its contributors
  *      may be used to endorse or promote products derived from this software
  *      without specific prior written permission.
  *
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  *
  ******************************************************************************
  */

#include "mbed.h"

#include "X_NUCLEO_NFC01A1.h"

static volatile bool buttonPress=false;

static void setButtonPress(){
    buttonPress=true;
}//if buttonPress

/**
 * return the led that tell if the tag is read only
 * @param nfcNucleo board where the lead lives
 * @return let to switch on if the tag is read only
 */
static inline DigitalOut& getReadOnlyLed(X_NUCLEO_NFC01A1 *nfcNucleo){
	return nfcNucleo->getLed2();
}

/**
 * return the led that tell if the tag is write only
 * @param nfcNucleo board where the lead lives
 * @return let to switch on if the tag is write only
 */
static inline DigitalOut& getWriteableLed(X_NUCLEO_NFC01A1 *nfcNucleo){
	return nfcNucleo->getLed3();
}

/**
 * set the tag as read only and switch the led on
 * @param nfcNucleo board where the lead lives
 * @param tag helper class to manage the nfc tag
 * @return true if the change has effect
 */
bool enableReadOnly( X_NUCLEO_NFC01A1 *nfcNucleo){

	if(nfcNucleo->getM24SR().EnableReadOnly(M24SR::DEFAULT_PASSWORD)){
		printf("Enable Read Only\r\n");
		getReadOnlyLed(nfcNucleo)=true;
		getWriteableLed(nfcNucleo)=false;
		return true;
	}else
		return false;
}

/**
 * set the tag as read/write and switch the led on
 * @param nfcNucleo board where the lead lives
 * @param tag helper class to manage the nfc tag
 * @return true if the change has effect
 */
bool disableReadOnly( X_NUCLEO_NFC01A1 *nfcNucleo){

	if(nfcNucleo->getM24SR().DisableReadOnly(M24SR::DEFAULT_PASSWORD)){
		printf("Disable Read Only\r\n");
		getReadOnlyLed(nfcNucleo)=false;
		getWriteableLed(nfcNucleo)=true;
		return true;
	}else
		return false;
}

void sampleSync_lockTagContent() {
	Serial console(SERIAL_TX, SERIAL_RX);

    I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
    i2cChannel.frequency(400000);

    X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel);
    
    NDefLib::NDefNfcTag &tag = nfcNucleo->getM24SR().getNDefTag();

    //when the user press the button set buttonPress to true
    InterruptIn userButton(USER_BUTTON);
    userButton.fall(setButtonPress);
	
	printf("Init Done\r\n");
	
    //restore the board as read/write
    tag.openSession(true);
    nfcNucleo->getM24SR().DisableAllPassword(M24SR::DEFAULT_PASSWORD);
    tag.closeSession();
    getReadOnlyLed(nfcNucleo)=false;
    getWriteableLed(nfcNucleo)=true;
    bool tagIsLock=false;
	
	printf("All Protection removed\r\n");
	
	nfcNucleo->getLed1()=true;
    while(true){

        if(buttonPress){
        	if(tag.openSession()){
        		bool changeStatusResult;

				if(!tagIsLock)
					changeStatusResult=enableReadOnly(nfcNucleo);
				else
					changeStatusResult=disableReadOnly(nfcNucleo);

				if(changeStatusResult)
					tagIsLock=!tagIsLock;
				else
					console.printf("Error change the tag status");
				tag.closeSession();
        	}else{
        		console.printf("Error opening the session, tag is in use");
        	}
        	buttonPress=false;
        }//if

        //wait next event
        __WFE();
    }//while

}//sample_countClick