Project ideas for SOC 2014

Release goal of moin2 is "a basic, but powerful wiki".

For further infos about moin2 read MoinMoin2.0.

As we still can't release moin2 because it doesn't fully work yet, still looks ugly, misses stuff, etc. - we should focus on the release-critical stuff and not work on optional or non-essential stuff. Students: please keep that in mind when writing your application.

Mentors/Helpers: Before putting project ideas here, please check whether the idea is in that scope.

Hints for students

These are just some basic and sometimes vague ideas. If you want to do a SOC project, we expect much more detailled/specific ideas and time planning from you.

In general, the success of a (SOC) project depends quite a bit on good planning:

Some of this stuff can and should be done before you submit your proposal / before coding starts.

Start preparing early, get in contact with us early.

To get in contact with us, use the MoinMoinChat (preferred) or the MoinMoinMailingLists.

If you like to publically express your interest in some project idea, put your name in the "Students interested" lines. Please note that this is completely optional, voluntary and for student's mutual information. Formally, only stuff in melange will count.

As we are participating under PSF umbrella in 2014, please see there: https://wiki.python.org/moin/SummerOfCode/ApplicationTemplate2014 For your application, you can use DeveloperApplicationTemplate.

If you want to work on your application on the wiki, you can request an ACL protected subpage of your wiki homepage, so that only mentors can read it (but not other students).

Hints for mentors

Please add yourself in some "Mentors interested" lines. If you don't think you should be primary mentor for this, but you would co-mentor this, put your name in parentheses. This is just for info, formally only stuff in melange will count.

Project Ideas

Improve bootstrap theme *2014 GSOC Project, some of the ideas below may be complete

In general: Create a well-structured, consistent, good looking and well usable UI for moin2.

requires: bootstrap 3 coding and design skills, usability, html/css/jquery/js/python (you will also need to deal with jinja2 templates, but if you know any other templating language and python, that should be easy)

Mentors interested: (ThomasWaldmann) (RogerHaase)

Students interested: ChitrankDixit, SaurabhKathpalia

More specific ideas follow:

Looks

Much stuff looks a bit boring and some stuff has slight issues. Make it look fresher and better.

UI for name list changes

moin supports multiple names per item (revision), we need a good UI for the basic operations on the names list.

also support changes of multiple items at once (see index, e.g. rename).

add/change/remove quicklinks

UI for dealing with ACLs

Mentors interested: (ReimarBauer)

Students interested: SaurabhKathpalia

It would be interesting to have some graphical visualisation of access rights for items (per user, per group).

A user could see what he can do in the wiki, an admin could see what a specific user or group has access to.

It also would be helpful if an admin could preview the effects of changes of hierarchical ACLs or item names.

Currently, we only can setup ACLs by editing metadata - we need an UI which enables setting ACLs comfortably.

The given and new acls should also be visualized.

Search UI

whoosh is a quite powerful search engine, but our current UI does not make good use of it - we need a better UI that gives a nice user experience.

ngrams, facetting, ajax, autocompletion, spellchecking, more like this, help to construct more advanced queries, ...

Trash and Purge Policy

Visualize "deleted" items (trashbin view), enable undeletion (for users), enable destruction (for admins).

To purge means to permanently remove stuff stored in the wiki storage, the policy would define the rules for that.

requires: python, html/css/jinja2 for UI parts

Mentors interested: ThomasWaldmann

Students interested: KumarRishabh, NitinAgarwal, Ankur Saldhi

requires: python

Mentors interested: (ThomasWaldmann)

Students interested: AnaBalica, NitinAgarwal

Validation of Wiki Contents

Use metadata to check whether the contents are still valid (not corrupted).

Mentors interested: ThomasWaldmann

Students interested:

moin2 uses emeraldtree (which is a fork of elementtree) for dealing with xml.

Some stuff there needs to be fixed / added as a requirement for improvements in moin2:

requires: python, xml/html5, xpath

Mentors interested: (ThomasWaldmann) (RogerHaase)

Students interested:

Improve DOM converters

Moin2 uses an internal "moin-DOM" to represent a document in a tree-structure. This is used as intermediate format for all kinds of input and output formats.

Requires: experience with tree representations, XML, elementtree (emeraldtree) plus the input/output formats mentioned below.

We have quite a lot of DOM converters, but they need improvement:

requires: python, xml/xpath

Mentors interested: (ThomasWaldmann) (RogerHaase)

Students interested:

Unify macros and converters

It's somehow the same, but implemented differently.

But:

requires: python, xml

Mentors interested: ThomasWaldmann

Students interested: SandeepKaur

Network API

