XS Community Edition/0.4/Project Specifications: Difference between revisions

From OLPC
Jump to navigation Jump to search
No edit summary
Line 5: Line 5:
A school server provides communication, networking, content, and maintenance to a school and or classroom. In everyday usage the school server provides services which extend capabilities of the connected laptops while being transparent to the user.
A school server provides communication, networking, content, and maintenance to a school and or classroom. In everyday usage the school server provides services which extend capabilities of the connected laptops while being transparent to the user.
These services include:
These services include:

* Classroom connectivity – Similar to what you would find in an advanced home router.
* Classroom connectivity – Similar to what you would find in an advanced home router.
* Internet gateway – If available, an internet connection is made available to laptops.
* Internet gateway – If available, an internet connection is made available to laptops.
Line 17: Line 16:
* Skilled sysadmins running micro-deployments.
* Skilled sysadmins running micro-deployments.
* Experienced mid-sized deployment with limited onsite sysadmins.
* Experienced mid-sized deployment with limited onsite sysadmins.

==Design==

One of the key design criteria of successful community-based projects is modularity with 'plug in' services


==Hardware==
==Hardware==
Line 23: Line 26:


===XO===
===XO===

XSCE v0.4 will run on all XO laptops. In common usage, the XO may be augmented by SD cards and two off the shelf USB devices:
XSCE will run on all XO laptops. In common usage, the XO may be augmented by SD cards and two off the shelf USB devices:
* Network connector – Allow the server to offer internet access to connected XO's.
* Network connector – Allow the server to offer internet access to connected XO's.
* 2 USB ethernet dongles.
* 2 USB ethernet dongles.
Line 31: Line 35:


===Standard Hardware===
===Standard Hardware===
For greater flexibility some schools will want to use standard hardware. XSCE v0.4 is currently supporting:


For greater flexibility some schools will want to use standard hardware. XSCE is currently supporting:
* Trim-Slice.
* Trim-Slice.


Line 38: Line 42:


==OS==
==OS==

XSCE will run on either:
XSCE will run on either:
* OLPC-OS 13.2.0
* OLPC-OS 13.2.0
* Fedora 18
* Fedora 18

==Design==
One of the key design criteria of successful community-based projects is modularity with 'plug in' services


==Configuration Tools==
==Configuration Tools==
===GUI===
FUTURE: Target users are often not familiar with Linux system administration. Initial setup or fixing a problem with their server is not a good time to introduce system administration skill.


===Remote Configuration===
===Remote Configuration===
* NEW IN 0.4 -- Remote administration – There are several systems such as CFEngine and puppet which enables remote management.


One of the most pressing logistical challenges for deployments is travel time between schools. If can take days, and weeks in some cases, a technical support person with the needed skills to arrive 'on-site' to fix an issue. XXCE provides two options for remote administration:
===Command Line===
* OpenVPN -- Any individual school server with internet connectivity can be accessed remotely by support staff.
???
* NEW IN 0.4 -- Ansible -- All servers in a deployment can be updated and maintained as a cohesive group.

===GUI===

FUTURE: Target users are often not familiar with Linux system administration. Initial setup or fixing a problem with their server is not a good time to introduce system administration skill.


== Deliverable==
== Deliverable==


=== RPM ===
=== RPM ===

A RPM combined with tested installation instructions necessary to convert a standard XO or Fedora-compatible computer into a School Server.
A RPM combined with tested installation instructions necessary to convert a standard XO or Fedora-compatible computer into a School Server.


=== IMAGE ===
=== IMAGE ===

* NEW IN 0.4 -- A downloadable USB flash drive image, combined with tested installation instructions, which permit deployment staff to install XSCE software without an internet connection.
* NEW IN 0.4 -- A downloadable USB flash drive image, combined with tested installation instructions, which permit deployment staff to install XSCE software without an internet connection. :NOTE: is this feasible in 0.4


==Core Services==
==Core Services==
Line 83: Line 89:
Provider: named
Provider: named


