Italiano English
Modifica History Actions

Differenze per "GSoCIdeas2012"

Differenze tra le versioni 12 e 35 (in 23 versioni)
Versione 12 del 2012-01-23 14:18:51
Dimensione: 4408
Autore: Nemesis
Commento:
Versione 35 del 2012-03-11 11:23:34
Dimensione: 11899
Autore: ClauzClauz
Commento:
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 2: Linea 2:
For the year 2012 the Ninux.org community decided to participate to Google Summer of Code (GSoC 2012). {{attachment:ninux-gsoc-2012-web.jpg}}

Ninux.org community Google Summer of Code 2012 (GSoC 2012) page.
Linea 5: Linea 7:
Here some info on GSoC
Linea 7: Linea 8:
From the [[https://www.google-melange.com/gsoc/document/show/gsoc_program/google/gsoc2012/home|Google Summer of Code 2012]] webpage:
Linea 15: Linea 17:
'''Mentors''' '''Mentors (draft)'''
Linea 17: Linea 19:
  * TODO   * Saverio Proto
  * Lorenzo Bracciale
  * Marco Giuntini
  * Federico Capoano
  * Gioacchino Mazzurco
Linea 19: Linea 25:
'''Students''' '''Students (draft)'''
Linea 21: Linea 27:
TODO   * Vittorio Cuculo (student in 2011)
  * Claudio Pisa (student in 2011)
  * Angelo Giovinazzo (student in 2011)
  * Raffaele Petteruti
  * Mara Sorella

More students want to join, we'll accept more if we will be accepted as a mentoring organization.
Linea 29: Linea 41:
 * Integration with django's user management framework (django.contrib.auth.user)
 * Registration and login
 * Integration with django's user management framework (django.contrib.auth.user) and permission system
 * Easy registration and login
Linea 32: Linea 44:
 * New improved graphical user interface: our golden rule will be "less is more"  * Improve the graphical user interface
Linea 36: Linea 48:
 * Differentiation between different types of devices (antennas, servers, others)
 * New pluggable DNS application with the possibility to associate hostnames with devices or servers
 * Traffic statistics with
graphs
 * Better DB abstraction, eg: differentiation between different types of devices (antennas, servers, others)
 * Network usage graphs
 * Elevation chart and Fresnel Zone calculation
Linea 43: Linea 55:
 * Integration with Layar - we already have a php script, we will just need to port it to python/django  * Integration with Layar - we already have a php script, we will just need to port it to python/django => Possibly find an open alternative to layar
Linea 48: Linea 60:
 * Permit nodes configuration from nodeshot ( http://nnx.me/eigenfirmware + UCI + SSH? - this needs to be in a separate app)
 * Better SNMP monitoring (at the moment we support only Ubiquiti devices)
 * Visual traceroute & graphs

== DNS Management App for wireless communities ==
We implemented our own DNS system in our community which is integrated with the map-server. At the moment the integration is more like a temporary hack and not a piece of good software. We would like to separate this functionality and make it an indipendent application that can be integrated easily into the map-server but also run in standalone mode. The Goal is to make a system which calculates the hostnames of the nodes automatically but also gives the possibility for community networkers to manage their own DNS records indipendently (each node owner should be able to change his/her hostnames or add new ones).

Features:
 * Backend web interface for administration
 * Frontend application in which each node owner can manage hostnames of his/her node
 * Standalone mode
 * Pluggable mode (integration with Nodeshot)
 * Integration with Opensource DNS software (PowerDNS, myDNS, ecc)

== Distributed node monitoring and management application ==
We use different monitoring systems but we are not completely satisfied with any of them.

Problems we face:
 * Different monitoring systems are hard to mantain. When we change anything in our network we have to remember to change also the information in all the systems we use
 * One of the systems is proprietary, closed source and it works only with a very limited set of devices
 * We need to be able to diagnose problems quickly with a cross check on different protocols (SNMP, OLSR, BATMAN)
 * We need more flexibility
 * We need a decentralized system
 * We want it Open Source

Solution proposed:<<BR>>
Develop a new pluggable distributed app for the map-server which can be deployed in different parts of the network which automatize the synchronization of the operations and eases our pain in the management of our network.

== Videoconferencing suitable for Mobile Phone and Mesh Networks (MPMN ) ==

Many people want to use VOIP in our mesh network but they step into some problems:
 * Existent major videoconferencing solutions depend on the Internet ( like skype or gtalk )
 * Most of major existent videoconferencing solutions have not a good mobile phone integration ( like skype )
 * Most of major existent videoconferencing solutions don't have support for ipv6 ( our network is primarily ipv6 )
 * Internet bandwidth on our network is going towards exhaustion
 * They doen't want to learn to use another VOIP app

To solve these issues we decided to implement Videoconferencing suitable for Mobile Phone and Mesh Networks:
 * Create a good app, fully integrated in android/iphone/(other?) addressbook ( call someone trough MMPN must me simple as call him with phone number without learn to use other apps or have different gui).
 * Separate MMPN backend from addressbook integration ( like telepathy framework do on desktop ).
 * Make the backend extensible for newer protocols
 * Offer good privacy with encryption
 * Preferable completely serverless protocol such as retroshare

Type of Work: Coding
Level 4 Semi-Professional
Linea 50: Linea 109:
This project aim to realize a web-based social application for music composition.
It will allow the creation of jam session (non real-time) in this way: users will upload tracks (e.g. piano track) and then they can merge them with other tracks (e.g. bass track) putted in the system by other user. Users could play a bunch of selected tracks creating a composition (e.g. bass+piano+vocal).
'''Idea'''<<BR>>
This project aims to realize a web-based social application for music composition.<<BR>>
It will allow the creation of jam session (non real-time) in this way: users will upload tracks (e.g. piano track) and then they can merge them with other tracks (e.g. bass track) put in the system by other users. Users can play a bunch of selected tracks creating a composition (e.g. bass+piano+vocal).
<<BR>>
Using the linux audio plugin and a proper backend engine, they can also apply effects on tracks.<<BR>>
Conversely, if a user doesn't like an instrument track of a song, she can create her version by substituting it with her own track.<<BR>>
Linea 53: Linea 116:
Using the linux audio plugin and a proper backend engine, they can also apply effects on tracks. '''Technology'''<<BR>>
  * It will use a web framework such as [[http://djangoproject.com|Django]] to manage users, file upload and dynamic content.
  * It will rely on [[http://www.schillmania.com/projects/soundmanager2/|Soundmanager]] a popular and portable javascript library (adopted also by [[http://soundcloud.com|SoundCloud]]) for the front-end and mp3/mp4/ogg/wav playing. By default this library supports loop creation, volume, pan, set position, mute, peak volume level, pause/resume all, eq data (FFT). It supports also HTML5 (iPhone friendly). <<BR>>
  * On the backend it will handle files using linux programs. It could add effects (such as reverb or delay) on tracks by interfacing with a [[http://www.ladspa.org/|LADSA]] compatible command line script. In this way we will reuse the tons of linux audio plugin.
  * Every track is under a kind version control (git or whatever) so to keep track of branches and merges.
Linea 55: Linea 122:
It rely on [[Soundmanager|http://www.schillmania.com/projects/soundmanager2/]] a javascript library (adopted also by [[http://soundcloud.com|SoundCloud]]) for the front-end, and a [[http://www.ladspa.org/|LADSA]] compatible command line script as for a backend. == Improve the OLSRd mDNS plug-in ==
Linea 57: Linea 124:
Every track is under version control (git or whatever) so to keep track of branches and merges. The OLSRd mDNS plug-in allows the distribution of mDNS (multicast DNS i.e. avahi/bonjour/zeroconf) messages over an OLSR network. This is substantially achieved by sniffing for mDNS packets on the final users' networks (usually HNA networks), encapsulating them inside OLSR protocol messages, exploiting OLSR native message transfer mechanisms, and decapsulating the mDNS packets at all the other end users' networks.

The plug-in has been developed by ninux.org members, however we would like to address some important issues that have arised during deployment:
 * '''loops'''. If two mDNS plug-in enabled OLSR routers are attached to the same HNA network, then mDNS packets will loop back and forth between the two, also flooding the whole OLSR network. For the moment the temporary solution to this problem is to enable the plug-in on one router at a time on the same HNA. A real solution to the problem would be the following:
  * usually mDNS packets have a TTL != 1, so:
  * capture only mDNS packets with TTL != 1
  * when decapsulating mDNS packets, set TTL = 1
  * where TTL is the IP Time-to-live field
 * '''capture rate'''. mDNS packets are incapsulated into OLSR messages, which in turn are contained in OLSR packets that are sent at the wireless basic rate (i.e. 1 or 2 Mbps) over the whole network. Thus a big amount of mDNS captured packets in a small time can slow down the whole network. A solution to this is to add a plug-in configuration option to set the maximum packet capture rate.

''' References '''

 * [[http://olsr.org/git/?p=olsrd.git;a=blob;f=lib/mdns/README | mDNS plug-in README]]
 * [[http://sesame-project.net/raw-attachment/wiki/PublicationsPage/mdns-plugin-paper.pdf | The OLSR mDNS extension for service discovery ]]
 * [[https://tools.ietf.org/html/draft-cheshire-dnsext-multicastdns-15]]
 * [[http://www.multicastdns.org/]]


== Improve the ninuxoo search engine ==

We have started the development of a community-network-wide open-source search engine called [[https://github.com/ninuxorg/ninuxoo|ninuxoo]]. Written in Python, it is formed by a samba and ftp share crawler and of a cgi-based website, with a common database. We would like to enhance it by adding some features:
 * show results whith a number of hops distance, based on the IP address of the user that is performing the search. This needs to interact with the routing daemon (i.e. olsrd in our case) by periodically retrieving the graph of the community network (through the txtinfo or dot olsrd plugins) and running standard graph search algorithms (e.g. Dijkstra's)
 * add a "what's new" web page that shows the newest files found by the crawler. This needs changes to the [[https://github.com/cl4u2/ninuu/blob/master/ninuxuu0.sql|database schema]]
 * reengineer the ftp crawling code
Linea 60: Linea 150:
About GSOC 2012: __http://www.google-melange.com/__ About GSOC 2012: [[http://www.google-melange.com/|http://www.google-melange.com/]]
Linea 62: Linea 152:
Info about ninux participation on previous years: Info about ninux participation in previous years:
Linea 69: Linea 159:
If you are interested to participate please contact If you are a student interested in one (of more) of these projects please write to
Linea 71: Linea 161:
contatti@ninux.org . contatti [AT] ninux [DOT] org

Google summer of Code 2012

ninux-gsoc-2012-web.jpg

Ninux.org community Google Summer of Code 2012 (GSoC 2012) page.

About the Google Summer of Code

From the Google Summer of Code 2012 webpage:

Google Summer of Code is a global program that offers student developers stipends to write code for various open source software projects. We have worked with several open source, free software, and technology-related groups to identify and fund several projects over a three month period. Since its inception in 2005, the program has brought together nearly 2500 successful student participants and 2500 mentors from 98 countries worldwide, all for the love of code. Through Google Summer of Code, accepted student applicants are paired with a mentor or mentors from the participating projects, thus gaining exposure to real-world software development scenarios and the opportunity for employment in areas related to their academic pursuits. In turn, the participating projects are able to more easily identify and bring in new developers. Best of all, more source code is created and released for the use and benefit of all.

Participants

Mentors (draft)

  • Saverio Proto
  • Lorenzo Bracciale
  • Marco Giuntini
  • Federico Capoano
  • Gioacchino Mazzurco

Students (draft)

  • Vittorio Cuculo (student in 2011)
  • Claudio Pisa (student in 2011)
  • Angelo Giovinazzo (student in 2011)
  • Raffaele Petteruti
  • Mara Sorella

More students want to join, we'll accept more if we will be accepted as a mentoring organization.

GSoC Project Ideas 2012

Mapserver Improvements

The goal of this task is to push forward the development of Nodeshot in order to make it mature, stable and more flexible. The final goal is to promote this software so other wireless communities around the world can start using it and participate in the development. At the moment this is only partially possible because the software is not very flexible and has been developed to satisfy our needs only.

  • Integration with django's user management framework (django.contrib.auth.user) and permission system
  • Easy registration and login
  • Possibility for admins and users to login in the frontend and be able to perform different actions depending on their privileges (eg: some info might be configurable to be seen by a certain group of users only)
  • Improve the graphical user interface
  • Email app to ease the communication with node owners (possibility to send an email to all the nodes, possibility to send an email to only a group of nodes)
  • Possibility to use placeholders for distance calculations on the fly
  • New overviews with IP addresses
  • Better DB abstraction, eg: differentiation between different types of devices (antennas, servers, others)
  • Network usage graphs
  • Elevation chart and Fresnel Zone calculation
  • Better caching system
  • Javascript refactoring
  • History for all the changes in the database
  • Mobile version
  • Integration with Layar - we already have a php script, we will just need to port it to python/django => Possibly find an open alternative to layar

  • Better notifications, 2 examples:
    • Possibility for non-admins to receive notifications when new potential nodes are added
    • Possibility to be notified if new potential nodes are added in a specified distance range (eg: notify me if a new potential node is added in a range of 10km)
  • Documentation
  • Permit nodes configuration from nodeshot ( http://nnx.me/eigenfirmware + UCI + SSH? - this needs to be in a separate app)

  • Better SNMP monitoring (at the moment we support only Ubiquiti devices)
  • Visual traceroute & graphs

DNS Management App for wireless communities

We implemented our own DNS system in our community which is integrated with the map-server. At the moment the integration is more like a temporary hack and not a piece of good software. We would like to separate this functionality and make it an indipendent application that can be integrated easily into the map-server but also run in standalone mode. The Goal is to make a system which calculates the hostnames of the nodes automatically but also gives the possibility for community networkers to manage their own DNS records indipendently (each node owner should be able to change his/her hostnames or add new ones).

Features:

  • Backend web interface for administration
  • Frontend application in which each node owner can manage hostnames of his/her node
  • Standalone mode
  • Pluggable mode (integration with Nodeshot)
  • Integration with Opensource DNS software (PowerDNS, myDNS, ecc)

Distributed node monitoring and management application

We use different monitoring systems but we are not completely satisfied with any of them.

Problems we face:

  • Different monitoring systems are hard to mantain. When we change anything in our network we have to remember to change also the information in all the systems we use
  • One of the systems is proprietary, closed source and it works only with a very limited set of devices
  • We need to be able to diagnose problems quickly with a cross check on different protocols (SNMP, OLSR, BATMAN)
  • We need more flexibility
  • We need a decentralized system
  • We want it Open Source

Solution proposed:
Develop a new pluggable distributed app for the map-server which can be deployed in different parts of the network which automatize the synchronization of the operations and eases our pain in the management of our network.

Videoconferencing suitable for Mobile Phone and Mesh Networks (MPMN )

Many people want to use VOIP in our mesh network but they step into some problems:

  • Existent major videoconferencing solutions depend on the Internet ( like skype or gtalk )
  • Most of major existent videoconferencing solutions have not a good mobile phone integration ( like skype )
  • Most of major existent videoconferencing solutions don't have support for ipv6 ( our network is primarily ipv6 )
  • Internet bandwidth on our network is going towards exhaustion
  • They doen't want to learn to use another VOIP app

To solve these issues we decided to implement Videoconferencing suitable for Mobile Phone and Mesh Networks:

  • Create a good app, fully integrated in android/iphone/(other?) addressbook ( call someone trough MMPN must me simple as call him with phone number without learn to use other apps or have different gui).
  • Separate MMPN backend from addressbook integration ( like telepathy framework do on desktop ).
  • Make the backend extensible for newer protocols
  • Offer good privacy with encryption
  • Preferable completely serverless protocol such as retroshare

Type of Work: Coding Level 4 Semi-Professional

Collaborative Music Composition

Idea
This project aims to realize a web-based social application for music composition.
It will allow the creation of jam session (non real-time) in this way: users will upload tracks (e.g. piano track) and then they can merge them with other tracks (e.g. bass track) put in the system by other users. Users can play a bunch of selected tracks creating a composition (e.g. bass+piano+vocal).
Using the linux audio plugin and a proper backend engine, they can also apply effects on tracks.
Conversely, if a user doesn't like an instrument track of a song, she can create her version by substituting it with her own track.

Technology

  • It will use a web framework such as Django to manage users, file upload and dynamic content.

  • It will rely on Soundmanager a popular and portable javascript library (adopted also by SoundCloud) for the front-end and mp3/mp4/ogg/wav playing. By default this library supports loop creation, volume, pan, set position, mute, peak volume level, pause/resume all, eq data (FFT). It supports also HTML5 (iPhone friendly).

  • On the backend it will handle files using linux programs. It could add effects (such as reverb or delay) on tracks by interfacing with a LADSA compatible command line script. In this way we will reuse the tons of linux audio plugin.

  • Every track is under a kind version control (git or whatever) so to keep track of branches and merges.

Improve the OLSRd mDNS plug-in

The OLSRd mDNS plug-in allows the distribution of mDNS (multicast DNS i.e. avahi/bonjour/zeroconf) messages over an OLSR network. This is substantially achieved by sniffing for mDNS packets on the final users' networks (usually HNA networks), encapsulating them inside OLSR protocol messages, exploiting OLSR native message transfer mechanisms, and decapsulating the mDNS packets at all the other end users' networks.

The plug-in has been developed by ninux.org members, however we would like to address some important issues that have arised during deployment:

  • loops. If two mDNS plug-in enabled OLSR routers are attached to the same HNA network, then mDNS packets will loop back and forth between the two, also flooding the whole OLSR network. For the moment the temporary solution to this problem is to enable the plug-in on one router at a time on the same HNA. A real solution to the problem would be the following:

    • usually mDNS packets have a TTL != 1, so:
    • capture only mDNS packets with TTL != 1
    • when decapsulating mDNS packets, set TTL = 1
    • where TTL is the IP Time-to-live field
  • capture rate. mDNS packets are incapsulated into OLSR messages, which in turn are contained in OLSR packets that are sent at the wireless basic rate (i.e. 1 or 2 Mbps) over the whole network. Thus a big amount of mDNS captured packets in a small time can slow down the whole network. A solution to this is to add a plug-in configuration option to set the maximum packet capture rate.

References

Improve the ninuxoo search engine

We have started the development of a community-network-wide open-source search engine called ninuxoo. Written in Python, it is formed by a samba and ftp share crawler and of a cgi-based website, with a common database. We would like to enhance it by adding some features:

  • show results whith a number of hops distance, based on the IP address of the user that is performing the search. This needs to interact with the routing daemon (i.e. olsrd in our case) by periodically retrieving the graph of the community network (through the txtinfo or dot olsrd plugins) and running standard graph search algorithms (e.g. Dijkstra's)
  • add a "what's new" web page that shows the newest files found by the crawler. This needs changes to the database schema

  • reengineer the ftp crawling code

More Info

About GSOC 2012: http://www.google-melange.com/

Info about ninux participation in previous years:

[http://wiki.ninux.org/GSoCIdeas2011]

[http://wiki.ninux.org/GSoCIdeas2010]

Contact

If you are a student interested in one (of more) of these projects please write to

contatti [AT] ninux [DOT] org

Thank You!