For moin2 we need a network api that can be used by the user interface, other wiki instances (e.g. for wiki sync) and scripts.

requires: python (some js/json/ajax skills might be helpful)

Mentors interested: ThomasWaldmann, (DmitriiMiliaev)

Students interested: TarashishMishra

Remote editor wrapper

Using the network API, a comfortable remote editor wrapper can get implemented.

requires: python (some js/json/ajax skills might be helpful)

Mentors interested: ThomasWaldmann

Students interested:

Universal Pastebin

Using metadata, some forms, some queries, some views, we could do a pastebin in moin2.

The pastebin could support all sorts of items (as moin does).

Using the network API, a commandline client for the pastebin could be implemented.

requires: python, jquery/js, flatland/jinja2, UI skills

Mentors interested: ThomasWaldmann

Students interested: TarashishMishra, NitinAgarwal

Collab editor

We could make pretty good use of a collaborative editor for editing (text) items.

Maybe use http://togetherjs.com

Issues to check before proposing this:

Mentors interested: ThomasWaldmann

Students interested:

Plugin system

Half done in 2012, try again?

There should be a evaluation of the 2012 stuff before this is proposed, so it doesn't start from scratch (if not needed due to reasons).

Mentors interested: ThomasWaldmann (RogerHaase)

Students interested: KumarRishabh

Android app

/!\ Note: this is pretty much a vague idea yet, we first have to check whether someone can mentor it.

How could a moin2 client app look like? (opposed to just using a browser)

Language: Python? Java? Who can mentor the android side? see at http://kivy.org/#home if we want a crossplatform app

Mentors interested: (ThomasWaldmann)

Students interested:

Increasing test coverage / Python 3.x porting

/!\ Just an idea. Needs evaluation whether it should be done now or rather later.

moin2 currently only works on python 2.7 and depends on some libraries/frameworks with varying py3 support, see Python3.

moin2 will support python 2.x as primary platform, but maybe could support python 3.x as well.

Requires: python 2 to 3 porting experience (you need to provide a reference to code you ported), insightful proposal describing how you would do the port

Mentors interested: ThomasWaldmann, (DmitriiMiliaev)

Students interested:

Issue tracker *2014 GSOC Project, some of the ideas below may be complete

The issue tracker needs more improvements to be practically useful. You may locate some of the existing code in /MoinMoin/items/ticket.py, /moinMoin/security/ticket.py, and /MoinMoin/templates/ticket/. To exercise the existing code, install moin2, start built-in server, create a new item and from the "Item not found, create it now?" page select "Ticket" from the list of choices. You will likely be able to create a ticket and save it, but the code to update a ticket appears broken.

Requires: python, html/css, jquery/js, flatland/jinja2, UI skills

Mentors interested: (ThomasWaldmann)

Students interested:

Blog *2014 GSOC Project, some of the ideas below may be complete

The blogging code needs more improvements to be practically useful. See existing code in /MoinMoin/items/blog.py and /MoinMoin/templates/blog/. To exercise the existing code, install moin2, start built-in server, create a new item and from the "Item not found, create it now?" page select "Blog" from the list of choices. Type a few starting lines and save. Then create a blog entry by creating a new sub-item (usually name is <blog-name>/<topic-name>) and choosing "Blog entry" from the "Item not found...: page. You should be able to create multiple blog entries, but the code to modify a blog entry or add a discussion page appears broken.

Requires: python, html/css, jquery/js, flatland/jinja2, UI skills

Mentors interested: (ThomasWaldmann)

Students interested:

Branching, merging and syncing

We have seen in 2012 that this is rather complex - try again?

moin 1.9 data cleanup

Some day, we'll want to migrate moin 1.9 data into moin2. But if one looks into the data storage of a typical moin 1.x installation (esp. if it was open to the public), one sees that there is quite some need for cleanup (and we should do that before importing into moin2). Also, multiple separate wikis need cleanup if they shall become a farm wiki (or even a single wiki with multiple namespaces) with common users.

Code should be written in a way so it can be used even for wikis staying on 1.9.x (and not migrating to moin2 at the same time).

requires: python (maybe also UI stuff, depending on how you suggest to solve)

Mentors interested: ThomasWaldmann (RogerHaase)

Students interested:

Your Idea?

You may suggest projects based on own ideas that are not found on this page.

If you like to do that, it is a good idea to discuss them with the developers first so we can see if they are in scope of the moin 2.0 release, etc. - please keep in mind that this takes some time, so start early.

Other

MoinMoin: GoogleSoc2014/InitialProjectIdeas (last edited 2014-09-13 19:07:28 by RogerHaase)