[Zope] POSKeyError
Dieter Maurer
dieter@handshake.de
Wed, 28 May 2003 23:28:01 +0200
Jeremy M. Smith wrote at 2003-5-27 15:36 -0700:
> ...
> With this one folder, I get a POSKeyError. After researching this
> problem online, I used the fsrefs.py utility to determine which object
> it is that's not being found, but I can't figure out how to either a)
> get that object back (since I can't access the management screens due to
> the error) or b) remove the invalid references. I have seen some
> references to truncating (a copy of) the Data.fs just before the
> transaction that causes the error, but I haven't found any instructions
> on how to do this.
You know that you can access the ZODB outside of Zope?
For this to be possible, you must either stop Zope or use ZEO.
It then looks like this (I assume a Unix setup with "bash";
the shell commands are different for Windows):
# you are inside your Zope directory
export PYTHONPATH=$PYTHONPATH:$PWD/lib/python
python
from Zope import app
root= app() # "root" contains your root object
obj= root.unrestrictedTraverse(url_to_obj)
# assume, "obj" now contains the folder with the dangling
# reference; we must find the id belonging to the reference
for id,val in obj.objectItems():
try: val.getId()
except POSKeyError: break
# "id" should now contain the id with the broken object
# we give it a new one
obj._setOb(id,DTMLMethod('',__name__=id))
# now we delete it
obj.manage_delObject(id)
# commit
get_transaction().commit()
The script is not complete. You must import "POSKeyError" and
"DTMLMethod" and provide "url_to_obj".
Dieter