Size: 1170
Comment:
|
Size: 4344
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
#pragma page-filename DEV/versions/10354701 | #pragma page-filename DEV/versions/15171627 |
Line 3: | Line 3: |
This page should serve as a place to update everyone with the current state of development on the Mailman web UI, but also to discuss the progress and/or decisions being made while developing. | |
Line 5: | Line 4: |
== Web Framework == For now we have decided on using Django as the web framework for the UI. |
== Postorius == |
Line 8: | Line 6: |
Django distincts between ''projects'' and ''applications'' (a project being a website or a set of applications). One advantage of that is the possibility to make a django app reusable in other django projects/websites. Ideally people should be able to choose to either install the web ui as a stand-alone django project or to integrate the mailmanweb app into their existing django website. | Postorius is the main component of the administrative interface of Mailman 3. It is an application based on the Django framework and is currently in alpha state. The project is hosted on Launchpad: |
Line 10: | Line 8: |
== REST Communication == The web UI communicates with Mailman over the REST server included in MM3. The request methods to acces the server are placed in a separate REST client module which will be used by the web ui. The idea is to make it really easy for other Python programs to import the module and talk to Mailman. |
[[https://launchpad.net/postorius|https://launchpad.net/postorius]] |
Line 13: | Line 10: |
== Test Server == A test server with a basic setup of the web UI is currently being set up. |
Currently Postorius has all basic management features, like creating lists and domains, editing list settings, moderating messages and, of course, (un)subscribing to/from lists. Authentication is handled by Django's own authentication app, or optionally by Mozilla's BrowserID service. So far it cannot handle roles Postorius uses mailman.client, the Python bindings to Mailman's REST interface: [[https://launchpad.net/mailman.client|https://launchpad.net/mailman.client]] === [[https://launchpad.net/postorius|https://launchpad.net/postorius]]Road map === This is the road map for the next alpha relase: [[https://launchpad.net/postorius/+milestone/1.0.0a2|https://launchpad.net/postorius/+milestone/1.0.0a2]] Ideas, features and topics for the next releases (just a draft - feel free to add more. If you don't like what you see, add a comment or send an angry post to the dev mailing list): * Permissions: Add missing authentication/authorization functionality (roles etc...). * Integration with other Mailman UI projects (HyperKitty, Mailman Metrics). * Anonymous subscriptions * User profile pages * Code refactoring and testing: Switch to Django class-based views to reduce redundancy and make testing easier. * Todo-functionality * UI enhancement: Ajaxify static pages where appropriate, evaluate local/offline storage for speed. * Add responsive CSS styles for mobile phones. * mailman.client: Change package name to stop it from breaking the Mailman test suite. * mailman.client: Evaluate switching to `requests` as http library instead of httlib2. * mailman.client: Tests: Move mocking from mocker to mock === Development === A quick 5 minute guide (if you're lucky) to get Postorius installed for development can be found here: [[../A 5 minute guide to get the Mailman web UI running|A 5 minute guide to get the Mailman web UI running]] A guide to hook Postorius up to Apache is part of the Postorius documentation: [[http://packages.python.org/postorius/setup.html|http://packages.python.org/postorius/setup.html]] Some preliminary notes on testing new code in Postorius (this is still a draft...): [[http://packages.python.org/postorius/development.html|http://packages.python.org/postorius/development.html]] == Systers == {{{#!wiki important Note This section has been unchanged for a while and is possible outdated. }}} Alongside the general web ui an extra django app for the Systers mailing list was developed as part of Anna Granudd's GSOC project: The plan is that there will be the "normal"/standard UI/app which only uses the core DB and accesses this via the rest client. However, with the help of Django one can add databases which can be used for alternative UI's, such as the one from Systers. The extra DB could, for instance, include the following tables and content (although with this content the user table is probably redundant and can be removed): '''Table "user"''' * id integer not null (to connect to core db), PK * URL text (specific "link_id" for each user) * required_id integer (connects to the "required" table) * web_url text (if someone, for instance, wish to add a link to a blog or similar) '''Table mailing list''' * id integer not null (to connect to core db), PK * URL text (specific "link_id") * picture base64-encoded (if, for instance, the organization using the mailing list wants to add a logo) * dlist_enabled boolean (Systers specific) * questions_essay text (Systers specific) * required_id integer (connects to the "required" table) '''Table required''' * id integer not null, PK * fullname_req boolean (Systers specific, possibly for core as well) * essay_req boolean (Systers specific) * picture_req boolean (although we'll probably want to make this optionally) Of these, the mailing list and the user tables are already present in core and would be extended with this information. |
Web UI - Status
Postorius
Postorius is the main component of the administrative interface of Mailman 3. It is an application based on the Django framework and is currently in alpha state. The project is hosted on Launchpad:
https://launchpad.net/postorius
Currently Postorius has all basic management features, like creating lists and domains, editing list settings, moderating messages and, of course, (un)subscribing to/from lists. Authentication is handled by Django's own authentication app, or optionally by Mozilla's BrowserID service. So far it cannot handle roles
Postorius uses mailman.client, the Python bindings to Mailman's REST interface:
https://launchpad.net/mailman.client
[[https://launchpad.net/postorius|https://launchpad.net/postorius]]Road map
This is the road map for the next alpha relase:
https://launchpad.net/postorius/+milestone/1.0.0a2
Ideas, features and topics for the next releases (just a draft - feel free to add more. If you don't like what you see, add a comment or send an angry post to the dev mailing list):
- Permissions: Add missing authentication/authorization functionality (roles etc...).
Integration with other Mailman UI projects (HyperKitty, Mailman Metrics).
- Anonymous subscriptions
- User profile pages
- Code refactoring and testing: Switch to Django class-based views to reduce redundancy and make testing easier.
- Todo-functionality
- UI enhancement: Ajaxify static pages where appropriate, evaluate local/offline storage for speed.
- Add responsive CSS styles for mobile phones.
- mailman.client: Change package name to stop it from breaking the Mailman test suite.
mailman.client: Evaluate switching to requests as http library instead of httlib2.
- mailman.client: Tests: Move mocking from mocker to mock
Development
A quick 5 minute guide (if you're lucky) to get Postorius installed for development can be found here:
A 5 minute guide to get the Mailman web UI running
A guide to hook Postorius up to Apache is part of the Postorius documentation:
http://packages.python.org/postorius/setup.html
Some preliminary notes on testing new code in Postorius (this is still a draft...):
http://packages.python.org/postorius/development.html
Systers
Note
This section has been unchanged for a while and is possible outdated.
Alongside the general web ui an extra django app for the Systers mailing list was developed as part of Anna Granudd's GSOC project:
The plan is that there will be the "normal"/standard UI/app which only uses the core DB and accesses this via the rest client. However, with the help of Django one can add databases which can be used for alternative UI's, such as the one from Systers. The extra DB could, for instance, include the following tables and content (although with this content the user table is probably redundant and can be removed):
Table "user"
- id integer not null (to connect to core db), PK
- URL text (specific "link_id" for each user)
- required_id integer (connects to the "required" table)
- web_url text (if someone, for instance, wish to add a link to a blog or similar)
Table mailing list
- id integer not null (to connect to core db), PK
- URL text (specific "link_id")
- picture base64-encoded (if, for instance, the organization using the mailing list wants to add a logo)
- dlist_enabled boolean (Systers specific)
- questions_essay text (Systers specific)
- required_id integer (connects to the "required" table)
Table required
- id integer not null, PK
- fullname_req boolean (Systers specific, possibly for core as well)
- essay_req boolean (Systers specific)
- picture_req boolean (although we'll probably want to make this optionally)
Of these, the mailing list and the user tables are already present in core and would be extended with this information.