add pipfile for installation of plugins

This commit is contained in:
Jakob Schnitzer 2021-09-18 15:56:28 +02:00
parent 86d35c13de
commit 9e76bb58dd
5 changed files with 695 additions and 10 deletions

20
Pipfile Normal file
View File

@ -0,0 +1,20 @@
[[source]]
url = "https://pypi.org/simple"
verify_ssl = true
name = "pypi"
[packages]
lektor = {git = "https://github.com/lektor/lektor"}
lektor-atom = "*"
lektor-tags = "*"
lektor-slugify = "*"
lektor-webpack-support = "*"
lektor-disqus-comments = "*"
lektor-markdown-header-anchors = "*"
lektor-markdown-highlighter = "*"
lektor-markdown-admonition = "*"
[dev-packages]
[requires]
python_version = "3.9"

340
Pipfile.lock generated Normal file
View File

@ -0,0 +1,340 @@
{
"_meta": {
"hash": {
"sha256": "72e4688c51db0078d95e53a23477f41db32b98b3a4bcc296ad7c6f4c9360df19"
},
"pipfile-spec": 6,
"requires": {
"python_version": "3.9"
},
"sources": [
{
"name": "pypi",
"url": "https://pypi.org/simple",
"verify_ssl": true
}
]
},
"default": {
"babel": {
"hashes": [
"sha256:ab49e12b91d937cd11f0b67cb259a57ab4ad2b59ac7a3b41d6c06c0ac5b0def9",
"sha256:bc0c176f9f6a994582230df350aa6e05ba2ebe4b3ac317eab29d9be5d2768da0"
],
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
"version": "==2.9.1"
},
"certifi": {
"hashes": [
"sha256:2bbf76fd432960138b3ef6dda3dde0544f27cbf8546c458e60baf371917ba9ee",
"sha256:50b1e4f8446b06f41be7dd6338db18e0990601dce795c2b1686458aa7e8fa7d8"
],
"version": "==2021.5.30"
},
"charset-normalizer": {
"hashes": [
"sha256:5d209c0a931f215cee683b6445e2d77677e7e75e159f78def0db09d68fafcaa6",
"sha256:5ec46d183433dcbd0ab716f2d7f29d8dee50505b3fdb40c6b985c7c4f5a3591f"
],
"markers": "python_version >= '3'",
"version": "==2.0.6"
},
"click": {
"hashes": [
"sha256:8c04c11192119b1ef78ea049e0a6f0463e4c48ef00a30160c704337586f3ad7a",
"sha256:fba402a4a47334742d782209a7c79bc448911afe1149d07bdabdf480b3e2f4b6"
],
"markers": "python_version >= '3.6'",
"version": "==8.0.1"
},
"exifread": {
"hashes": [
"sha256:3ef8725efdb66530b4b3cd1c4ba5d3f3b35a7872137d2c707f711971f8ebf809",
"sha256:a0f74af5040168d3883bbc980efe26d06c89f026dc86ba28eb34107662d51766"
],
"version": "==2.3.2"
},
"feedgenerator": {
"hashes": [
"sha256:950541cd3ef43ca2a72802308f7fc393ab9e3e3957471907751cd9791009e76a",
"sha256:b06d6941e8fd6a2c9e71791079e86cbe7a3788c72244acc06f0593b49cda379b"
],
"version": "==1.9.2"
},
"filetype": {
"hashes": [
"sha256:353369948bb1c09b8b3ea3d78390b5586e9399bff9aab894a1dff954e31a66f6",
"sha256:da393ece8d98b47edf2dd5a85a2c8733e44b769e32c71af4cd96ed8d38d96aa7"
],
"version": "==1.0.7"
},
"flask": {
"hashes": [
"sha256:1c4c257b1892aec1398784c63791cbaa43062f1f7aeb555c4da961b20ee68f55",
"sha256:a6209ca15eb63fc9385f38e452704113d679511d9574d09b2cf9183ae7d20dc9"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.1"
},
"idna": {
"hashes": [
"sha256:14475042e284991034cb48e06f6851428fb14c4dc953acd9be9a5e95c7b6dd7a",
"sha256:467fbad99067910785144ce333826c71fb0e63a425657295239737f7ecd125f3"
],
"markers": "python_version >= '3'",
"version": "==3.2"
},
"inifile": {
"hashes": [
"sha256:891bc629f81477708581b30a7b0583bb5c9c2ee3c070afd4675ecd4f96b0d78d",
"sha256:d712bdcee8a7b8894e0214a285d252202f99d5a3f592bd6793a776af8dce9907"
],
"version": "==0.4"
},
"itsdangerous": {
"hashes": [
"sha256:5174094b9637652bdb841a3029700391451bd092ba3db90600dea710ba28e97c",
"sha256:9e724d68fc22902a1435351f84c3fb8623f303fffcc566a4cb952df8c572cff0"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.1"
},
"jinja2": {
"hashes": [
"sha256:1f06f2da51e7b56b8f238affdd6b4e2c61e39598a378cc49345bc1bd42a978a4",
"sha256:703f484b47a6af502e743c9122595cc812b0271f661722403114f71a79d0f5a4"
],
"markers": "python_version >= '3.6'",
"version": "==3.0.1"
},
"lektor": {
"git": "https://github.com/lektor/lektor",
"ref": "0fd7ab0761e7d6cee924d227c3c3b1587d909538"
},
"lektor-atom": {
"hashes": [
"sha256:0299ea8dcac0f2535e74e273cf939a8052f22dd9e99831b056a8cde9a8318563",
"sha256:70f4e018278d68d07d48dc9b748cd012f1f558bef04d984c45d9a36e5a880176"
],
"index": "pypi",
"version": "==0.4.0"
},
"lektor-disqus-comments": {
"hashes": [
"sha256:8d48c6b370862a6488a1742a53ae62e0562a8cbd3ccd03bab89bdb7244998975",
"sha256:d36edb4e6131fa583f40fa18fc45e849c05e098e290aadfc609d0a31d2d26c7a"
],
"index": "pypi",
"version": "==0.4.1"
},
"lektor-markdown-admonition": {
"hashes": [
"sha256:514c2c93ba66fb93abdbfaa927d9c4f52ade25d6362d007c2e40c9b939059980",
"sha256:5c769228316a144dfafc34f6180badff906cd37c99bc45566594dfd632bfda77"
],
"index": "pypi",
"version": "==0.3.1"
},
"lektor-markdown-header-anchors": {
"hashes": [
"sha256:0d38c8bc891784f409f13b0945d835412a3626d4fc9c5b6e3b6bdf43fc07fb89",
"sha256:23036131c210de9e0367ddd6b5ba51967a1e43027ebcacaf650c62c3b1e65b4b"
],
"index": "pypi",
"version": "==0.3.1"
},
"lektor-markdown-highlighter": {
"hashes": [
"sha256:ce257b608a2094540702209f99e28b546581777a67882cebc8e8dabb6429422e",
"sha256:e9fe5f7bd11d7a072e262ca094d25edef7eeeba5d81d8b37518fa391d0a6555f"
],
"index": "pypi",
"version": "==0.3.1"
},
"lektor-slugify": {
"hashes": [
"sha256:01f3cd83880755471bc0a4bdda6f107b9652f2ead2490fc4cac62b7ee8a33448",
"sha256:df075b644f0744a583d84d9ea25b3b29bb86e3368350011a564150d59380f928"
],
"index": "pypi",
"version": "==0.4"
},
"lektor-tags": {
"hashes": [
"sha256:a75003dd72874930c3d3ee3a37956c789abb0c9b30f336e9f600cd706026981a",
"sha256:fc0b40fec754a0c486b5ea3c51fd65b91f58971cbdff164f9f698f5e33cb0a3d"
],
"index": "pypi",
"version": "==0.4.0"
},
"lektor-webpack-support": {
"hashes": [
"sha256:02405921f5c4a93a71a111c762857f21df5d8c1a370e6b7ae81519773a545a09"
],
"index": "pypi",
"version": "==0.5"
},
"markupsafe": {
"hashes": [
"sha256:01a9b8ea66f1658938f65b93a85ebe8bc016e6769611be228d797c9d998dd298",
"sha256:023cb26ec21ece8dc3907c0e8320058b2e0cb3c55cf9564da612bc325bed5e64",
"sha256:0446679737af14f45767963a1a9ef7620189912317d095f2d9ffa183a4d25d2b",
"sha256:0717a7390a68be14b8c793ba258e075c6f4ca819f15edfc2a3a027c823718567",
"sha256:0955295dd5eec6cb6cc2fe1698f4c6d84af2e92de33fbcac4111913cd100a6ff",
"sha256:0d4b31cc67ab36e3392bbf3862cfbadac3db12bdd8b02a2731f509ed5b829724",
"sha256:10f82115e21dc0dfec9ab5c0223652f7197feb168c940f3ef61563fc2d6beb74",
"sha256:168cd0a3642de83558a5153c8bd34f175a9a6e7f6dc6384b9655d2697312a646",
"sha256:1d609f577dc6e1aa17d746f8bd3c31aa4d258f4070d61b2aa5c4166c1539de35",
"sha256:1f2ade76b9903f39aa442b4aadd2177decb66525062db244b35d71d0ee8599b6",
"sha256:2a7d351cbd8cfeb19ca00de495e224dea7e7d919659c2841bbb7f420ad03e2d6",
"sha256:2d7d807855b419fc2ed3e631034685db6079889a1f01d5d9dac950f764da3dad",
"sha256:2ef54abee730b502252bcdf31b10dacb0a416229b72c18b19e24a4509f273d26",
"sha256:36bc903cbb393720fad60fc28c10de6acf10dc6cc883f3e24ee4012371399a38",
"sha256:37205cac2a79194e3750b0af2a5720d95f786a55ce7df90c3af697bfa100eaac",
"sha256:3c112550557578c26af18a1ccc9e090bfe03832ae994343cfdacd287db6a6ae7",
"sha256:3dd007d54ee88b46be476e293f48c85048603f5f516008bee124ddd891398ed6",
"sha256:47ab1e7b91c098ab893b828deafa1203de86d0bc6ab587b160f78fe6c4011f75",
"sha256:49e3ceeabbfb9d66c3aef5af3a60cc43b85c33df25ce03d0031a608b0a8b2e3f",
"sha256:4efca8f86c54b22348a5467704e3fec767b2db12fc39c6d963168ab1d3fc9135",
"sha256:53edb4da6925ad13c07b6d26c2a852bd81e364f95301c66e930ab2aef5b5ddd8",
"sha256:5855f8438a7d1d458206a2466bf82b0f104a3724bf96a1c781ab731e4201731a",
"sha256:594c67807fb16238b30c44bdf74f36c02cdf22d1c8cda91ef8a0ed8dabf5620a",
"sha256:5bb28c636d87e840583ee3adeb78172efc47c8b26127267f54a9c0ec251d41a9",
"sha256:60bf42e36abfaf9aff1f50f52644b336d4f0a3fd6d8a60ca0d054ac9f713a864",
"sha256:611d1ad9a4288cf3e3c16014564df047fe08410e628f89805e475368bd304914",
"sha256:6557b31b5e2c9ddf0de32a691f2312a32f77cd7681d8af66c2692efdbef84c18",
"sha256:693ce3f9e70a6cf7d2fb9e6c9d8b204b6b39897a2c4a1aa65728d5ac97dcc1d8",
"sha256:6a7fae0dd14cf60ad5ff42baa2e95727c3d81ded453457771d02b7d2b3f9c0c2",
"sha256:6c4ca60fa24e85fe25b912b01e62cb969d69a23a5d5867682dd3e80b5b02581d",
"sha256:6fcf051089389abe060c9cd7caa212c707e58153afa2c649f00346ce6d260f1b",
"sha256:7d91275b0245b1da4d4cfa07e0faedd5b0812efc15b702576d103293e252af1b",
"sha256:905fec760bd2fa1388bb5b489ee8ee5f7291d692638ea5f67982d968366bef9f",
"sha256:97383d78eb34da7e1fa37dd273c20ad4320929af65d156e35a5e2d89566d9dfb",
"sha256:984d76483eb32f1bcb536dc27e4ad56bba4baa70be32fa87152832cdd9db0833",
"sha256:99df47edb6bda1249d3e80fdabb1dab8c08ef3975f69aed437cb69d0a5de1e28",
"sha256:a30e67a65b53ea0a5e62fe23682cfe22712e01f453b95233b25502f7c61cb415",
"sha256:ab3ef638ace319fa26553db0624c4699e31a28bb2a835c5faca8f8acf6a5a902",
"sha256:add36cb2dbb8b736611303cd3bfcee00afd96471b09cda130da3581cbdc56a6d",
"sha256:b2f4bf27480f5e5e8ce285a8c8fd176c0b03e93dcc6646477d4630e83440c6a9",
"sha256:b7f2d075102dc8c794cbde1947378051c4e5180d52d276987b8d28a3bd58c17d",
"sha256:baa1a4e8f868845af802979fcdbf0bb11f94f1cb7ced4c4b8a351bb60d108145",
"sha256:be98f628055368795d818ebf93da628541e10b75b41c559fdf36d104c5787066",
"sha256:bf5d821ffabf0ef3533c39c518f3357b171a1651c1ff6827325e4489b0e46c3c",
"sha256:c47adbc92fc1bb2b3274c4b3a43ae0e4573d9fbff4f54cd484555edbf030baf1",
"sha256:d7f9850398e85aba693bb640262d3611788b1f29a79f0c93c565694658f4071f",
"sha256:d8446c54dc28c01e5a2dbac5a25f071f6653e6e40f3a8818e8b45d790fe6ef53",
"sha256:e0f138900af21926a02425cf736db95be9f4af72ba1bb21453432a07f6082134",
"sha256:e9936f0b261d4df76ad22f8fee3ae83b60d7c3e871292cd42f40b81b70afae85",
"sha256:f5653a225f31e113b152e56f154ccbe59eeb1c7487b39b9d9f9cdb58e6c79dc5",
"sha256:f826e31d18b516f653fe296d967d700fddad5901ae07c622bb3705955e1faa94",
"sha256:f8ba0e8349a38d3001fae7eadded3f6606f0da5d748ee53cc1dab1d6527b9509",
"sha256:f9081981fe268bd86831e5c75f7de206ef275defcb82bc70740ae6dc507aee51",
"sha256:fa130dd50c57d53368c9d59395cb5526eda596d3ffe36666cd81a44d56e48872"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.1"
},
"mistune": {
"hashes": [
"sha256:59a3429db53c50b5c6bcc8a07f8848cb00d7dc8bdb431a4ab41920d201d4756e",
"sha256:88a1051873018da288eee8538d476dffe1262495144b33ecb586c4ab266bb8d4"
],
"version": "==0.8.4"
},
"pygments": {
"hashes": [
"sha256:b8e67fe6af78f492b3c4b3e2970c0624cbf08beb1e493b2c99b9fa1b67a20380",
"sha256:f398865f7eb6874156579fdf36bc840a03cab64d1cde9e93d68f46a425ec52c6"
],
"markers": "python_version >= '3.5'",
"version": "==2.10.0"
},
"python-slugify": {
"hashes": [
"sha256:6d8c5df75cd4a7c3a2d21e257633de53f52ab0265cd2d1dc62a730e8194a7380",
"sha256:f13383a0b9fcbe649a1892b9c8eb4f8eab1d6d84b84bb7a624317afa98159cab"
],
"markers": "python_version >= '3.6'",
"version": "==5.0.2"
},
"pytz": {
"hashes": [
"sha256:83a4a90894bf38e243cf052c8b58f381bfe9a7a483f6a9cab140bc7f702ac4da",
"sha256:eb10ce3e7736052ed3623d49975ce333bcd712c7bb19a58b9e2089d4057d0798"
],
"version": "==2021.1"
},
"requests": {
"extras": [
"security"
],
"hashes": [
"sha256:6c1246513ecd5ecd4528a0906f910e8f0f9c6b8ec72030dc9fd154dc1a6efd24",
"sha256:b8aa58f8cf793ffd8782d3d8cb19e66ef36f7aba4353eec859e74678b01b07a7"
],
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4, 3.5'",
"version": "==2.26.0"
},
"six": {
"hashes": [
"sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926",
"sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254"
],
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
"version": "==1.16.0"
},
"text-unidecode": {
"hashes": [
"sha256:1311f10e8b895935241623731c2ba64f4c455287888b18189350b67134a822e8",
"sha256:bad6603bb14d279193107714b288be206cac565dfa49aa5b105294dd5c4aab93"
],
"version": "==1.3"
},
"urllib3": {
"hashes": [
"sha256:39fb8672126159acb139a7718dd10806104dec1e2f0f6c88aab05d17df10c8d4",
"sha256:f57b4c16c62fa2760b7e3d97c35b255512fb6b59a259730f36ba32ce9f8e342f"
],
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4' and python_version < '4'",
"version": "==1.26.6"
},
"watchdog": {
"hashes": [
"sha256:28777dbed3bbd95f9c70f461443990a36c07dbf49ae7cd69932cdd1b8fb2850c",
"sha256:41d44ef21a77a32b55ce9bf59b75777063751f688de51098859b7c7f6466589a",
"sha256:43bf728eb7830559f329864ab5da2302c15b2efbac24ad84ccc09949ba753c40",
"sha256:50a7f81f99d238f72185f481b493f9de80096e046935b60ea78e1276f3d76960",
"sha256:51af09ae937ada0e9a10cc16988ec03c649754a91526170b6839b89fc56d6acb",
"sha256:5563b005907613430ef3d4aaac9c78600dd5704e84764cb6deda4b3d72807f09",
"sha256:58ae842300cbfe5e62fb068c83901abe76e4f413234b7bec5446e4275eb1f9cb",
"sha256:59767f476cd1f48531bf378f0300565d879688c82da8369ca8c52f633299523c",
"sha256:5cf78f794c9d7bc64a626ef4f71aff88f57a7ae288e0b359a9c6ea711a41395f",
"sha256:5f57ce4f7e498278fb2a091f39359930144a0f2f90ea8cbf4523c4e25de34028",
"sha256:6f3ad1d973fe8fc8fe64ba38f6a934b74346342fa98ef08ad5da361a05d46044",
"sha256:78b1514067ff4089f4dac930b043a142997a5b98553120919005e97fbaba6546",
"sha256:814d396859c95598f7576d15bc257c3bd3ba61fa4bc1db7dfc18f09070ded7da",
"sha256:8874d5ad6b7f43b18935d9b0183e29727a623a216693d6938d07dfd411ba462f",
"sha256:8b74d0d92a69a7ab5f101f9fe74e44ba017be269efa824337366ccbb4effde85",
"sha256:9391003635aa783957b9b11175d9802d3272ed67e69ef2e3394c0b6d9d24fa9a",
"sha256:a2888a788893c4ef7e562861ec5433875b7915f930a5a7ed3d32c048158f1be5",
"sha256:a7053d4d22dc95c5e0c90aeeae1e4ed5269d2f04001798eec43a654a03008d22",
"sha256:b0cc7d8b7d60da6c313779d85903ce39a63d89d866014b085f720a083d5f3e9a",
"sha256:e40e33a4889382824846b4baa05634e1365b47c6fa40071dc2d06b4d7c715fc1",
"sha256:e60d3bb7166b7cb830b86938d1eb0e6cfe23dfd634cce05c128f8f9967895193",
"sha256:eab14adfc417c2c983fbcb2c73ef3f28ba6990d1fff45d1180bf7e38bda0d98d",
"sha256:ed4ca4351cd2bb0d863ee737a2011ca44d8d8be19b43509bd4507f8a449b376b"
],
"markers": "python_version >= '3.6'",
"version": "==2.1.5"
},
"werkzeug": {
"hashes": [
"sha256:1de1db30d010ff1af14a009224ec49ab2329ad2cde454c8a708130642d579c42",
"sha256:6c1ec500dcdba0baa27600f6a22f6333d8b662d22027ff9f6202e3367413caa8"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.1"
}
},
"develop": {}
}

View File

@ -15,13 +15,13 @@ name = Github pages on repo
target = ghpages+https://lektor/lektor-website?cname=www.getlektor.com
default = not
[packages]
lektor-webpack-support = 0.3
lektor-disqus-comments = 0.1
lektor-markdown-header-anchors = 0.1
lektor-markdown-highlighter = 0.3.2
lektor-markdown-admonition = 0.1
lektor-atom = 0.4.0
lektor-tags = 0.3
lektor-slugify = 0.4
# These are managed with pipenv (see Pipfile)
# [packages]
# lektor-webpack-support = 0.3
# lektor-disqus-comments = 0.1
# lektor-markdown-header-anchors = 0.1
# lektor-markdown-highlighter = 0.3.2
# lektor-markdown-admonition = 0.1
# lektor-atom = 0.4.0
# lektor-tags = 0.3
# lektor-slugify = 0.4

View File

@ -0,0 +1,239 @@
# -*- coding: utf-8 -*-
import posixpath
from datetime import date
from itertools import chain
from werkzeug.utils import cached_property
from lektor.pluginsystem import Plugin
from lektor.sourceobj import VirtualSourceObject
from lektor.build_programs import BuildProgram
from lektor.utils import build_url, parse_path
class BlogArchive(VirtualSourceObject):
def __init__(self, record, plugin, items=None):
VirtualSourceObject.__init__(self, record)
self.plugin = plugin
self._items = items
@property
def path(self):
return self.record.path + '@blog-archive'
template_name = 'blog-archive/index.html'
@property
def parent(self):
return self.record
@cached_property
def year_archives(self):
years = set()
for item in self.record.children:
pub_date = self.plugin.get_pub_date(item)
if pub_date:
years.add(pub_date.year)
return [BlogYearArchive(self.record, self.plugin,
year=year) for year in sorted(years)]
@property
def items(self):
if self._items is not None:
return self._items
rv = list(self._iter_items())
self._items = rv
return rv
def _iter_items(self):
return iter(())
@property
def has_any_items(self):
if self._items is not None:
return bool(self._items)
for item in self._iter_items():
return True
return False
@property
def items_by_months(self):
months = {}
for item in self.items:
pub_date = self.plugin.get_pub_date(item)
months.setdefault(date(pub_date.year, pub_date.month, 1),
[]).append(item)
return [(BlogMonthArchive(self.record, self.plugin,
year=d.year, month=d.month), i)
for d, i in sorted(months.items())]
def get_archive_url_path(self):
return self.plugin.get_url_path('archive_path')
@property
def url_path(self):
return build_url(chain([self.record.url_path.strip('/')],
self.get_archive_url_path() or ()))
class BlogYearArchive(BlogArchive):
template_name = 'blog-archive/year.html'
def __init__(self, record, plugin, items=None, year=None):
BlogArchive.__init__(self, record, plugin, items)
self.year = year
def _iter_items(self):
for item in self.record.children:
pub_date = self.plugin.get_pub_date(item)
if pub_date is not None and \
pub_date.year == self.year:
yield item
@property
def path(self):
return '%s@blog-archive/%s' % (
self.record.path,
self.year,
)
@property
def parent(self):
return BlogArchive(self.record, self.plugin)
@property
def date(self):
return date(self.year, 1, 1)
def get_archive_url_path(self):
return self.plugin.get_url_path('year_archive_prefix') + [self.year]
class BlogMonthArchive(BlogArchive):
template_name = 'blog-archive/month.html'
def __init__(self, record, plugin, items=None, year=None, month=None):
BlogArchive.__init__(self, record, plugin, items)
self.year = year
self.month = month
def _iter_items(self):
for item in self.record.children:
pub_date = self.plugin.get_pub_date(item)
if pub_date is not None and \
pub_date.year == self.year and \
pub_date.month == self.month:
yield item
@property
def path(self):
return '%s@blog-archive/%s/%s' % (
self.record.path,
self.year,
self.month
)
@property
def parent(self):
return BlogYearArchive(self.record, self.plugin, year=self.year)
@property
def date(self):
return date(self.year, self.month, 1)
def get_archive_url_path(self):
return self.plugin.get_url_path('month_archive_prefix') + [
self.year, self.month]
class BlogArchiveBuildProgram(BuildProgram):
def produce_artifacts(self):
self.declare_artifact(
posixpath.join(self.source.url_path, 'index.html'),
sources=list(self.source.iter_source_filenames()))
def build_artifact(self, artifact):
artifact.render_template_into(self.source.template_name,
this=self.source)
class BlogArchivePlugin(Plugin):
name = u'Blog Archive'
description = u'Adds archives to a blog.'
def get_pub_date(self, post):
key = self.get_config().get('pub_date_field', 'pub_date')
return post[key]
def get_blog_path(self):
return self.get_config().get('blog_path', '/blog')
def get_url_path(self, name, default='archive'):
return parse_path(self.get_config().get(name, default))
def on_setup_env(self, **extra):
self.env.add_build_program(BlogArchive, BlogArchiveBuildProgram)
@self.env.virtualpathresolver('blog-archive')
def blog_archive_resolver(node, pieces):
if node.path == self.get_blog_path():
if not pieces:
return BlogArchive(node, self)
elif len(pieces) == 1 and pieces[0].isdigit():
return BlogYearArchive(node, self, year=int(pieces[0]))
elif len(pieces) == 2 and pieces[0].isdigit() \
and pieces[1].isdigit():
return BlogMonthArchive(node, self, year=int(pieces[0]),
month=int(pieces[1]))
@self.env.urlresolver
def archive_urlresolver(node, url_path):
if node.path != self.get_blog_path():
return
archive_index = self.get_url_path('archive_path')
if url_path == archive_index:
return BlogArchive(node, self)
year_prefix = self.get_url_path('year_archive_prefix')
if url_path[:len(year_prefix)] == year_prefix and \
url_path[len(year_prefix)].isdigit() and \
len(url_path) == len(year_prefix) + 1:
year = int(url_path[len(year_prefix)])
rv = BlogYearArchive(node, self, year=year)
if rv.has_any_items:
return rv
month_prefix = self.get_url_path('month_archive_prefix')
if url_path[:len(month_prefix)] == month_prefix and \
len(url_path) == len(month_prefix) + 2 and \
url_path[len(month_prefix)].isdigit() and \
url_path[len(month_prefix) + 1].isdigit():
year = int(url_path[len(month_prefix)])
month = int(url_path[len(month_prefix) + 1])
rv = BlogMonthArchive(node, self, year=year, month=month)
if rv.has_any_items:
return rv
@self.env.generator
def genererate_blog_archive_pages(source):
if source.path != self.get_blog_path():
return
years = {}
months = {}
for post in source.children:
pub_date = self.get_pub_date(post)
if pub_date:
years.setdefault(pub_date.year, []).append(post)
months.setdefault((pub_date.year,
pub_date.month), []).append(post)
yield BlogArchive(source, self)
for year, items in sorted(years.items()):
yield BlogYearArchive(source, self, year=year, items=items)
for (year, month), items in sorted(months.items()):
yield BlogMonthArchive(source, self, year=year, month=month,
items=items)

View File

@ -0,0 +1,86 @@
# -*- coding: utf-8 -*-
import cgi
import pkg_resources
import readme_renderer.markdown
import readme_renderer.rst
import readme_renderer.txt
import requests
from lektor.pluginsystem import Plugin
_RENDERERS = {
None: readme_renderer.rst, # Default if description_content_type is None
'': readme_renderer.rst, # Default if description_content_type is None
'text/plain': readme_renderer.txt,
'text/x-rst': readme_renderer.rst,
'text/markdown': readme_renderer.markdown,
}
class ProjectDataPlugin(Plugin):
name = 'Project Data'
description = u'Retrieve project information from PyPI.'
data = {}
def render(self, value, content_type=None):
"""Taken from https://github.com/pypa/warehouse/blob/master/warehouse/filters.py
to ensure compliance and not reinvent the wheel. We don't want to be creative here.
"""
content_type, parameters = cgi.parse_header(content_type or '')
# Get the appropriate renderer
renderer = _RENDERERS.get(content_type, readme_renderer.txt)
# Actually render the given value, this will not only render the value, but
# also ensure that it's had any disallowed markup removed.
rendered = renderer.render(value, **parameters)
# If the content was not rendered, we'll render as plaintext instead. The
# reason it's necessary to do this instead of just accepting plaintext is
# that readme_renderer will deal with sanitizing the content.
if rendered is None:
rendered = readme_renderer.txt.render(value)
return rendered
def package_data(self, name, entry_point=None):
if not entry_point:
entry_point = 'https://pypi.org/pypi'
url = '{}/{}/json'.format(entry_point, name)
resp = requests.get(url)
pkg = resp.json()
self.data.update(pkg['info'])
# Erase bad keys that are sometimes returned from the api
# to handle it in the template.
# To us, unknown is the same as non-existent.
for key in self.data:
val = self.data.get(key)
if type(val) is str and val.strip() == 'UNKNOWN':
self.data[key] = ''
self.data['short_name'] = name.split('lektor-')[1]
# Rewrite description as rendered description.
self.data['description'] = self.render(
self.data['description'], self.data['description_content_type'])
if not self.data.get('home_page'):
self.data['home_page'] = 'https://pypi.org/project/{}/'.format(name)
def github_data(self, owner=None, repo=None):
url = 'https://api.github.com/repos/{}/{}'.format(owner, repo)
response = requests.get(url)
data = response.json()
return data
def project_data(self, name):
self.package_data(name)
# github data not currently used. Commented to save build time.
# if 'github' in self.data.get('home_page'):
# owner = self.data['home_page'].split('/')[-2]
# repo = self.data['home_page'].split('/')[-1]
# self.data['gh'] = self.github_data(owner=owner, repo=repo)
# TODO: support bitbucket
return self.data
def on_setup_env(self, **extra):
self.env.jinja_env.globals['project_data'] = self.project_data