Newer
Older
# Works around a setuptools 50 issue
# AK, 2020-12-11
# taken from https://github.com/AnalogJ/lexicon/pull/629/files
requires = [
"setuptools!=50",
"poetry>=0.12",
]
build-backend = "poetry.masonry.api"
[tool.poetry]
name = "relate-courseware"
Andreas Klöckner
committed
version = "2020.1"
description = "RELATE courseware"
readme = "README.rst"
repository = "https://github.com/inducer/relate"
documentation = "https://documen.tician.de/relate/"
authors = ["Andreas Kloeckner <inform@tiker.net>"]
license = "MIT"
packages = [
{ include = "course" },
{ include = "accounts" },
{ include = "relate" },
[tool.poetry.scripts]
relate = "relate.bin.relate:main"
# Automatically renders Django forms in a pretty, Bootstrap-compatible way.
django-crispy-forms = ">=1.5.1"
# Page data, answer data, ... all represented in JSON. This makes that editable in the Django admin.
jsonfield = ">=1.4.0"
# /!\ Upstream is dead, using branch for Django 3.0 support
django-yamlfield = {git = "https://github.com/bakatrouble/django-yamlfield.git", rev = "c92d0373d12a02d1e52fb09b44010f156111d7ea"}
# For easy content formatting:
markdown = "^2.6.3"
# For rendering macros in content:
jinja2 = "^2.11.2"
# For math/symbolic questions
pymbolic = "*"
sympy = "*"
# Django timezone support
pytz = "^2020.1"
# Course content is stored in YAML.
pyyaml = "*"
# Dulwich git integration
dulwich = "^0.20.3"
ecdsa = "^0.15"
# FIXME: 2.7.1 gives bogus 'incorrect padding' error on PEM parsing
paramiko = "<2.7"
# A date picker widget - https://github.com/tutorcruncher/django-bootstrap3-datetimepicker
django-bootstrap3-datetimepicker-2 = "^2.8.2"
# For in-class instant messaging
dnspython = "^1.16.0"
SleekXMPP = "^1.3.3"
# To manage web dependencies
django-npm = "^1.0.0"
# For comfortable code entry
django-codemirror-widget = ">=0.5"
# For code isolation in code questions
docker-py = "^1.10.6"
# For code highlighting, required via the CodeHilite extension to Python-Markdown
pygments = "^2.6.1"
# For grade export
unicodecsv = "^0.14.1"
# To support network matching for facility recognition
ipaddress = "^1.0.23"
Andreas Klöckner
committed
Andreas Klöckner
committed
Andreas Klöckner
committed
# }}}
future = "^0.18.2"
# Try to avoid https://github.com/Julian/jsonschema/issues/449
attrs = ">=19"
python-memcached = "^1.59"
# {{{ celery and related
#
# 5.1.0 exclusion:
# https://github.com/celery/celery/issues/6797
# https://github.com/celery/celery/commit/8a4056087aeac6a5be79a2db4d6f06975f754609
celery = "^5.0.5,!=5.1.0"
django_select2 = "^7.4.2"
# To sanitize HTML generated by user code
Andreas Klöckner
committed
bleach = "^3.1.5"
# bleach is based on html5lib, but they vendor it. I don't think we should fish the
# vendored bits out of bleach, so we'll introduce our own dependency for data-URI
# sanitization.
html5lib = "^1.1"
# For query lexing
pytools = "^2020.2"
# For rendering ipython notebook
nbconvert = "^5.2.1"
IPython = "^7.15.0"
# For relate script
colorama = "*"
# not a direct dependency
# version constraint is here because of CVE-2020-25659
cryptography = "^3.2.1"
social-auth-app-django = "^4.0.0"
[tool.poetry.dev-dependencies]
factory_boy = "^2.12.0"
pytest = "^5.4.3"
pytest-django = "^3.9.0"
pytest-factoryboy = "^2.0.3"
pytest-cov = "^2.10.0"
furo = "^2020.11.27b19"
sphinx-copybutton = "^0.3.1"
Andreas Klöckner
committed
types-pytz = "^0.1.0"
types-bleach = "^0.1.2"
types-Jinja2 = "^0.1.3"
types-paramiko = "^0.1.3"
types-Markdown = "^0.1.2"
types-PyYAML = "^0.1.5"
Andreas Klöckner
committed
# vim: foldmethod=marker