mirror of
https://github.com/lektor/lektor-website.git
synced 2025-04-03 00:45:37 +02:00
add pipfile for installation of plugins
This commit is contained in:
parent
86d35c13de
commit
9e76bb58dd
20
Pipfile
Normal file
20
Pipfile
Normal 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
340
Pipfile.lock
generated
Normal 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": {}
|
||||
}
|
@ -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
|
||||
|
239
plugins/blog-archive/build/lib/lektor_blog_archive.py
Normal file
239
plugins/blog-archive/build/lib/lektor_blog_archive.py
Normal 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)
|
86
plugins/project-data/build/lib/lektor_project_data.py
Normal file
86
plugins/project-data/build/lib/lektor_project_data.py
Normal 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
|
Loading…
x
Reference in New Issue
Block a user