David Johnson wrote:
Thanks for the help. I think I understand, however, I think I might be
missing something. You specified that you would get a URL such as:
http://www.taupro.com/venture/IBM/ledger/100
This looks good, but it seems that the object is not persistent, and a
restart of the server would cause the URL to be invalid. Am I understanding
correctly? This also seems to be for a relatively small number of objects,
since you are creating objects on the fly. A larger number of objects may
consume the memory.
No, actually the objects ARE persistent, just not in the ZODB.
When Zope3 traveral reaches the "venture" folder, which is a ZODB-persistent
object with one attribute of a "RDB connection name", that connection name
is looked up and turned into a volatile "RDB connection instance". Then a
query to obtain the items in the folder is translated into SQL queries whose
responses are wrapped in non-persistent classes.
To continue the example the traversal engine then picks the "IBM" object,
which both acts as a folder representing a business venture -and- has
attributes about IBM, such as legalname and such. The "IBM" venture object
is transient in memory but recreated as needed. Since the Zope3 component
"SQLMethod" I build on caches the SQL query and response, recreation takes
little time for each successive traversal.
Now when the traversal engine queries the "IBM" object for its members, that
object returns a brief canned list of magic subfolders, such as ledger,
journal, transaction, statements, etc. These are transient classes as well,
that appear as folders to Zope3. So in this case it returns the "ledger"
folder object.
And then when the traversal engine queries the "ledger" object for ledger
#100, the ledger transient object has retained as an attribute from its
creation a reference to its parent, as part of the ILocation interface.
Using such explicit locational acquisition, the ledger object can issue an
SQL query, contextualized by the parent(s) to look for ledger #100 -OF THE
VENTURE IBM-, and wrap that response in a transient Ledger class as well.
And now we can locate and return views based on the ILedger interface.
-Jeff
_______________________________________________
Zope3-users mailing list
Zope3-users@zope.org
http://mail.zope.org/mailman/listinfo/zope3-users