Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

Download
ActivePython
INSTALL>
pypm install plone.uuid

How to install plone.uuid

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install plone.uuid
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
1.0.2
1.0.3Never BuiltWhy not?
1.0.2 Available View build log
1.0.1 Available View build log
1.0 Available View build log
1.0b2 Available View build log
1.0b1 Available View build log
Windows (64-bit)
1.0.2
1.0.3Never BuiltWhy not?
1.0.2 Available View build log
1.0.1 Available View build log
1.0 Available View build log
1.0b2 Available View build log
1.0b1 Available View build log
Mac OS X (10.5+)
1.0.2
1.0.3Never BuiltWhy not?
1.0.2 Available View build log
1.0.1 Available View build log
1.0 Available View build log
1.0b2 Available View build log
1.0b1 Available View build log
Linux (32-bit)
1.0.2
1.0.3Never BuiltWhy not?
1.0.2 Available View build log
1.0.1 Available View build log
1.0 Available View build log
1.0b2 Available View build log
1.0b1 Available View build log
Linux (64-bit)
1.0.3 Available View build log
1.0.2 Available View build log
1.0.1 Available View build log
1.0 Available View build log
1.0b2 Available View build log
1.0b1 Available View build log
 
Author
License
BSD
Imports
Lastest release
version 1.0.3 on Jan 9th, 2014

plone.uuid

This is a minimal package that can be used to obtain a universally unique identifier (UUID) for an object.

The default implementation uses the Python standard library uuid module to generate an RFC 4122-compliant UUID, using the uuid1() function. It will assign a UUID upon object creation (by subscribing to IObjectCreatedEvent from zope.lifecycleevent) and store it in an attribute on the object.

Why use an attribute and not annotations? The most common form of annotation is the one provided by IAttributeAnnotations. This stores annotations in a BTree in an attribute called __annotations__, which means that annotation values do not end up in the same ZODB persistent object as the parent. This is good for "large" values, but not very good for small ones that are frequently required, as it requires a separate ZODB object load.

Simple usage

To automatically assign a UUID to your objects using the default implementation outlined above, you should:

  • Make sure they implement plone.uuid.interfaces.IAttributeUUID. You can do this in code, via the implements() directive, or in ZCML, with a statement like:

    <class class="my.package.MyClass">
        <implements interface="plone.uuid.interfaces.IAttributeUUID" />
    </class>
    
  • Make sure that an IObjectCreatedEvent is fired for this object when it is first created.

Once the event handler has triggered, you can obtain a UUID by adapting the object to the IUUID interface:

from plone.uuid.interfaces import IUUID
uuid = IUUID(context)

The uuid variable will now be a (byte) string containing a UUID. If the UUID has not yet been assigned, adaptation will fail with a TypeError.

If you would rather get None instead of a TypeError, you can do:

uuid = IUUID(context, None)

UUID view

If you require a UUID in a page template or remotely, you can use the @@uuid view, which is registered for all objects that provide the IUUIDAware marker interface (which is a super-interface of the IAttributeUUID marker seen above).

For example:

<div tal:attributes="id string:uuid-${context/@@uuid}">
    ...
</div>

The view simply returns the UUID string as looked up by the IUUID adapter.

Customising behaviour

There are two primary customisation points for this package:

  • You can change the default UUID generating algorithm by overriding the unnamed utility providing the IUUIDGenerator interface. The default implementation simply calls uuid.uuid1() and casts the result to a str.

  • You can change the UUID storage by providing a custom IUUID adapter implementation. If you do this, you must also provide a mechanism for assigning UUIDs upon object creation, usually via an event handler. To obtain a UUID, use the IUUIDGenerator interface:

    from zope.component import getUtility
    from plone.uuid.interfaces import IUUIDGenerator
    
    generator = getUtility(IUUIDGenerator)
    uuid = generator()
    

    You should also make sure that instances with a UUID provide a sub-interface of plone.uuid.interfaces.IUUIDAware.

Changelog

1.0.3 (2012-05-31)
  • Use zope.browserpage. [hannosch]
  • Defensive UUID assignment in addAttributeUUID() handler: keep existing UUID value if handler called more than once, except in case of object copy event, where original and destination should have distinct UUID. [seanupton]
1.0.2 - 2011-10-18
  • Generate UUID without dashes. [elro]
1.0.1 - 2011-05-20
1.0 - 2011-05-13
  • Release 1.0 Final [esteele]
  • Add MANIFEST.in. [WouterVH]
1.0b2 - 2011-01-03
  • Add MutableUUID component [toutpt]
1.0b1 - 2010-11-27
  • Initial release

Subscribe to package updates

Last updated Jan 9th, 2014

Download Stats

Last month:1

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.