Note: You are currently viewing documentation for Moodle 1.9. Up-to-date documentation for the latest stable version is available here: Projects for new developers.

Projects for new developers: Difference between revisions

From MoodleDocs
(suggested project - Consuming RSS Feeds)
Line 59: Line 59:


'''Old Specification:''' [[Student projects/Secure RSS feeds|Secure RSS feeds]]
'''Old Specification:''' [[Student projects/Secure RSS feeds|Secure RSS feeds]]
'''Mentor:''' [http://moodle.org/user/view.php?id=240338&course=5 Nicolas Connault]


=== Roles interface improvements ===
=== Roles interface improvements ===

Revision as of 11:48, 20 March 2008

This page lists possible student projects in Moodle, in particular suggestions for GSOC 2008 projects.

Potential GSOC students

Firstly, review the GSOC advice for students.

You may choose a project from the list below and/or suggest your own project ideas. Please use the Moodle.org Student projects forum for discussing project ideas.

Student applications start on Monday 24th March 2008. See the GSOC timeline for more information.

Potential mentors

Moodle developers willing to mentor a GSOC project, please suggest a new project under the heading "Ideas we're considering for GSOC" and/or add your name to an existing project. Contact Helen Foster if you have any questions.


Useful links

  • GSOC - describing Moodle's involvement with Google in their Summer of Code program, including a list of GSOC projects from 2006 and 2007
  • Popular Requests - Most voted-for enhancements and new feature requests in the tracker

GSOC suggested projects

Following a review, approved suggested projects which have mentors will be moved under this heading. More approved suggested projects coming soon!

Consuming RSS Feeds

RSS/Atom feeds are becoming an important technology on the web and so it's crucial that Moodle has good support for consuming these feeds for a variety of different uses. At present we generate RSS feeds for use by other applications, though only consume feeds in the RSS feeds block. It would be useful to have a core library which can take care of aggregating feeds (and the issues around it) and to provide them in a simple format for plugins and other core parts of Moodle to use.

This project will involve creating a feed aggregation library which:

  • Will consume most current aggregation technologies (RSS 0.90/1.0/2.0 /Atom etc)
  • Will work behind a variety of web proxies
  • Periodically aggregates and uses a caching mechanism (doesn't query remote server with every request)
  • (Is probably based on an existing PHP framework)

In order test this library, it will be necessary to refactor the RSS block to use it.

Mentor: Dan Poltawski

Ideas we're considering for GSOC

Please add your ideas for GSOC projects under this heading.

Following a review, approved suggested projects which have mentors will be moved under the heading "GSOC suggested projects" above. Please note that suggested projects require a mentor in order for them to be approved.

Secure RSS feeds

Currently RSS is less than useful because:

  • Either we can't publish private information to the outside world because it's too sensitive.
  • We open up sensitive information to the outside world

We should add codes to make the RSS URLs practically impossible to guess, much the same way as Google Calendar does it.

  • Overhaul all the RSS feeds in Moodle to make use of a long hash-like string in the URL for identification (Forums, Data etc).
  • Store these codes in a new field per-user and per-course.
  • Add GUIs to let the user recreate their code to something else should they suspect a breach.
  • Add RSS to other areas of Moodle such as the participants "last logins" and the activity logs.
  • Explore/research other methods of opening up RSS in a safe way to the outside world.

Old Specification: Secure RSS feeds Mentor: Nicolas Connault

Roles interface improvements

Improve the roles editing interface by making it more dynamic and flexible. You can use the YUI library for ajax if you like, but there must be a good fall-back interface too. Some ideas include:

  • Improve the order of the capabilities and implement better grouping.
  • Make the groups of capabilities collapsible to make it easier to "zoom in" to a particular section.
  • Add floating tooltip help when you hover over any given capability.
  • Experiment with an (alternate) interface seeing the roles all side-by-side for easier comparison/editing.
  • Implement a roles backup and restore system to allow site administrators to distribute useful roles in the Moodle community (rather than having to describe the permissions setup)
  • More clearly designate the scope of capabilities. Does the capability apply at the site, category, course, activity, or user to user levels.
  • Analyse the problem carefully with feedback from the community for more ideas.

Integration with bibliographic systems such as Wikindx

Managing references and citing them is an important behaviour in university education and research. Bibliographic facilities are quite complicated and go beyond the capabilities of Moodle built-in technology (e.g. the database activity). Integrating Moodle with open-source bibliographic software such as Wikindx could much facilitate this practice within Moodle.

Design and construct an integration with Wikindx (or other open-source bibliographic tools, if appropriate).

Teachers should be able to easily refer to wikindx bibliography items throughout a Moodle course, and be able to:

  • Generate correctly-formatted in-place references (using standard styles e.g. Harvard, APA) for the commonly-cited reference types (e.g. journal article, book chapter, book). It may be possible to delegate the formatting directly to wikindx (since it already performs functions like these) rather than implementing a whole new set of logic in the Moodle integration.
    • Possibly, allow some kind of direct searching of a wikindx database from within Moodle, so as to make it easier to refer to items
  • Generate reading lists / bibliographies
  • Allow export of the above into common machine-readable formats such as Bibtex or RIS. (Wikindx can perform this so again it's a question of hooking into, or expanding, wikindx functionality.)

See also Development:Wikindx and this forum discussion too

Implement CATs in Moodle

This book describes a number of assessment techniques that involve collaboration and group work, and therefore fit very well into Moodle's Social Constructivist philosophy. The book about using these techniques in the classroom, but at an conference I attended there was a talk by Jean Runyon and Thomas Gorecki from the College of Southern Maryland saying how well these techniques work online.

Some of them just need a forum of something basic, but others would need to be done as a database module templates. Doing this would

  1. Make Moodle an even better teaching tool.
  2. Provide some good exemplars of how to do interesting things with database templates.
  3. Possibly highlight limitations in the database template system, that would require improvements to the database module code to overcome.
  4. One of the outcomes of this project could be some really good 'How to write a database template' tutorial, which would be very valuable to the community.

This is my (Tim Hunt's) idea, but I would not be interested in mentoring it. It would need to be someone who knows all about the database module.

Blog Assignment Type

What is it for?

Blogs are inherently user owned and driven by definition, however teachers would like to have a way to use blogs as assignments in their courses, comment, grade, etc.

A solution to this conundrum would be a new Assignment type that makes it possible for a student to easily submit the link one of their blogs to an assignment in a course, and have that blog entry privately graded and commented on by the instructor of that course. The blog entry itself remains public along with all of the student's other blogs. The tool would provide a time filter in the Assignment, so that the instructor could limit the blog entry posting dates that will be accepted (both to ensure 'fresh' entries and to keep the list of entries the student chooses short for frequent student bloggers).

I suggest a blog assignment type that functions as follows:

Teacher: Teacher creates a blog assignment, this puts a grade in the gradebook and provides an assignment link for students to see.

The teacher can configure options to allow a blog entry posted in the last X days to be used for the assignment.

Students: When students enter the assignment they see a drop down menu of all their current (blog entries posted in the last X days as chosen by the teacher) blog entries, and they choose one to satisfy the assignment.

Assessment: The teacher goes in to the Assignment, views the blogs that are linked from the assignment, leaves comments (the comments only show up to the student when they view the blog assignment), and gives a grade.

The blog entries themselves stay on the student's blog, only the grades, links, and comments go in the assignment (optionally the assignment scrapes the student's blog and loads the full text in to store for backup and restore).

Moodle IDE

The objective of this project is to create a Moodle IDE based on Eclipse so that new developers can get to develop Moodle in less time.

Ideas

  • First release: Eclipse + Plugins + Moodle splashscreen + CVS Configuration + Apache + MySQL + Moodle CVS code. All preconfigured and ready out of the box.
  • Every X time, it checks for new versions of Moodle and packs it.
  • Checkstyle plugin alike to follow Moodle Design Guidelines.
  • Development help (can be wiki pages to navigate offline)

More mentors needed Mentor: David Horat

Download (Old Version): MoodleIDE-latest

Join the discussion thread

Moodle Multisite

The objective of this project is to make Moodle able to manage several Moodle sites with just one source code. This will help administrators of several sites to centralize code upgrades and technical problems.

Ideas

  • config.php will be a proxy that executes the concrete config file depending on the current url.
  • The concrete config file will be under the directory /config and will have an arbitrary name created by the user.
  • Create an XML file with all the pairs URL(n)-ConfigFile(1).
  • Every time this file changes, it should be created the config.php file cache (to speed up things).
  • Develop a Web frontend to change this file, that can be just accessed by the super admin in every site.

Mentor: David Horat

Join the discussion thread

Automatic Accessibility Checking

The objective of this project is to make a tool that can check Moodle´s accessibility automatically before realising a version.

Ideas

  • Automatic Tool (see down)
  • Create an example course which introduces every XHTML code of the Moodle application, in order to have a way to test it.
  • Create a button called "Check XHTML" which will send the current page code to a validator.
    • This button just helps to check if the current page is valid. Good for development purposes.
    • This button will be (de)activated in the administration panel
    • Keep in mind that this button will not pass the URL as a referer, but it will take all the code from the page and send it to the validation service
    • This button can be used in other web applications

Automatic Tool

  • Create (or use an existing one) an automatic and easy to use tool that retrieves all the pages in a site until a concrete level (recursive calling it for each link)
    • Use concrete user agent names
    • Be able to store cookies in order to check it with a concrete user and password
  • Plug each output to an automatic XHTML validator
    • In the future we can plug in different validators: CSS, WCAG (what it can be checkable automatically), etc.
  • Generate stats

Mentor: David Horat

Join the discussion thread

Moodle Usability Guidelines

The main objective of this project is to develop a usability guidelines and testing methods in order to have a real view of Moodle usage.

Main tasks

  • Research in the usability world to see which methods are most used and which are most reliable.
  • Select the ones that are more appropriate for Moodle
  • Create a usability guideline with the way to apply these methods for Moodle
  • Try them with real world people (optional, although it would be very interesting)
  • Analyse the results in order to extract conclusions of the current Moodle Usage
  • Report the ways we could improve current Moodle Usability

Mentor: David Horat

Join the discussion thread

Moodle Target tracking + rewards/gifts

This one would suit a facebook enthusiast! The Facebook gifts system is very popular and an ideal motivator for students at school level. Moodle needs an equivalent.

The aim is to develop a system for setting targets e.g. 'get at least 60% in this assignment/quiz/whatever' and for reward credits to be awarded automatically when it is completed. These reward credits translate to a system of Gifts similar to Facebook ones (small images, akin to stickers, which can be bought for a small fee and sent to friends who then display them on their profile). Admins can control what the reward images are for their site, maybe having them in some sort of rank order of value, or having different ones with different meanings. There are several ways they could be implemented beyond that:

  • Teachers could choose which rewards can be earned for a specific task. For example, there may be different rewards for forums and assignments
  • Teachers may want to specify different rewards for different levels of performance on the same task
  • Teachers decide how many points a certain target is worth and the students cash in those points for rewards of various values
  • Teachers decide how many rewards a target is worth and students choose that many rewards. None are worth more than 1 point each, the only difference is the graphic.

Once students have rewards, they need a way of allocating them (presumably permanently) to their friends. A system for logically displaying them on the friend's profile page would be needed too and will need to take into account

  • Students with only a few stickers given to them by friends will want them to maximise their display
  • Students who are very popular with hundreds of stickers may need to groups of 10 similar ones substituted for a super-sticker to use less space
  • Hovering over the sticker should give details of who awarded it and when and possibly a short message.

Additionally, the social rating/ranking that this achieves will have most effect when it is publicly visible in various places e.g. under forum avatars and maybe in the online users block as well as the user profile.

Maybe this would sit well with the 'Friends' part of last years GSOC social networking project if it were finished.

I can't offer to mentor in coding terms, but will help with ideas all I can. Matt Gibson 05:26, 4 March 2008 (CST)

Interested Student : Rajan Vaish ( GTALK/GMAIL:vaish.rajan@gmail.com, IRC: vaish)

Use of Video Material Effectively within Moodle

The main purpose of this module will be to get use of video content, most probably a lecture, in a more formal/controlled/effective way within Moodle.

The main features of this module will be;

  • Stream the video file (most probably in flv format)
    • Should be able to stream by using multiple ways (e.x. FMS, Red5, lighttpd, etc..)
    • Develop a front-end to configure the streaming server settings
    • automatic media conversion (controlled by other Moodle settings like max file size, etc..)
  • The teacher can give related notes, websites or other resources with the video
  • The students can keep a note related to each video
  • Share/view other student's notes (probably controlled by the teachers and/or students)
  • Optionally assess the student notes and include them in the grade book

The above list may expanded based on your views.

Difficulty Level: Easy/Medium

Skills Required:

  • Familiarity with streaming servers like Red5 and video streaming in general.
  • Should be able to install and configure required products (Moodle, Red5, lighttpd, etc..) in any OS (Windows, Linux, Mac, etc..)
  • Understanding of UI design concepts.
  • Familiarity with Moodle APIs and Developing Moodle in general

Join the discussion thread

References


Potential Mentor: Rashan Anushka

Web-based upgrade and plugins interface

A system for Moodle to be upgraded along with its plugins from within the admin interface.

Currently, adding third party modules/patches can be messy and can especially slow down the upgrade process if CVS is not used. The aim would be to develop a way to package plugins in a standardised way so that a single zip file could be retrieved and installed automatically, similar to the way courses are restored. An added feature would be for the modules and plugins database on moodle.org to have an XML index so that you could browse available plugins from within your own moodle instance and have a one-click install option. Version compatibility info could be included so that only those which will work with your install will be shown. At upgrade time, the new third-party components screen could then show which ones could be upgraded along with the rest of the code and which would need to dropped because there is no compatible replacement.

See also