Skip to main content

RFID reader control library

Project description

http://img.shields.io/pypi/v/sllurp.svg https://img.shields.io/pypi/pyversions/sllurp.svg https://github.com/sllurp/sllurp/actions/workflows/test.yml/badge.svg

sllurp is a Python library to interface with RFID readers. It is a pure-Python implementation of the Low Level Reader Protocol (LLRP).

These readers are known to work well with sllurp, but it should be adaptable with not much effort to other LLRP-compatible readers:

  • Impinj Speedway (R1000)

  • Impinj Speedway Revolution (R220, R420)

  • Impinj Speedway xPortal

  • Motorola MC9190-Z (handheld)

  • Zebra Fixed RFID Reader (FX7500, FX9600)

File an issue on GitHub if you would like help getting another kind of reader to work.

sllurp is distributed under version 3 of the GNU General Public License. See LICENSE.txt for details.

Quick Start

Install from PyPI:

$ python3 -m venv .venv
$ source .venv/bin/activate
$ pip install sllurp
$ sllurp inventory ip.add.re.ss

Run sllurp --help and sllurp inventory --help to see options.

Or install from GitHub:

$ git clone https://github.com/sllurp/sllurp.git
$ cd sllurp
$ python3 -m venv .venv
$ source .venv/bin/activate
$ pip install .
$ sllurp inventory ip.add.re.ss

If the reader gets into a funny state because you’re debugging against it (e.g., if your program or sllurp has crashed), you can set it back to an idle state by running sllurp reset ip.add.re.ss.

Reader API

sllurp spawn his own “thread” to manage network interaction with the reader. To make a connection, create a LLRPReaderClient and connect() it:

# Minimal example; see sllurp/verb/inventory.py for more.
from sllurp import llrp
from sllurp.llrp import LLRPReaderConfig, LLRPReaderClient, LLRP_DEFAULT_PORT
import logging
logging.getLogger().setLevel(logging.INFO)

def tag_report_cb (reader, tag_reports):
    for tag in tag_reports:
        print('tag: %r' % tag)

config = LLRPReaderConfig()
reader = LLRPReaderClient(host, LLRP_DEFAULT_PORT, config)
reader.add_tag_report_callback(tag_report_cb)

reader.connect()
# We are now connected to the reader and inventory is running.

try:
    # Block forever or until a disconnection of the reader
    reader.join(None)
except (KeyboardInterrupt, SystemExit):
    # catch ctrl-C and stop inventory before disconnecting
    reader.disconnect()

Getting More Information From Tag Reports

When initializing LLRPReaderConfig, set flags in the tag_content_selector dictionary argument:

llrp.LLRPReaderConfig({
    'tag_content_selector': {
        'EnableROSpecID': False,
        'EnableSpecIndex': False,
        'EnableInventoryParameterSpecID': False,
        'EnableAntennaID': True,
        'EnableChannelIndex': False,
        'EnablePeakRSSI': True,
        'EnableFirstSeenTimestamp': False,
        'EnableLastSeenTimestamp': True,
        'EnableTagSeenCount': True,
        'EnableAccessSpecID': False,
    }
})

Logging

sllurp logs under the name sllurp, so if you wish to log its output, you can do this the application that imports sllurp:

sllurp_logger = logging.getLogger('sllurp')
sllurp_logger.setLevel(logging.DEBUG)
sllurp_logger.setHandler(logging.FileHandler('sllurp.log'))
# or .setHandler(logging.StreamHandler()) to log to stderr...

Vendor Extensions

sllurp has limited support for vendor extensions through LLRP’s custom message facilities. For example, sllurp inventory –impinj-search-mode N allows you to set the Impinj search mode to single target (1) or dual target (2).

Handy Reader Commands

To see what inventory settings an Impinj reader is currently using (i.e., to fetch the current ROSpec), ssh to the reader and

> show rfid llrp rospec 0

The “nuclear option” for resetting a reader is:

> reboot

If You Find a Bug

Start an issue on GitHub! Please follow Simon Tatham’s guide on writing good bug reports.

Bug reports are most useful when they’re accompanied by verbose error messages. Turn sllurp’s log level up to DEBUG, which you can do by specifying the -d command-line option to sllurp. You can log to a logfile with the -l [filename] option. Or simply put this at the beginning of your own code:

import logging
logging.getLogger('sllurp').setLevel(logging.DEBUG)

Known Issues

Reader mode selection is confusing, not least because most readers seem to conflate ModeIndex and ModeIdentifier. If you’re using sllurp inventory, use --mode-identifier N. Check your reader’s manual to see what mode identifiers it supports via the C1G2RFControl parameter, or run sllurp --debug inventory against a reader to see a dump of the supported modes in the capabilities description.

Contributing

Want to contribute? Here are some areas that need improvement:

  • Encode more protocol messages in the construct branch.

  • Write tests for common encoding and decoding tasks.

Authors

Much of the code in sllurp is by Ben Ransford, although it began its life in August 2013 as a fork of LLRPyC. Many fine citizens of GitHub have contributed code to sllurp since the fork, including Florent Viard, Bogdan-Marius Pradatu, Jonas Gröger, and Qifan Lu.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sllurp-3.0.5.tar.gz (71.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sllurp-3.0.5-py3-none-any.whl (67.0 kB view details)

Uploaded Python 3

File details

Details for the file sllurp-3.0.5.tar.gz.

File metadata

  • Download URL: sllurp-3.0.5.tar.gz
  • Upload date:
  • Size: 71.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sllurp-3.0.5.tar.gz
Algorithm Hash digest
SHA256 3360079a0804989e249f039fddb9ee9f9a32dec0bd77d48ca50a02382605d367
MD5 48a0afa23b08c2934041961c87c75317
BLAKE2b-256 60fc8bff260973854af03bc5e79afeb1e60c4b3def93b74b106c45ea76f13a63

See more details on using hashes here.

Provenance

The following attestation bundles were made for sllurp-3.0.5.tar.gz:

Publisher: publish-to-pypi.yaml on sllurp/sllurp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sllurp-3.0.5-py3-none-any.whl.

File metadata

  • Download URL: sllurp-3.0.5-py3-none-any.whl
  • Upload date:
  • Size: 67.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sllurp-3.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 0c013b530e9759d9cc64f917b07ab72faf4c0e6eb1aa34ab77407ed8f00b7a08
MD5 08897d2a6853079a96bea442ec0a145e
BLAKE2b-256 3a7767621db07a7793d82c43c5b8e6f9082edd0db70a45424e1e653d4bbd8571

See more details on using hashes here.

Provenance

The following attestation bundles were made for sllurp-3.0.5-py3-none-any.whl:

Publisher: publish-to-pypi.yaml on sllurp/sllurp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page