virtualpathresolver
(prefix
)When implementing Virtual Source Objects it's important that you can locate them. While virtual sources do not appear as children of pages they can be navigated to through the database pad. This is achieved through custom virtual path resolvers.
Each source object needs to be a unique prefix which identifies all instances
of it. For instance if you want to implement a special page (like a feed)
that would exist for specific pages, then you can register the virtual path
prefix feed
with your plugin. Though you should use more descriptive names
for your plugins as these paths are shared.
If a user then resolves the page /my-page@feed
it would invoke your URL
resolver with the record my-page
and an empty list (rest of the path
segments). If they would request /my-page@feed/recent
then it would
pass ['recent']
as path segments.
Here an example that would implement a virtual source for feeds and an associated virtual path resolver:
from lektor.sourceobj import VirtualSourceObject
from lektor.utils import build_url
class Feed(VirtualSourceObject):
def __init__(self, record, version='default'):
VirtualSourceObject.__init__(self, record)
self.version = version
@property
def path(self):
return '%s@feed%s' % (
self.record.path,
'/' + self.version if self.version != 'default' else '',
)
@property
def url_path(self):
return build_url([self.record.url_path, 'feed.xml'])
def on_setup_env(self, **extra):
@self.env.virtualpathresolver('feed')
def resolve_virtual_path(record, pieces):
if not pieces:
return Feed(record)
elif pieces == ['recent']:
return Feed(record, version='recent')
Comments