ext/rest.py
changeset 6948 013f81b729de
parent 6938 6c1a960735f5
child 7577 9892937d9041
--- a/ext/rest.py	Mon Feb 07 18:19:40 2011 +0100
+++ b/ext/rest.py	Tue Feb 08 12:23:30 2011 +0100
@@ -47,6 +47,8 @@
 from cubicweb import UnknownEid
 from cubicweb.ext.html4zope import Writer
 
+from cubicweb.web.views import vid_from_rset # XXX better not to import c.w.views here...
+
 # We provide our own parser as an attempt to get rid of
 # state machine reinstanciation
 
@@ -93,6 +95,23 @@
     return [nodes.reference(rawtext, utils.unescape(rest), refuri=ref,
                             **options)], []
 
+def rql_role(role, rawtext, text, lineno, inliner, options={}, content=[]):
+    """:rql:`Any X,Y WHERE X is CWUser, X login Y:table`"""
+    _cw = inliner.document.settings.context._cw
+    text = text.strip()
+    if ':' in text:
+        rql, vid = text.rsplit(u':', 1)
+        rql = rql.strip()
+    else:
+        rql, vid = text, None
+    _cw.ensure_ro_rql(rql)
+    rset = _cw.execute(rql, {'userid': _cw.user.eid})
+    if vid is None:
+        vid = vid_from_rset(_cw, rset, _cw.vreg.schema)
+    view = _cw.vreg['views'].select(vid, _cw, rset=rset)
+    content = view.render()
+    set_classes(options)
+    return [nodes.raw('', content, format='html')], []
 
 def winclude_directive(name, arguments, options, content, lineno,
                        content_offset, block_text, state, state_machine):
@@ -288,6 +307,7 @@
         return
     _INITIALIZED = True
     register_canonical_role('eid', eid_reference_role)
+    register_canonical_role('rql', rql_role)
     directives.register_directive('winclude', winclude_directive)
     if pygments_directive is not None:
         directives.register_directive('sourcecode', pygments_directive)