NEW IN 0.4 -- System monitoring <br>
Service: Backup student work<br>
Purpose: To back up student work<br>
Purpose: Ensures that all offered services are running as expected<br>
Provider: idmgr
Provider: monit

Service: Restore student work<br>
Purpose: ???<br>
Provider: ???


Service:Jabber server<br>
Service:Jabber server<br>
Line 106: Line 108:


Service: Moodle<br>
Service: Moodle<br>
Purpose: <br>
Purpose: Provides Course Management System<br>
Provider: <br>
Provider: Moodle<br>

Service: OLPC-update<br>
Purpose: OLPC-update is necessary to update the kernel of XO<br>
Provider: rsync<br>


Service: Activity update<br>
Service: Activity update<br>
Purpose: Enables teachers to easily distribute new or updated activities to their students<br>
Purpose: Enables teachers to easily distribute new or updated activities to their students<br>
Provider: activity updater<br>
Provider: activity updater<br>

Service: OLPC-update<br>
Purpose: OLPC-update is necessary to update the kernel of XO<br>
Provider: rsync<br>


Service: Virtual Private Network (VPN)<br>
Service: Virtual Private Network (VPN)<br>
Line 121: Line 123:
Provider: openvpn<br>
Provider: openvpn<br>


Service: Backup student work<br>
NEW IN 0.4 -- ??? <br>
Purpose: <br>
Purpose: To back up student work<br>
Provider: monit
Provider: idmgr

Service: Restore student work<br>
Purpose: To restore student work<br>
Provider: ???


