3

我正在编写一个用于保留不同资源的 Plone 日历模块。该模块具有一个日历,其事件存储在 Postgresql 中。每个日历都是存储在 ZODB 中的 Dexterity 对象。

为了在 Plone 和 Postgresql 之间建立联系,我自然而然地转向了 Plone 对象的 uuid 属性。因此,Plone 中的每个 uuid 都作为 Postgresql 中的外键,后者原生支持 uuid。

在我开始使用 Plone 4.1.4 之前,这对我来说在过去的 6 个月里效果很好。有了它,plone.uuid 1.0.2 被引入,它将 uuid 的字符串表示从 uuid 更改为不带破折号的 uuid 。

这种变化的问题是我不能再确定在任何给定对象上将使用哪种表示。在 Plone 4.1.4 之前创建的对象包含与之后创建的对象不同格式的 uuid 字符串。

长话短说,为了确保我的代码适用于任何 uuid 表示,我希望能够使用 Python 的 uuid 类型进行搜索。

所以代替这个:

catalog.searchResults(UID='325dc47e-08f9-4fa1-bc18-3944a725adb4')

它返回与此不同的结果:

catalog.searchResults(UID='325dc47e08f94fa1bc183944a725adb4')

我很想这样做:

from uuid import UUID
catalog.searchResults(UID=UUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))

相当于

catalog.searchResults(UID=UUID('325dc47e08f94fa1bc183944a725adb4'))

有谁知道我如何从 uuid 在 Plone 中的表示中实现这种独立性?

4

1 回答 1

4

您必须同时查询这两种格式;一旦分配了 UID 字段,它就不应更改,真的。因此,您的选择是:

  1. 创建一个给定 UID 的方法,该方法返回一个包含虚线和非虚线版本的元组,然后用于查询目录:

    def queryUID(UID):
        if '-' in UID:
            return (UID.replace('-', ''), UID)
        return (UID, '-'.join([
            UID[:8], UID[8:12], UID[12:16], UID[16:20], UID[20:]]))
    

    使用该方法,查询就变成了:

    catalog.searchResults(UID=queryUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))
    
  2. 让您的数据库使用 Plone UID 有破折号的破折号版本,旧的 Plone 内容仍然有一个没有破折号的 UID 的非破折号版本。换句话说,将 UID 视为不透明的字符串。

    Plone 中的 UID 在任何情况下都不会更改,因此当生成虚线版本时,您不必搜索非虚线版本。一旦一个 UID 被分配给一个对象,它就永远不会改变,也永远不会获得破折号。

  3. 不推荐遍历您的 ZODB 并将所有不带破折号的 UID 替换为虚线等效项。这很可能会破坏通过 UID 链接到这些项目的任何其他内容。

于 2012-04-13T13:22:00.223 回答