<div dir="ltr">Gears sounded like a exciting way to go right when Martin L told me on
Skype two weeks ago. That's why I've committed a talented guy like
Ruben to dig on this task. We are starting to work on it, and it might
even work <img alt="guiņo" src="http://moodle.org/pix/s/wink.gif" width="15" height="15"><br><br>BUT,
in I've been working on a WS architecture for Moodle that can allow
SOME features of Moodle to be taken out to offline clients (I'm
thinking about <a class="glossary autolink glossaryid5" title="Glossary of common terms: Java" href="http://moodle.org/mod/glossary/showentry.php?courseid=5&concept=Java" onclick="return openpopup('/mod/glossary/showentry.php?courseid=5\&concept=Java', 'entry', 'menubar=0,location=0,scrollbars,resizable,width=600,height=450', 0);">Java</a> Phones, iPhones and other no Gears powered machines. <br>
<br>As
Martin L. says some things move so fast we will not keep up to, BUT
maybe we can choose a part of moodle that makes sense to have in a
limited device like a phone or an ipod or nintendo ds, and bring it
there. This way will never aspire to take out all the features (due to
the development rithms that wise ML tells me ) like the gears
approach... but hey! is worth a try. So I will put people on both bets.
And we are working on WS for other purposes as important as this one
http://<a class="autolink" title="Tracker" href="http://moodle.org/mod/resource/view.php?id=125">tracker</a>.<a href="http://moodle.org/browse/MDL-12886">moodle.org/browse/MDL-12886</a><br><br>Sleeping is optional, sure :p<br>
<br><div class="gmail_quote">On Fri, Oct 10, 2008 at 11:18 AM, Martin Langhoff <span dir="ltr"><<a href="mailto:martin.langhoff@gmail.com">martin.langhoff@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Posted on <a href="http://moodle.org" target="_blank">moodle.org</a> <a href="http://moodle.org/mod/forum/discuss.php?d=107920" target="_blank">http://moodle.org/mod/forum/discuss.php?d=107920</a><br>
<br>
Hi all! I have been away for a while working on other olpc stuff, but<br>
now my attention is returning to Moodle, and offline moodle is<br>
definitely in my roadmap.<br>
<br>
In the AU and NZ moot I had good chances to talk with Dan and MartinD<br>
about a cunning plan to get a Gears-based offline moodle going.<br>
<br>
When we disscussed architecture for the current moodle-on-a-stick<br>
(MoaS) based we also talked quite a bit about a Gears-based approach.<br>
At the time, it looked huge and risky. Google had just released GG,<br>
and was talking about upgrading Reader to use it.<br>
<br>
So there many things stacked against it: Noone had seen Reader doing<br>
the offline thing yet, Gears had a somewhat restrictive license, and<br>
it seemed that we'd have to implement a significant chunk of Moodle as<br>
an AJAX application.<br>
<br>
Things have changed between then and now. Google has made things much<br>
simpler now with a BSD license and Reader shows it can make the<br>
offline thing work very well.<br>
<br>
Reimplementing Moodle as an AJAX app was still a big monster in my<br>
head until recently. But a volunteer approached me recently saying he<br>
could take a stab at it, and I thought "what would be the simplest<br>
thing that could possibly work?"<br>
<br>
The answer was suprisingly simple: store the damn HTML, CSS and JS in<br>
the sqlite DB that Gears provides.<br>
<br>
So from the course page, we can "go offline" by<br>
<br>
- Storing the html+css in sqlite -<br>
- Requesting a special 'manifest of resources that are ok to use<br>
offline' - published by the course-format page...<br>
- Retrieving those offline resources. Initially, just mod/resource<br>
contents. Later we can extend this support to work with other modules.<br>
- When we use the course homepage later while offline, we'll walk the<br>
DOM to show CSS blocks 'disabled' (by graying them out) and we will<br>
disable links to resources we cannot support offline.<br>
- As the user browses the content we do have offline, the JS code<br>
keeps track of resources visited. Upon reconnection to the moodle<br>
site, we push back the collected logs to mdl_log(*)<br>
- Other modules (mod/forum for example) can be supported with ob magic<br>
and/or more explicit/AJAXy use of JS.<br>
<br>
* - we'll need to review the log handling code. So far we've never had<br>
"out-of-sequence" log entries, and this will introduce them for the<br>
first time. I'm sure there'll be a few gotchas there.<br>
<br>
Hearing this, MartinD suggested that - as long as we go the "store<br>
html" way (supported with output buffering tricks if needed) then we<br>
can add the ability to produce a plain old zipfile with a course<br>
homepage + static resources. I think it's a good secondary goal to<br>
have -- though I'm not sure what limits we'll have with this.<br>
<br>
Tony Anderson - the volunteer who sparked this - has been working on a<br>
proof-of-concept implementation. It currently uses Gears and<br>
GreaseMonkey, and requires a few manual tweaks. Unfortunately, I don't<br>
think that code can be merged directly - we will want to refine the<br>
approach to avoid GreaseMonkey and other inconveniences. My take is<br>
that we can either adapt it, or use it as a reference for a more<br>
moodlish implentation -- Tony is not a moodle dev, so he's not<br>
necessarily familiar with our odd style smile ).<br>
<br>
Tony's code is here<br>
<a href="http://lists.laptop.org/pipermail/server-devel/2008-September/002101.html" target="_blank">http://lists.laptop.org/pipermail/server-devel/2008-September/002101.html</a><br>
together with some discussion around it.<br>
<br>
I also hear noises from Barcelona -- Ludo and Ruben may be able to get<br>
involved. This could start getting interesting.<br>
<br>
Getting this from a PoC to something shippable will take a bit of<br>
work. Right now I still have a ton of work to do on other aspects of<br>
Moodle that are more urgent for OLPC, but I will find the time to work<br>
on this working with Tony, Ludo and Ruben. Sleeping is optional,<br>
right? wink<br>
<br>
Once the urgent infrastructure stuff for olpc is sorted, I'll be keen<br>
on bringing this to completion -- at least of an initial stage.<br>
<font color="#888888"><br>
--<br>
 <a href="mailto:martin.langhoff@gmail.com">martin.langhoff@gmail.com</a><br>
 <a href="mailto:martin@laptop.org">martin@laptop.org</a> -- School Server Architect<br>
 - ask interesting questions<br>
 - don't get distracted with shiny stuff  - working code first<br>
 - <a href="http://wiki.laptop.org/go/User:Martinlanghoff" target="_blank">http://wiki.laptop.org/go/User:Martinlanghoff</a><br>
</font></blockquote></div><br><br clear="all"><br>-- <br>---<br>Ludo ( Marc Alier) <br>UPC - <a href="mailto:granludo@gmail.com">granludo@gmail.com</a> - Tel. +34-934137885<br><a href="http://orangoodling.blogspot.com">http://orangoodling.blogspot.com</a> - <a href="http://www.dfwikilabs.org">http://www.dfwikilabs.org</a> - <br>
<a href="http://ososdeviaje.dfwikilabs.org">http://ososdeviaje.dfwikilabs.org</a> - <a href="http://mossegalapoma.cat">http://mossegalapoma.cat</a><br>
</div>