Compare commits
14 Commits
2016-2017
...
ec821d1e3c
| Author | SHA1 | Date | |
|---|---|---|---|
| ec821d1e3c | |||
| 528f8c807b | |||
| bb39706e4c | |||
| 22d4b1cfae | |||
| 5f2bf02388 | |||
| ce836d1692 | |||
| 32d0f9c0fc | |||
| 560eaddafd | |||
| e30ede21cf | |||
| 9488882cab | |||
| 2354cc4b29 | |||
| 67e01f6f4e | |||
| b8ed9f5ae2 | |||
| 1ad81faabe |
28
.drone.yml
Normal file
28
.drone.yml
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
kind: pipeline
|
||||||
|
name: Opytex 2019-2020
|
||||||
|
type: docker
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
branch:
|
||||||
|
- 2019-2020
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Deploy
|
||||||
|
image: python:3.8-alpine
|
||||||
|
commands:
|
||||||
|
- echo "Trigger from branch"
|
||||||
|
- git clone https://git.opytex.org/lafrite/2019-2020.git content
|
||||||
|
- pip install --no-cache-dir -r requirements.txt
|
||||||
|
- pelican ./content/ -o output -s publishconf.py --relative-urls
|
||||||
|
- apk add --no-cache openssh-client ca-certificates bash rsync
|
||||||
|
- echo Début du Push
|
||||||
|
- eval `ssh-agent -s`
|
||||||
|
- echo "$SSH_KEY" | ssh-add -
|
||||||
|
- mkdir -p ~/.ssh
|
||||||
|
- echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config
|
||||||
|
- rsync -rv --delete -e "ssh -p 22" ./output/ sshcontent@91.121.90.228:~/raw.opytex.org/www/2019-2020/ --checksum
|
||||||
|
environment:
|
||||||
|
SSH_KEY:
|
||||||
|
from_secret: sshcontent-key
|
||||||
|
|
||||||
|
|
||||||
1
Makefile
1
Makefile
@@ -48,6 +48,7 @@ help:
|
|||||||
@echo ' '
|
@echo ' '
|
||||||
|
|
||||||
html:
|
html:
|
||||||
|
lessc $(BASEDIR)/theme/static/stylesheet/style.less $(BASEDIR)/theme/static/stylesheet/style.min.css -x
|
||||||
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(CONFFILE) $(PELICANOPTS)
|
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(CONFFILE) $(PELICANOPTS)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ DISPLAY_PAGES_ON_MENU = False
|
|||||||
DISPLAY_CATEGORIES_ON_MENU = False
|
DISPLAY_CATEGORIES_ON_MENU = False
|
||||||
MENUITEMS = [
|
MENUITEMS = [
|
||||||
#("Dernières modifications", SITEURL+"blog_index.html"),
|
#("Dernières modifications", SITEURL+"blog_index.html"),
|
||||||
|
("Accueil", "/"),
|
||||||
("Contenus de cours", "/pages/tout-sur-mes-cours.html"),
|
("Contenus de cours", "/pages/tout-sur-mes-cours.html"),
|
||||||
('blog', '/blog_index.html'),
|
('blog', '/blog_index.html'),
|
||||||
('Opytex', "/opytex/"),
|
('Opytex', "/opytex/"),
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ blinker==1.4
|
|||||||
docutils==0.13.1
|
docutils==0.13.1
|
||||||
feedgenerator==1.9
|
feedgenerator==1.9
|
||||||
Jinja2==2.9.6
|
Jinja2==2.9.6
|
||||||
MarkupSafe==1.0
|
MarkupSafe==1.1.1
|
||||||
pelican==3.7.1
|
pelican==3.7.1
|
||||||
Pygments==2.2.0
|
Pygments==2.2.0
|
||||||
python-dateutil==2.6.0
|
python-dateutil==2.6.0
|
||||||
|
|||||||
136
tasks.py
Normal file
136
tasks.py
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
|
import sys
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
from invoke import task
|
||||||
|
from invoke.util import cd
|
||||||
|
from pelican.server import ComplexHTTPRequestHandler, RootedHTTPServer
|
||||||
|
from pelican.settings import DEFAULT_CONFIG, get_settings_from_file
|
||||||
|
|
||||||
|
SETTINGS_FILE_BASE = 'pelicanconf.py'
|
||||||
|
SETTINGS = {}
|
||||||
|
SETTINGS.update(DEFAULT_CONFIG)
|
||||||
|
LOCAL_SETTINGS = get_settings_from_file(SETTINGS_FILE_BASE)
|
||||||
|
SETTINGS.update(LOCAL_SETTINGS)
|
||||||
|
|
||||||
|
CONFIG = {
|
||||||
|
'current_path': os.getcwd(),
|
||||||
|
'settings_base': SETTINGS_FILE_BASE,
|
||||||
|
'settings_publish': 'publishconf.py',
|
||||||
|
|
||||||
|
'year_subfolder': 'enseignements/2019-2020/',
|
||||||
|
|
||||||
|
# Output path. Can be absolute or relative to tasks.py. Default: 'output'
|
||||||
|
'deploy_path': SETTINGS['OUTPUT_PATH'],
|
||||||
|
|
||||||
|
'fake_path': '../../output/',
|
||||||
|
|
||||||
|
# Remote server configuration
|
||||||
|
'ssh_user': 'sshcontent',
|
||||||
|
'ssh_host': 'Embrevade',
|
||||||
|
'ssh_port': '22',
|
||||||
|
'ssh_path': '/home/sshcontent/opytex.org/www/',
|
||||||
|
|
||||||
|
# Rsync config
|
||||||
|
'rsync_exclude': '',
|
||||||
|
|
||||||
|
# Port for `serve`
|
||||||
|
'port': 8000,
|
||||||
|
}
|
||||||
|
|
||||||
|
@task
|
||||||
|
def clean(c):
|
||||||
|
"""Remove generated files"""
|
||||||
|
if os.path.isdir(CONFIG['deploy_path']):
|
||||||
|
shutil.rmtree(CONFIG['deploy_path'])
|
||||||
|
os.makedirs(CONFIG['deploy_path'])
|
||||||
|
|
||||||
|
@task
|
||||||
|
def build(c):
|
||||||
|
"""Build local version of site"""
|
||||||
|
c.run('lessc {current_path}/theme/static/stylesheet/style.less {current_path}/theme/static/stylesheet/style.min.css -x'.format(**CONFIG))
|
||||||
|
c.run('pelican -s {settings_base}'.format(**CONFIG))
|
||||||
|
|
||||||
|
@task
|
||||||
|
def rebuild(c):
|
||||||
|
"""`build` with the delete switch"""
|
||||||
|
c.run('pelican -d -s {settings_base}'.format(**CONFIG))
|
||||||
|
|
||||||
|
@task
|
||||||
|
def regenerate(c):
|
||||||
|
"""Automatically regenerate site upon file modification"""
|
||||||
|
c.run('pelican -r -s {settings_base}'.format(**CONFIG))
|
||||||
|
|
||||||
|
@task
|
||||||
|
def serve(c):
|
||||||
|
"""Serve site at http://localhost:$PORT/ (default port is 8000)"""
|
||||||
|
|
||||||
|
class AddressReuseTCPServer(RootedHTTPServer):
|
||||||
|
allow_reuse_address = True
|
||||||
|
|
||||||
|
server = AddressReuseTCPServer(
|
||||||
|
CONFIG['deploy_path'],
|
||||||
|
('', CONFIG['port']),
|
||||||
|
ComplexHTTPRequestHandler)
|
||||||
|
|
||||||
|
sys.stderr.write('Serving on port {port} ...\n'.format(**CONFIG))
|
||||||
|
server.serve_forever()
|
||||||
|
|
||||||
|
@task
|
||||||
|
def reserve(c):
|
||||||
|
"""`build`, then `serve`"""
|
||||||
|
build(c)
|
||||||
|
serve(c)
|
||||||
|
|
||||||
|
@task
|
||||||
|
def preview(c):
|
||||||
|
"""Build production version of site"""
|
||||||
|
c.run('pelican -s {settings_publish}'.format(**CONFIG))
|
||||||
|
|
||||||
|
@task
|
||||||
|
def livereload(c):
|
||||||
|
"""Automatically reload browser tab upon file modification."""
|
||||||
|
from livereload import Server
|
||||||
|
build(c)
|
||||||
|
server = Server()
|
||||||
|
# Watch the base settings file
|
||||||
|
server.watch(CONFIG['settings_base'], lambda: build(c))
|
||||||
|
# Watch content source files
|
||||||
|
content_file_extensions = ['.md', '.rst']
|
||||||
|
for extension in content_file_extensions:
|
||||||
|
content_blob = '{0}/**/*{1}'.format(SETTINGS['PATH'], extension)
|
||||||
|
server.watch(content_blob, lambda: build(c))
|
||||||
|
# Watch the theme's templates and static assets
|
||||||
|
theme_path = SETTINGS['THEME']
|
||||||
|
server.watch('{}/templates/*.html'.format(theme_path), lambda: build(c))
|
||||||
|
static_file_extensions = ['.css', '.js']
|
||||||
|
for extension in static_file_extensions:
|
||||||
|
static_file = '{0}/static/**/*{1}'.format(theme_path, extension)
|
||||||
|
server.watch(static_file, lambda: build(c))
|
||||||
|
# Serve output path on configured port
|
||||||
|
server.serve(port=CONFIG['port'], root=CONFIG['deploy_path'])
|
||||||
|
|
||||||
|
|
||||||
|
@task
|
||||||
|
def publish(c):
|
||||||
|
"""Publish to production via rsync"""
|
||||||
|
c.run('pelican -s {settings_publish}'.format(**CONFIG))
|
||||||
|
c.run(
|
||||||
|
'rsync --delete {rsync_exclude} -pthrvz -c '
|
||||||
|
'-e "ssh " '
|
||||||
|
'{} {ssh_host}:{ssh_path}'.format(
|
||||||
|
CONFIG['deploy_path'].rstrip('/') + '/',
|
||||||
|
**CONFIG))
|
||||||
|
|
||||||
|
@task(
|
||||||
|
pre=[build]
|
||||||
|
)
|
||||||
|
def fake(c):
|
||||||
|
""" Mimic a push to server """
|
||||||
|
print('{fake_path}{year_subfolder}'.format(**CONFIG))
|
||||||
|
os.makedirs('{fake_path}{year_subfolder}'.format(**CONFIG), exist_ok=True)
|
||||||
|
c.run('rsync -P -rvzc --delete {rsync_exclude} {deploy_path}/ {fake_path}{year_subfolder} --cvs-exclude'.format(**CONFIG))
|
||||||
|
|
||||||
@@ -113,6 +113,48 @@ aside {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tagcloud {
|
||||||
|
padding: 0;
|
||||||
|
list-style: none;
|
||||||
|
li {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
h2 {
|
||||||
|
background-color: @sidebar-bg;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
list-style: none;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul li {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
li.tag-0 {
|
||||||
|
font-size: 170%;
|
||||||
|
}
|
||||||
|
|
||||||
|
li.tag-1 {
|
||||||
|
font-size: 150%;
|
||||||
|
}
|
||||||
|
|
||||||
|
li.tag-2 {
|
||||||
|
font-size: 120%;
|
||||||
|
}
|
||||||
|
|
||||||
|
li.tag-3 {
|
||||||
|
font-size: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
li.tag-4 {
|
||||||
|
font-size: 80%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
main {
|
main {
|
||||||
|
|||||||
27
theme/static/stylesheet/style.min.css
vendored
27
theme/static/stylesheet/style.min.css
vendored
File diff suppressed because one or more lines are too long
@@ -23,7 +23,7 @@
|
|||||||
@sidebar-bg: @grey;
|
@sidebar-bg: @grey;
|
||||||
@sidebar-text-color: @white;
|
@sidebar-text-color: @white;
|
||||||
@sidebar-link-color: @white;
|
@sidebar-link-color: @white;
|
||||||
@sidebar-link-hover-color: @light-grey;
|
@sidebar-link-hover-color: @light-orange;
|
||||||
|
|
||||||
// Buttons
|
// Buttons
|
||||||
@btn-bg: @orange;
|
@btn-bg: @orange;
|
||||||
|
|||||||
@@ -81,9 +81,9 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</a>
|
</a>
|
||||||
-->
|
-->
|
||||||
<h1><a href="{{ SITEURL }}/">{{ SITETITLE }}</a></h1>
|
<h1><a href="/">{{ SITETITLE }}</a></h1>
|
||||||
|
|
||||||
{% if SITESUBTITLE %}<p>{{ SITESUBTITLE }}</p>{% endif %}
|
{% if SITESUBTITLE %}<p><a href="{{ SITEURL }}/">{{ SITESUBTITLE }}</a></p>{% endif %}
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
<h2>Années</h2>
|
<h2>Années</h2>
|
||||||
@@ -99,26 +99,28 @@
|
|||||||
<nav>
|
<nav>
|
||||||
<ul class="list">
|
<ul class="list">
|
||||||
{% for category, articles in categories|sort %}
|
{% for category, articles in categories|sort %}
|
||||||
<li><a href="{{ SITEURL }}/{{ category.url }}">{{ category }}</a> ({{ articles|count }})</li>
|
<li><a href="{{ SITEURL }}/{{ category.url }}">{{ category }} ({{ articles|count }})</a></li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
</nav>
|
</nav>
|
||||||
<h2><a href="{{ SITEURL }}/tags.html">
|
<h2><a href="{{ SITEURL }}/tags.html">
|
||||||
Thèmes
|
Thèmes
|
||||||
</a></h2>
|
</a></h2>
|
||||||
<nav>
|
<nav>
|
||||||
<ul class="tagcloud">
|
|
||||||
{% for tag in tag_cloud %}
|
<ul class="tagcloud">
|
||||||
<li class="tag-{{ tag.1 }}">
|
{% for tag in tag_cloud %}
|
||||||
<a href="{{ SITEURL }}/{{ tag.0.url }}">
|
<li class="tag-{{ tag.1 }}">
|
||||||
{{ tag.0 }}
|
<a href="{{ SITEURL }}/{{ tag.0.url }}">
|
||||||
{% if TAG_CLOUD_BADGE %}
|
{{ tag.0 }}
|
||||||
<span class="badge">{{ tag.2 }}</span>
|
{% if TAG_CLOUD_BADGE %}
|
||||||
{% endif %}
|
<span class="badge">{{ tag.2 }}</span>
|
||||||
</a>
|
{% endif %}
|
||||||
</li>
|
</a>
|
||||||
{% endfor %}
|
</li>
|
||||||
</ul>
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
</nav>
|
</nav>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -126,8 +128,6 @@
|
|||||||
<main>
|
<main>
|
||||||
{% if MAIN_MENU %}
|
{% if MAIN_MENU %}
|
||||||
<nav>
|
<nav>
|
||||||
<a href="{{ SITEURL }}/">{{ _('Home') }}</a>
|
|
||||||
|
|
||||||
{% for title, link in MENUITEMS %}
|
{% for title, link in MENUITEMS %}
|
||||||
<a href="{{ link }}">{{ title }}</a>
|
<a href="{{ link }}">{{ title }}</a>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|||||||
Reference in New Issue
Block a user