NEW IN 0.4 -- Service: Content filtering (TimM??) <br>
NEW IN 0.4 -- Service: Content filtering (TimM??) <br>
Line 147: Line 153:
== Future Features and Objectives==
== Future Features and Objectives==
* Browser-based GUI Config - as primary configuration tool? To configure install setup and core services?
* Browser-based GUI Config - as primary configuration tool? To configure install setup and core services?
* Puppet remote management (future service below, [http://lists.laptop.org/pipermail/server-devel/2013-May/thread.html#6358 design goals reviewed May 2013])
* ejabberd roster admin
* ejabberd roster admin
* Consideration of other devices (Android, Kindle, iPods, iPads)
* Consideration of other devices (Android, Kindle, iPods, iPads)
* Content curation (beyond '''dumping''' stuff into Apache directories)
* Content curation (beyond '''dumping''' stuff into Apache directories)
* Khan Academy


== Future services ==
== Future services ==

Revision as of 15:07, 22 June 2013

School Server - Community Edition 0.4 Project Specifications

Summary

A school server provides communication, networking, content, and maintenance to a school and or classroom. In everyday usage the school server provides services which extend capabilities of the connected laptops while being transparent to the user. These services include:

  • Classroom connectivity – Similar to what you would find in an advanced home router.
  • Internet gateway – If available, an internet connection is made available to laptops.
  • Content - Tools are available for deployments and teachers to make instructional media available to their schools and classrooms.
  • Maintenance - Tools are available to keep laptop updated and running smoothly.

Reference User

The XS-CE 0.4 has three types of reference user:

  • Highly motivated volunteers willing to risk the bleeding edge.
  • Skilled sysadmins running micro-deployments.
  • Experienced mid-sized deployment with limited onsite sysadmins.

Design

One of the key design criteria of successful community-based projects is modularity with 'plug in' services

Hardware

School servers can be either an XO or standard x86 and arm based hardware.

XO

XSCE will run on all XO laptops. In common usage, the XO may be augmented by SD cards and two off the shelf USB devices:

  • Network connector – Allow the server to offer internet access to connected XO's.
  • 2 USB ethernet dongles.
  • NEW IN 0.4 -- External USB hard drive – Allows the server to provide additional storage capabilities. Experimental: Some hard drives fail to reliably wake after being in a low power state.

Please note that XO-1s and XO-1.5 'lite' machines made require an internal SD card to meet XS storage requirements.

Standard Hardware

For greater flexibility some schools will want to use standard hardware. XSCE is currently supporting:

  • Trim-Slice.

Other hardware may work, but is not tested as part of the release process. Please help us by running the tests at testing on your hardware of choice to verify it works.

OS

XSCE will run on either:

  • OLPC-OS 13.2.0
  • Fedora 18

Configuration Tools

Remote Configuration

One of the most pressing logistical challenges for deployments is travel time between schools. If can take days, and weeks in some cases, a technical support person with the needed skills to arrive 'on-site' to fix an issue. XXCE provides two options for remote administration:

  • OpenVPN -- Any individual school server with internet connectivity can be accessed remotely by support staff.
  • NEW IN 0.4 -- Ansible -- All servers in a deployment can be updated and maintained as a cohesive group.

GUI

FUTURE: Target users are often not familiar with Linux system administration. Initial setup or fixing a problem with their server is not a good time to introduce system administration skill.

Deliverable

RPM

A RPM combined with tested installation instructions necessary to convert a standard XO or Fedora-compatible computer into a School Server.

IMAGE

  • NEW IN 0.4 -- A downloadable USB flash drive image, combined with tested installation instructions, which permit deployment staff to install XSCE software without an internet connection. :NOTE: is this feasible in 0.4

Core Services

The core server will contain five services which can be extended via extended services.

Service: Network setup
Purpose:
Provider: xs-setup-network

Service: Dynamic Host Configuration Protocol
Purpose: Schoolserver and clients need to be on same subnet.
Provider: dhcpd

Service: Iptables -- Network Address Translation (NAT)
Purpose: Permits all XO’s to access the internet.
Provider: gateway

Service: Internet domain name server
Prupose:
Provider: named

NEW IN 0.4 -- System monitoring
Purpose: Ensures that all offered services are running as expected
Provider: monit

Service:Jabber server
Purpose: collaboration > 15 clients needs to work.
Provider: ejabberd

Extended Services

Service: Web server
Purpose: Building block for many other extended services
Provider: apache

Service: proxy server and web cache
Purpose: bandwidth, web-filtering, web-monitoring
Provider: squid

Service: Moodle
Purpose: Provides Course Management System
Provider: Moodle

Service: Activity update
Purpose: Enables teachers to easily distribute new or updated activities to their students
Provider: activity updater

Service: OLPC-update
Purpose: OLPC-update is necessary to update the kernel of XO
Provider: rsync

Service: Virtual Private Network (VPN)
Purpose: Creating secure point-to-point or site-to-site connections in routed or bridged configurations and remote access facilities
Provider: openvpn

Service: Backup student work
Purpose: To back up student work
Provider: idmgr

Service: Restore student work
Purpose: To restore student work
Provider: ???

NEW IN 0.4 -- Service: Content filtering (TimM??)
Purpose: age-appropriate surfing, legal compliance, religious risks
Provider: dansguardian and opendns

NEW IN 0.4 -- Service: 1-N WebDEV(JerryV, GeorgeH)
Purpose: Journal submissions to teacher, academic record (homework etc)
Provider: WebDAV

NEW IN 0.4 -- Service: Statistics Collection
Purpose: Collects users statics for academic research
Provider: pilot monitoring system

NEW IN 0.4 -- Service: Book server (SameerV, AlexK, GeorgeH struggling!)
Purpose: compete with Khan Academy?
Provider: pathagar

NEW IN 0.4 -- Service: Internet in Box
Purpose: Provide offline content
Provider: ???

Future Features and Objectives

  • Browser-based GUI Config - as primary configuration tool? To configure install setup and core services?
  • ejabberd roster admin
  • Consideration of other devices (Android, Kindle, iPods, iPads)
  • Content curation (beyond dumping stuff into Apache directories)

Future services

Please consider adding features and objectives to this list if you feel they should be included in a future release. If you consider the feature important and are willing and able to do the necessary work please sign your name to take responsibility for that service.

Service: (GeorgeH, Gerald, AnnaS)
Purpose: local distribution/replication of Sugar Activities etc
Provider: pdsh

Service: MediaWiki
Purpose:
Provider: