2013-10-31 18:35:03 +08:00
|
|
|
--[[
|
2013-10-31 05:10:47 +08:00
|
|
|
THIS IS WORK IN PROGREESS, very much not finished.
|
|
|
|
|
|
|
|
This library utilises other libraries under the hood, but can be used as a generic reader for 13.56MHz tags.
|
|
|
|
]]
|
|
|
|
|
|
|
|
local reader14443A = require('read14a')
|
2016-03-21 02:34:34 +08:00
|
|
|
local reader14443B = require('read14b')
|
2018-11-30 08:41:39 +08:00
|
|
|
local reader15693 = require('read15')
|
2013-10-31 05:10:47 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
-- This method library can be set waits or a 13.56 MHz tag, and when one is found, returns info about
|
|
|
|
-- what tag it is.
|
|
|
|
--
|
|
|
|
-- @return if successfull: an table containing card info
|
|
|
|
-- @return if unsuccessfull : nil, error
|
|
|
|
local function waitForTag()
|
|
|
|
print("Waiting for card... press any key to quit")
|
2013-10-31 18:35:03 +08:00
|
|
|
local readers = {reader14443A, reader14443B, reader15693}
|
|
|
|
local i = 0;
|
2013-10-31 05:10:47 +08:00
|
|
|
while not core.ukbhit() do
|
2013-10-31 18:35:03 +08:00
|
|
|
i = (i % 3) +1
|
|
|
|
r = readers[i]
|
|
|
|
print("Reading with ",i)
|
|
|
|
res, err = r.read()
|
|
|
|
if res then return res end
|
|
|
|
print(err)
|
2013-10-31 05:10:47 +08:00
|
|
|
-- err means that there was no response from card
|
|
|
|
end
|
|
|
|
return nil, "Aborted by user"
|
2013-10-31 18:35:03 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
return {
|
|
|
|
waitForTag = waitForTag,
|
|
|
|
}
|