Skip to content

Commit

Permalink
Merge pull request #679 from ae-utbm/xapian-from-sources
Browse files Browse the repository at this point in the history
Xapian from sources and fix CVE
  • Loading branch information
klmp200 authored Jun 26, 2024
2 parents ee43764 + ca27b89 commit a8b9f38
Show file tree
Hide file tree
Showing 8 changed files with 878 additions and 666 deletions.
8 changes: 6 additions & 2 deletions .github/actions/setup_project/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,13 @@ runs:
- name: Install apt packages
uses: awalsh128/cache-apt-pkgs-action@latest
with:
packages: gettext libxapian-dev libgraphviz-dev
packages: gettext libgraphviz-dev
version: 1.0 # increment to reset cache

- name: Install dependencies
run: |
sudo apt update
sudo apt install gettext libxapian-dev libgraphviz-dev
sudo apt install gettext libgraphviz-dev
shell: bash

- name: Set up python
Expand Down Expand Up @@ -48,6 +48,10 @@ runs:
run: poetry install -E testing -E docs
shell: bash

- name: Install xapian
run: poetry run ./manage.py install_xapian
shell: bash

- name: Compile gettext messages
run: poetry run ./manage.py compilemessages
shell: bash
67 changes: 67 additions & 0 deletions core/management/commands/install_xapian.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
# -*- coding:utf-8 -*
#
# Copyright 2024 © AE UTBM
# [email protected] / [email protected]
#
# This file is part of the website of the UTBM Student Association (AE UTBM),
# https://ae.utbm.fr.
#
# You can find the source code of the website at https://github.com/ae-utbm/sith3
#
# LICENSED UNDER THE GNU GENERAL PUBLIC LICENSE VERSION 3 (GPLv3)
# SEE : https://raw.githubusercontent.com/ae-utbm/sith3/master/LICENSE
# OR WITHIN THE LOCAL FILE "LICENSE"
#
#

import os
import tomli
import subprocess
from django.core.management.base import BaseCommand, CommandParser
from pathlib import Path


class Command(BaseCommand):
help = "Install xapian"

def add_arguments(self, parser: CommandParser):
parser.add_argument(
"-f",
"--force",
action="store_true",
help="Force installation even if already installed",
)

def _current_version(self) -> str | None:
try:
import xapian
except ImportError:
return None
return xapian.version_string()

def _desired_version(self) -> str:
with open(
Path(__file__).parent.parent.parent.parent / "pyproject.toml", "rb"
) as f:
pyproject = tomli.load(f)
return pyproject["tool"]["xapian"]["version"]

def handle(self, force: bool, *args, **options):
if not os.environ.get("VIRTUAL_ENV", None):
print("No virtual environment detected, this command can't be used")
return

desired = self._desired_version()
if desired == self._current_version():
if not force:
print(
f"Version {desired} is already installed, use --force to re-install"
)
return
print(f"Version {desired} is already installed, re-installing")
print(f"Installing xapian version {desired} at {os.environ['VIRTUAL_ENV']}")
subprocess.run(
[str(Path(__file__).parent / "install_xapian.sh"), desired],
env=dict(os.environ),
).check_returncode()
print("Installation success")
47 changes: 47 additions & 0 deletions core/management/commands/install_xapian.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
#!/usr/bin/env bash
# Originates from https://gist.github.com/jorgecarleitao/ab6246c86c936b9c55fd
# first argument of the script is Xapian version (e.g. 1.2.19)
VERSION=$1

# Cleanup env vars for auto discovery mechanism
export CPATH=
export LIBRARY_PATH=
export CFLAGS=
export LDFLAGS=
export CCFLAGS=
export CXXFLAGS=
export CPPFLAGS=

# prepare
rm -rf "$VIRTUAL_ENV/packages"
mkdir -p "$VIRTUAL_ENV/packages" && cd "$VIRTUAL_ENV/packages" || exit 1

CORE=xapian-core-$VERSION
BINDINGS=xapian-bindings-$VERSION

# download
echo "Downloading source..."
curl -O "https://oligarchy.co.uk/xapian/$VERSION/${CORE}.tar.xz"
curl -O "https://oligarchy.co.uk/xapian/$VERSION/${BINDINGS}.tar.xz"

# extract
echo "Extracting source..."
tar xf "${CORE}.tar.xz"
tar xf "${BINDINGS}.tar.xz"

