IResultSet is missing several methods that exist on ResultSet
Bug #659883 reported by
Gavin Panella
This bug affects 1 person
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
Storm |
Fix Released
|
Low
|
Gavin Panella |
Bug Description
The following names appear to be missing:
difference
find
get_select_expr
group_by
having
intersection
remove
set
union
Related branches
lp://staging/~allenap/storm/interface-rationale-bug-659883
- Michael Hudson-Doyle: Approve
- Jamu Kakar (community): Approve
-
Diff: 37 lines (+27/-0)1 file modifiedstorm/zope/interfaces.py (+27/-0)
Changed in storm: | |
assignee: | nobody → Gavin Panella (allenap) |
importance: | Undecided → Low |
milestone: | none → 0.18 |
status: | Incomplete → Fix Committed |
Changed in storm: | |
status: | Fix Committed → Fix Released |
To post a comment you must log in.
This bug is essentially a superset of bug 431203, which I marked incomplete and haven't seen any further activity on.
The rationale behind the exposed attributes is:
1. your model code constructs a ResultSet and returns a security proxied object to the view code.
2. the view code treats the ResultSet as an immutable sequence/iterable and presents the data to the user.
Both set() and remove() can be used to modify the contained objects, which will bypass the security proxies on those objects.
get_select_expr() will return a Select object, which has no security declarations (and it isn't clear that any would be desirable).
find(), group_by() and having() are really used to configure result sets, so are mostly intended for use on the model side.
I could see an argument for exposing difference(), intersection() and union() as a way for view code to combine multiple results, but it isn't clear how often it makes sense to do this on the view side rather than model side.
If my analysis is wrong, please explain what it is you want to do and how the current security declarations are preventing you from doing so. Simply stating that some methods are not exposed doesn't really give enough information to respond to the bug report.