Personal fork from https://anonscm.debian.org/git/nm/nm2.git
Enrico Zini e6c774c725 Notify log entries to nm@debian.org | 8 years ago | |
---|---|---|
api | 8 years ago | |
apikeys | 8 years ago | |
backend | 8 years ago | |
contributors | 10 years ago | |
deblayout | 8 years ago | |
dm | 8 years ago | |
dsa | 8 years ago | |
fprs | 8 years ago | |
keyring | 8 years ago | |
locale | 11 years ago | |
maintenance | 10 years ago | |
minechangelogs | 8 years ago | |
nm2 | 8 years ago | |
nmlayout | 8 years ago | |
person | 8 years ago | |
process | 8 years ago | |
projectb | 8 years ago | |
public | 8 years ago | |
restricted | 8 years ago | |
templates | 8 years ago | |
test_data | 8 years ago | |
wizard | 8 years ago | |
.coveragerc | 8 years ago | |
.gitignore | 8 years ago | |
LICENSE | 9 years ago | |
README.md | 8 years ago | |
TODO | 11 years ago | |
archive-process-email | 8 years ago | |
coverage.sh | 8 years ago | |
debsso | 8 years ago | |
fabfile.py | 10 years ago | |
manage.py | 10 years ago | |
test-archive-process-email | 9 years ago | |
urls.py | 8 years ago |
apt-get install python-markdown python-ldap python-psycopg2 python-xapian \
python-django python-django-south python-django-housekeeping \
python-debian python-debiancontributors
The ‘python-django-housekeeping’ package is not available in Debian earlier than Debian Stretch. If you are deploying to a machine running Debian earlier than Stretch, use the following procedure:
# https://github.com/spanezz/django-housekeeping
git clone https://github.com/spanezz/django-housekeeping
(you can either build the package from it or symlink the module directory
into the contributors.debian.org sources)
# build the package
fakeroot debian/rules clean binary
# install the package
dpkg -i ../python-django-housekeeping_0.1-1_all.deb
mkdir data # required by default settings
cd nm2
ln -s local_settings.py.devel local_settings.py
edit local_settings.py as needed
./manage.py migrate
Visit https://nm.debian.org/am/db-export to download nm-mock.json; for privacy, sensitive information are replaced with mock strings.
If you cannot login to the site, you can ask any DD to download it for you. There is nothing secret in the file, but I am afraid of giving out convenient email databases to anyone.
./manage.py import nm-mock.json
If you are a Front Desk member or a DAM, you can use https://nm.debian.org/am/db-export?full for a full database export.
rsync -az --progress keyring.debian.org::keyrings/keyrings/ ./data/keyrings/
./manage.py housekeeping
./manage.py runserver
You need to run periodic maintenance to check/regenerate the denormalised fields:
./manage.py housekeeping
Development targets Django 1.8, although the codebase has been created with Django 1.2 and it still shows in some places. Feel free to cleanup.
Unusual things in the design:
backend/
has the core models. Note that backend.models.Process
is the
old-style workflow, and process.model.Process
is the new style workflow.backend.models.VisitorPermissions
, and that generates a set of permission
strings that get tested in views and templates with things like if
"edit_bio" in visit_perms: …
.backend.mixins.VisitorMixin
is the root of a class hierarchy of mixins used
by most views in the site; those mixins implement the basis of resource
instantiation and permission checking.