NAME

RFID::EPC::Tag - An EPC tag.

SYNOPSIS

This class implements an EPC tag based on RFID::Tag. It allows tags to be created based on the fields of the various EPC tag types, and allows tag IDs to be parsed into their EPC components.

Generally, you'll get these objects returend from an EPC RFID reader:

    use RFID::Gumbo::Reader::TCP;
    my $reader = 
      RFID::Gumbo::Reader::TCP->new(PeerAddr => 10.20.30.40,
                                    PeerPort => 4001)
        or die "Couldn't create Blammo reader";
    my @tags = $reader->readtags();
    foreach my $tag (@tags)
    {
	if ($tag->type eq 'epc')
	{
	    my $epc_type = $tag->get('epc_type');
	    print "I see EPC tag ",$tag->id," of type $epc_type\n";
	}
    }

But you can also create a tag yourself, either with an ID string:

my $tag = RFID::EPC::Tag->new(id => '357777777666666999999999');

or with the various componenets:

    my $tag =
      RFID::EPC::Tag->new(epc_serial => '999999999',
			  epc_manager => '7777777',
			  epc_class => '666666',
			  epc_type => 'GID-96');
    print "Tag ID is ",$tag->id,"\n";

DESCRIPTION

The parsing and tag creation in this module are based on the specifications in EPCGlobal's EPC Tag Data Standards Version 1.1 Rev.1.24, from April 1st 2004 (although it doesn't appear to be a joke...). See http://www.epcglobalinc.com/ for more information.

Constructor

new

Creates a new EPC tag object with the requested properties.

There are two general ways to create an EPC tag. First, you can pass in the tag ID number as a hex string with the parameter name id. Second, you can pass in various components specific to your Tag Type, including at least epc_type.

    my $tag1 = RFID::EPC::Tag->new(id => '357777777666666999999999');

    my $tag2 =
      RFID::EPC::Tag->new(epc_serial => '999999999',
			  epc_manager => '7777777',
			  epc_class => '666666',
			  epc_type => 'GID-96');

    print "The two tags are ",
          ($tag1->tagcmp($tag2)==0?"the same":"different"),
          "\n";

Methods

The following methods are supported. In addition, methods from RFID::Tag are inherited.

get

Get a property of this tag. In addition to the properties inherited from RFID::Tag, the following fields are supported. Note that whether a particular field is supported depends on the tag type. All fields are represented as hex strings.

epc_type

The EPC type of this tag.

epc_serial

The EPC serial number of this tag.

epc_manager

The EPC manager number of this tag.

epc_class

The EPC class of this tag.

epc_header

The EPC header bits for this tag.

epc_filter

The EPC filter for this tag.

epc_partition

The EPC partition number for this tag. This field determines the size of later fields; see the EPC specification for more information.

epc_item

The EPC item number for this tag.

epc_company

The EPC company number for this tag.

epc_asset_type

The EPC asset type number for this tag.

epc_location

The EPC location number for this tag.

epc_asset

The EPC asset number for this tag.

epc_unknown

For tags of unrecognized type, all of the bytes that could not be parsed.

type

This method returns the general type of this tag (always epc).

Tag Types

The EPC Tag Data Standards document defines many specific types of EPC tags. We do our best to parse these out, and return the appropriate fields. This isn't very well tested, since we don't have access to a large number of different types of EPC tags, but it tries to follow the spec, and should be easy to correct if any errors are found.

The purpose of the fields is beyond the scope of this document; we assume you know what the fields are for, and just want to know what names they are given in this code. Mostly that's because it took EPC 78 pages to describe exactly what the tag types are, and I don't want to repeat that here. Look up the EPC Tag Data Standards document referenced at the top of this documentation for more information.

GIAI-64

64-bit Global Individual Asset Identifier. Fields are epc_header, epc_filter, epc_company, epc_asset.

GIAI-96

96-bit Global Individual Asset Identifier. Fields are epc_header, epc_filter, epc_partition, epc_company, epc_asset.

GID-96

96-bit General Identifier. Fields are epc_header, epc_manager, epc_class, epc_serial.

GRAI-64

64-bit Global Returnable Asset Identifier. Fields are epc_header, epc_filter, epc_company, epc_asset_type, epc_serial.

GRAI-96

96-bit Global Returnable Asset Identifier. Fields are epc_header, epc_filter, epc_partition, epc_company, epc_asset_type, epc_serial.

SGLN-64

64-bit Serialized Global Location Number. Fields are epc_header, epc_filter, epc_company, epc_location, epc_serial.

SGLN-96

96-bit Serialized Global Location Number. Fields are epc_header, epc_filter, epc_partition, epc_company, epc_location, epc_serial.

SGTIN-64

64-bit Serialized Global Trade Identification Number. Fields are epc_header, epc_filter, epc_company, epc_item, epc_serial.

SGTIN-96

96-bit Serialized Global Trade Identification Number. Fields are epc_header, epc_filter, epc_partition, epc_company, epc_item, epc_serial.

SSCC-64

64-bit Serial Shipping Container Code. Fields are epc_header, epc_filter, epc_company, epc_serial.

SSCC-96

96-bit Serial Shipping Container Code. Fields are epc_header, epc_filter, epc_partition, epc_company, epc_serial, epc_unallocated.

UNKNOWNx-64

64-bit tag without any type recognized by this software, but with a header indicating it is 64 bits. Fields are epc_header and epc_unknown.

UNKNOWN-96

96-bit tag without any type recognized by this software, but with a header indicating it is 96 bits. Fields are epc_header and epc_unknown.

UNKNOWN

Tag without any type recognized by this software, and with no indication of its size in the header. Fields are epc_header and epc_unknown.

SEE ALSO

RFID::Tag, RFID::Reader, http://www.eecs.umich.edu/~wherefid/code/rfid-perl/, http://www.epcglobalinc.com/, The manual for your particular RFID reader.

AUTHOR

Scott Gifford <gifford@umich.edu>, <sgifford@suspectclass.com>

Copyright (C) 2004 The Regents of the University of Michigan.

See the file LICENSE included with the distribution for license information.