Skip to content

Commit

Permalink
python3Packages.froide: init at 0-unstable-2024-11-22
Browse files Browse the repository at this point in the history
  • Loading branch information
onny committed Nov 25, 2024
1 parent fcdc4b9 commit e267b6a
Show file tree
Hide file tree
Showing 3 changed files with 224 additions and 0 deletions.
203 changes: 203 additions & 0 deletions pkgs/development/python-modules/froide/default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,203 @@
{
lib,
python3,
fetchFromGitHub,
gdal,
geos,
pnpm,
nodejs,
postgresql,
postgresqlTestHook,
playwright-driver,
}:
let

python = python3.override {
packageOverrides = self: super: {
django = super.django.override { withGdal = true; };

# Project discontinued upstream
# https://github.com/okfde/froide/issues/893
django-fsm = self.buildPythonPackage rec {
pname = "django-fsm";
version = "3.0.0";
pyproject = true;

src = fetchFromGitHub {
owner = "viewflow";
repo = "django-fsm";
rev = "refs/tags/${version}";
hash = "sha256-woN0F4hTaPk8HTGNT6zQlZDJ9SCVRut9maKSlDmalUE=";
};

build-system = [ self.setuptools ];

dependencies = [ self.django ];

checkInputs = [ self.django-guardian ];

checkPhase = ''
${python3.interpreter} tests/manage.py test
'';

pythonImportsCheck = [ "django_fsm" ];

meta = {
description = "Django friendly finite state machine support";
homepage = "https://github.com/viewflow/django-fsm";
license = lib.licenses.mit;
knownVulnerabilities = [ "Package is marked as discontinued upstream." ];
maintainers = [ lib.maintainers.onny ];
};
};
};
};

in
python.pkgs.buildPythonPackage rec {
pname = "froide";
version = "0-unstable-2024-11-22";
pyproject = true;

src = fetchFromGitHub {
owner = "okfde";
repo = "froide";
rev = "a90f5c4d40b46a161111eefdc84e5214e85715b0";
hash = "sha256-Q+iNI3yqxqAtDONHY+SaZeMyjY6hqTxwy7YmiiY94+0=";
};

patches = [ ./django_42_storages.patch ];

pythonRelaxDeps = [
"pikepdf"
"channels"
];

build-system = [ python.pkgs.setuptools ];

nativeBuildInputs = [
pnpm.configHook
nodejs
];

dependencies = with python.pkgs; [
bleach
celery
celery-singleton
channels
coreapi
dj-database-url
django
django-celery-beat
django-celery-email
django-configurations
django-contrib-comments
django-crossdomainmedia
django-elasticsearch-dsl
django-filingcabinet
django-filter
django-fsm
django-json-widget
django-leaflet
django-mfa3
django-oauth-toolkit
django-parler
django-storages
django-taggit
django-treebeard
djangorestframework
djangorestframework-csv
djangorestframework-jsonp
drf-spectacular
drf-spectacular-sidecar
easy-thumbnails
elasticsearch
elasticsearch-dsl
geoip2
icalendar
markdown
phonenumbers
pillow
pikepdf
psycopg
pygtail
pyisemail
pypdf
python-magic
python-mimeparse
python-slugify
requests
wand
weasyprint
websockets
];

pnpmDeps = pnpm.fetchDeps {
inherit pname version src;
hash = "sha256-DMoaXNm5S64XBERHFnFM6IKBkzXRGDEYWSTruccK9Hc=";
};

postBuild = ''
pnpm run build
'';

postInstall = ''
cp -r build $out/${python.sitePackages}/froide/
'';

nativeCheckInputs = with python.pkgs; [
(postgresql.withPackages (p: [ p.postgis ]))
postgresqlTestHook
pytest-django
pytest-playwright
pytestCheckHook
];

checkInputs = with python.pkgs; [
beautifulsoup4
pytest-factoryboy
time-machine
];

disabledTests = [
# Requires network connection: elastic_transport.ConnectionError
"test_search_similar"
"test_search"
"test_list_requests"
"test_list_jurisdiction_requests"
"test_tagged_requests"
"test_publicbody_requests"
"test_feed"
"test_request_list_filter_pagination"
"test_request_list_path_filter"
"test_web_page"
"test_autocomplete"
"test_list_no_identical"
"test_set_status"
"test_make_not_logged_in_request"
"test_make_logged_in_request"
# TypeError: Pygtail.with_offsets() got an unexpected keyword argument
"test_email_signal"
"test_pygtail_log_append"
"test_bouncing_email"
"test_multiple_partial"
"test_logfile_rotation"
];

preCheck = ''
export PGUSER="froide"
export postgresqlEnableTCP=1
export postgresqlTestUserOptions="LOGIN SUPERUSER"
export GDAL_LIBRARY_PATH="${gdal}/lib/libgdal.so"
export GEOS_LIBRARY_PATH="${geos}/lib/libgeos_c.so"
export PLAYWRIGHT_BROWSERS_PATH="${playwright-driver.browsers}"
'';

meta = {
description = "Freedom of Information Portal";
homepage = "https://github.com/okfde/froide";
license = lib.licenses.mit;
maintainers = [ lib.maintainers.onny ];
mainProgram = "froide";
};
}
19 changes: 19 additions & 0 deletions pkgs/development/python-modules/froide/django_42_storages.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
diff --git a/froide/settings.py b/froide/settings.py
index 428349cb..1e1bd7a8 100644
--- a/froide/settings.py
+++ b/froide/settings.py
@@ -867,9 +867,11 @@ class Production(Base):

ALLOWED_HOSTS = values.TupleValue(("example.com",))
CELERY_TASK_ALWAYS_EAGER = values.BooleanValue(False)
- STATICFILES_STORAGE = (
- "django.contrib.staticfiles.storage.ManifestStaticFilesStorage"
- )
+ STORAGES = {
+ 'staticfiles': {
+ 'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage',
+ },
+ }


class SSLSite(object):
2 changes: 2 additions & 0 deletions pkgs/top-level/python-packages.nix
Original file line number Diff line number Diff line change
Expand Up @@ -4888,6 +4888,8 @@ self: super: with self; {

fritzconnection = callPackage ../development/python-modules/fritzconnection { };

froide = callPackage ../development/python-modules/froide { };

frozendict = callPackage ../development/python-modules/frozendict { };

frozenlist = callPackage ../development/python-modules/frozenlist { };
Expand Down

0 comments on commit e267b6a

Please sign in to comment.