2015-12-19 14:52:17 +01:00
|
|
|
title: SourceObject
|
|
|
|
---
|
|
|
|
summary: The basic interface of all source objects.
|
|
|
|
---
|
2022-02-27 23:09:30 +01:00
|
|
|
module: lektor.sourceobj
|
2015-12-19 14:52:17 +01:00
|
|
|
---
|
|
|
|
type: class
|
|
|
|
---
|
|
|
|
body:
|
|
|
|
|
|
|
|
Source objects is the common interface for all things that come out of the
|
|
|
|
database. There are two types of source objects:
|
|
|
|
|
|
|
|
* [Records :ref](../record/) which are pages and attachments from the
|
|
|
|
`contents/` folder.
|
|
|
|
* [Assets :ref](../asset/) which are files and directories from the
|
|
|
|
`assets/` folder.
|
|
|
|
|
2018-04-17 23:16:47 +02:00
|
|
|
Whatever object you have in hand that comes from the database, they will
|
2015-12-19 14:52:17 +01:00
|
|
|
at least provide a minimal useful set of API methods and properties.
|
|
|
|
|
|
|
|
Plugins can subclass source objects to come up with their own source
|
|
|
|
objects if needed. In addition to that there is a special source object
|
|
|
|
called the `VirtualSourceObject` which is more useful for plugin usage.
|
|
|
|
|
|
|
|
## Virtual Source Objects
|
|
|
|
|
|
|
|
Most plugins will not have source objects that actually originate on the
|
|
|
|
file system. This means that their "source" is entirely virtual. Because
|
|
|
|
this is a very common situation there is a base class, the
|
|
|
|
`VirtualSourceObject` which plugins can subclass. The constructor takes one
|
2016-01-09 10:24:39 +01:00
|
|
|
argument which is the source record the virtual source lives below. Virtual
|
|
|
|
sources are separated from the records they belong to with an at sign (`@`)
|
|
|
|
in the path. The part after the at sign is called the “virtual path”.
|
|
|
|
|
|
|
|
For instance in the below example the canonical path for the object would be
|
|
|
|
the record's path + `@source`. So if the record was `/hello` then the
|
|
|
|
path would be `/hello@source`. The true base record it belongs to can be
|
|
|
|
referenced from the [record :ref](record/) property.
|
2015-12-19 14:52:17 +01:00
|
|
|
|
|
|
|
```python
|
|
|
|
from lektor.sourceobj import VirtualSourceObject
|
2016-01-09 10:24:39 +01:00
|
|
|
from lektor.utils import build_url
|
2015-12-19 14:52:17 +01:00
|
|
|
|
|
|
|
class Source(VirtualSourceObject):
|
|
|
|
|
2016-01-09 10:24:39 +01:00
|
|
|
@property
|
|
|
|
def path(self):
|
|
|
|
return self.record.path + '@source'
|
|
|
|
|
2015-12-19 14:52:17 +01:00
|
|
|
@property
|
|
|
|
def source_content(self):
|
2016-01-09 10:24:39 +01:00
|
|
|
with open(self.record.source_filename) as f:
|
2015-12-19 14:52:17 +01:00
|
|
|
return f.read().decode('utf-8')
|
|
|
|
|
|
|
|
@property
|
|
|
|
def url_path(self):
|
2016-01-09 10:24:39 +01:00
|
|
|
return build_url([self.record.url_path, 'source.txt'])
|
2015-12-19 14:52:17 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
For more information see [add-build-program
|
2016-01-09 10:24:39 +01:00
|
|
|
:ref](../../environment/add-build-program/) as well as
|
|
|
|
[virtualpathresolver :ref](../../environment/virtualpathresolver/).
|