28 Commits

Author SHA1 Message Date
7a8936b9ac import .drone.yml from master
All checks were successful
continuous-integration/drone/push Build is passing
2023-07-25 16:55:12 +02:00
3c3e3b9096 Feat: add umami analytics
All checks were successful
continuous-integration/drone/push Build is passing
2022-06-15 09:23:16 +02:00
4b254dec82 Fix: link to projets-informatiques
All checks were successful
continuous-integration/drone/push Build is passing
2020-08-16 10:33:51 +02:00
ec21c34aa1 Feat: remove link to bopytex and mapytex
Some checks reported errors
continuous-integration/drone/push Build was killed
2020-08-16 10:29:05 +02:00
e62a4bb753 Fix: remove link try other version of wand
All checks were successful
continuous-integration/drone/push Build is passing
2020-08-06 16:22:30 +02:00
9c4fb24cb7 Fix: pdf generation with drone
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-06 16:20:02 +02:00
15fc379383 Feat: Deploy to opytex!
All checks were successful
continuous-integration/drone/push Build is passing
2020-08-06 16:13:09 +02:00
479a901e89 Fix: quote for ssh command
All checks were successful
continuous-integration/drone/push Build is passing
2020-08-05 10:01:00 +02:00
07799ed0e9 Fix: ssh address and export for MAGICK_HOME
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:56:59 +02:00
53ef4367e9 Fix: ensure mkdir
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:54:48 +02:00
59d98cafad Fix: libmagic -> imagemagick
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:51:05 +02:00
872a74fb26 Fix: add libmagic to apline
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:49:24 +02:00
b408541cc7 Fix: path to the year
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:47:08 +02:00
b9b69e789a Feat: submodule and requirements for plugins
All checks were successful
continuous-integration/drone/push Build is passing
2020-08-05 09:43:54 +02:00
126b4585c1 Feat: install git in drone
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:38:13 +02:00
ec821d1e3c Feat: drone.yml for 2019-2020
Some checks failed
continuous-integration/drone/push Build is failing
2020-08-05 09:36:14 +02:00
528f8c807b Feat: New pipeline for 2019-2020 2020-08-05 09:36:14 +02:00
bb39706e4c Fix: Spelling once again! 2020-08-05 09:36:14 +02:00
22d4b1cfae Fix: directory spelling 2020-08-05 09:36:14 +02:00
5f2bf02388 Fix: Good directory to push! 2020-08-05 09:36:14 +02:00
ce836d1692 Fix: remove double apk 2020-08-05 09:36:14 +02:00
32d0f9c0fc Fix: install rsync in drone.yml 2020-08-05 09:36:14 +02:00
560eaddafd Fix: upgrade MarkupSafe 2020-08-05 09:36:14 +02:00
e30ede21cf Feat: start using invoke 2020-07-01 14:57:37 +02:00
9488882cab Fix: tagcloud display and link color 2020-06-30 14:38:27 +02:00
2354cc4b29 Feat: add in html rule less processing 2020-06-30 14:38:24 +02:00
67e01f6f4e Feat: Title link to /, date to /ense.... 2020-06-30 14:38:19 +02:00
b8ed9f5ae2 Feat: move HOME to links 2020-06-24 10:35:24 +02:00
12 changed files with 320 additions and 59 deletions

101
.drone.yml Normal file
View File

@@ -0,0 +1,101 @@
---
kind: pipeline
name: Opytex Main
type: docker
trigger:
branch:
- master
steps:
- name: Build Opytex base
image: python:3.8-alpine
volumes:
- name: pelican-output
path: /output
commands:
- apk add --no-cache git imagemagick-dev imagemagick
- git submodule init
- git submodule update
- pip install --no-cache-dir -r requirements.txt
- export MAGICK_HOME=/usr
- pelican ./content/ -o /output -s publishconf.py --relative-urls
- ls /output
- name: Push to bucket opytex.org
image: plugins/s3
volumes:
- name: pelican-output
path: /output
settings:
bucket: opytex.org
endpoint: https://storage.opytex.org
access_key:
from_secret: minio_access_key
secret_key:
from_secret: minio_secret_key
source: /output/**/*
target: /
path_style: true
strip_prefix: /output
volumes:
- name: pelican-output
temp: {}
---
kind: pipeline
name: Opytex Year
type: docker
trigger:
branch:
- 2022-2023
- 2021-2022
- 2020-2021
- 2019-2020
- 2018-2019
- 2017-2018
- 2016-2017
- 2015-2016
steps:
- name: Build Opytex ${DRONE_BRANCH}
image: python:3.8-alpine
volumes:
- name: pelican-output
path: /output
commands:
- apk add --no-cache git imagemagick-dev imagemagick
- git submodule init
- git submodule update
- git clone https://git.opytex.org/lafrite/${DRONE_BRANCH}.git content
- pip install --no-cache-dir -r requirements.txt
- apk add --no-cache git imagemagick-dev imagemagick
- pip install --no-cache-dir -r requirements.txt
- export MAGICK_HOME=/usr
- pelican ./content/ -o /output -s publishconf.py --relative-urls
- ls /output
- name: Push to bucket opytex.org
image: plugins/s3-sync:1
volumes:
- name: pelican-output
path: /drone/src/output
settings:
bucket: opytex.org
endpoint: https://storage.opytex.org
access_key:
from_secret: minio_access_key
secret_key:
from_secret: minio_secret_key
source: /output
target: /enseignements/${DRONE_BRANCH}
path_style: true
delete: true
volumes:
- name: pelican-output
temp: {}