# install
echo "Installing Xapian-core..."
cd "$VIRTUAL_ENV/packages/${CORE}" || exit 1
./configure --prefix="$VIRTUAL_ENV" && make && make install

PYTHON_FLAG=--with-python3

echo "Installing Xapian-bindings..."
cd "$VIRTUAL_ENV/packages/${BINDINGS}" || exit 1
./configure --prefix="$VIRTUAL_ENV" $PYTHON_FLAG XAPIAN_CONFIG="$VIRTUAL_ENV/bin/xapian-config" && make && make install

# clean
rm -rf "$VIRTUAL_ENV/packages"

# test
python -c "import xapian"
29 changes: 27 additions & 2 deletions core/views/files.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,12 +79,37 @@ def send_file(request, file_id, file_class=SithFile, file_attr="file"):
return response


class MultipleFileInput(forms.ClearableFileInput):
allow_multiple_selected = True


class _MultipleFieldMixin:
def __init__(self, *args, **kwargs):
kwargs.setdefault("widget", MultipleFileInput())
super().__init__(*args, **kwargs)

def clean(self, data, initial=None):
single_file_clean = super().clean
if isinstance(data, (list, tuple)):
result = [single_file_clean(d, initial) for d in data]
else:
result = [single_file_clean(data, initial)]
return result


class MultipleFileField(_MultipleFieldMixin, forms.FileField):
...


class MultipleImageField(_MultipleFieldMixin, forms.ImageField):
...


class AddFilesForm(forms.Form):
folder_name = forms.CharField(
label=_("Add a new folder"), max_length=30, required=False
)
file_field = forms.FileField(
widget=forms.ClearableFileInput(attrs={"multiple": True}),
file_field = MultipleFileField(
label=_("Files"),
required=False,
)
Expand Down
27 changes: 14 additions & 13 deletions doc/start/install.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ Certaines dépendances sont nécessaires niveau système :
* poetry
* libssl
* libjpeg
* libxapian-dev
* zlib1g-dev
* python
* gettext
Expand Down Expand Up @@ -76,13 +75,13 @@ Sur Ubuntu
# Sait-on jamais
sudo apt update

sudo apt install python-is-python3 # Permet d'utiliser python au lieu de python3, c'est optionel
sudo apt install python-is-python3 # Permet d'utiliser python au lieu de python3, c'est optionnel

sudo apt install build-essentials libssl-dev libjpeg-dev zlib1g-dev python-dev \
libffi-dev python-dev-is-python3 libgraphviz-dev pkg-config libxapian-dev \
gettext git
libffi-dev python-dev-is-python3 libgraphviz-dev pkg-config \
gettext git pipx

curl -sSL https://install.python-poetry.org | python -
pipx install poetry

.. note::

Expand All @@ -92,22 +91,21 @@ Sur Ubuntu
Sur MacOS
~~~~~~~~~

Pour installer les dépendances, il est fortement recommandé d'installer le gestionnaire de paquets `homebrew <https://brew.sh/index_fr>`_.
Pour installer les dépendances, il est fortement recommandé d'installer le gestionnaire de paquets `homebrew <https://brew.sh/index_fr>`_.
Il est également nécessaire d'avoir installé xcode

.. sourcecode:: bash

brew install git python xapian graphviz poetry

# Si vous aviez une version de python ne venant pas de homebrew
brew link --overwrite python
echo 'export PATH="$(brew --prefix graphviz)/bin:$PATH"' >> ~/.zshrc
echo 'export CFLAGS="-isysroot /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk -I $(brew --prefix graphviz)/include"' >> ~/.zshrc
echo 'export LDFLAGS="-L /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/lib -L $(brew --prefix graphviz)/lib"' >> ~/.zshrc

brew install git python graphviz pipx
pipx install poetry

# Pour bien configurer gettext
brew link gettext # (suivez bien les instructions supplémentaires affichées)

# Pour installer poetry
pip3 install poetry

.. note::

Si vous rencontrez des erreurs lors de votre configuration, n'hésitez pas à vérifier l'état de votre installation homebrew avec :code:`brew doctor`
Expand All @@ -134,6 +132,9 @@ Finaliser l'installation
# Activation de l'environnement virtuel
poetry shell

# Installe xapian
python manage.py install_xapian

# Prépare la base de données
python manage.py setup

Expand Down
Loading

0 comments on commit a8b9f38

Please sign in to comment.