1
.gitignore vendored
View File

@@ -6,3 +6,4 @@ content
__pycache__
*.pid
venv/
.vim/

View File

@@ -48,6 +48,7 @@ help:
@echo ' '
html:
lessc $(BASEDIR)/theme/static/stylesheet/style.less $(BASEDIR)/theme/static/stylesheet/style.min.css -x
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(CONFFILE) $(PELICANOPTS)
clean:

View File

@@ -8,10 +8,10 @@ DISPLAY_PAGES_ON_MENU = False
DISPLAY_CATEGORIES_ON_MENU = False
MENUITEMS = [
#("Dernières modifications", SITEURL+"blog_index.html"),
("Accueil", "/"),
("Contenus de cours", "/pages/tout-sur-mes-cours.html"),
('blog', '/blog_index.html'),
('Opytex', "/opytex/"),
("pyMath", "/pymath/"),
('Blog', '/blog_index.html'),
('Informatique', "/pages/projets-informatiques.html"),
('À propos', "/pages/a-propos.html"),
]

View File

@@ -11,7 +11,7 @@ sys.path.append(os.curdir)
from pelicanconf import *
# If your site is available via HTTPS, make sure SITEURL begins with https://
SITEURL = 'https://opytex.org/enseignements/2019-2020/'
SITEURL = 'https://raw.opytex.org/enseignements/2019-2020/'
RELATIVE_URLS = False
FEED_ALL_ATOM = 'feeds/all.atom.xml'

View File

@@ -1,11 +1,15 @@
beautifulsoup4==4.9.1
blinker==1.4
docutils==0.13.1
feedgenerator==1.9
Jinja2==2.9.6
MarkupSafe==1.0
pelican==3.7.1
Pygments==2.2.0
python-dateutil==2.6.0
pytz==2017.2
six==1.10.0
Unidecode==0.4.20
bs4==0.0.1
docutils==0.16
feedgenerator==1.9.1
Jinja2==2.11.2
MarkupSafe==1.1.1
pelican==4.2.0
Pygments==2.6.1
python-dateutil==2.8.1
pytz==2020.1
six==1.15.0
soupsieve==2.0.1
Unidecode==1.1.1
Wand==0.6.2

136
tasks.py Normal file
View 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))

View File

@@ -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 {

File diff suppressed because one or more lines are too long

View File

@@ -23,7 +23,7 @@
@sidebar-bg: @grey;
@sidebar-text-color: @white;
@sidebar-link-color: @white;
@sidebar-link-hover-color: @light-grey;
@sidebar-link-hover-color: @light-orange;
// Buttons
@btn-bg: @orange;

View File

@@ -81,9 +81,9 @@
{% endif %}
</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>
@@ -99,26 +99,28 @@
<nav>
<ul class="list">
{% 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 %}
</ul>
</nav>
<h2><a href="{{ SITEURL }}/tags.html">
Thèmes
</a></h2>
<nav>
<ul class="tagcloud">
{% for tag in tag_cloud %}
<li class="tag-{{ tag.1 }}">
<a href="{{ SITEURL }}/{{ tag.0.url }}">
{{ tag.0 }}
{% if TAG_CLOUD_BADGE %}
<span class="badge">{{ tag.2 }}</span>
{% endif %}
</a>
</li>
{% endfor %}
</ul>
<ul class="tagcloud">
{% for tag in tag_cloud %}
<li class="tag-{{ tag.1 }}">
<a href="{{ SITEURL }}/{{ tag.0.url }}">
{{ tag.0 }}
{% if TAG_CLOUD_BADGE %}
<span class="badge">{{ tag.2 }}</span>
{% endif %}
</a>
</li>
{% endfor %}
</ul>
</nav>
</div>
@@ -126,8 +128,6 @@
<main>
{% if MAIN_MENU %}
<nav>
<a href="/">{{ _('Home') }}</a>
{% for title, link in MENUITEMS %}
<a href="{{ link }}">{{ title }}</a>
{% endfor %}
@@ -173,5 +173,6 @@
{% if GITHUB_CORNER_URL %}
{% include 'partial/github.html' %}
{% endif %}
<script type="text/javascript" async defer data-website-id="2cb9cd4c-66da-4e4f-9e84-a2d53c7b07bc" src="https://stat.opytex.org/umami.js"></script>
</body>
</html>