<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Jeroens blog</title>
	<atom:link href="http://blog.bn2vs.com/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.bn2vs.com</link>
	<description>Blog of Jeroen De Dauw. The latest news on my open source work and interests.</description>
	<lastBuildDate>Sun, 04 Mar 2012 23:25:31 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Semantic MediaWiki: Google Summer of Code</title>
		<link>http://blog.bn2vs.com/2012/03/05/semantic-mediawiki-google-summer-of-code/</link>
		<comments>http://blog.bn2vs.com/2012/03/05/semantic-mediawiki-google-summer-of-code/#comments</comments>
		<pubDate>Sun, 04 Mar 2012 23:25:31 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Education]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[GSoC]]></category>
		<category><![CDATA[GSoC 2012]]></category>
		<category><![CDATA[Online education]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[Semantic MediaWiki]]></category>
		<category><![CDATA[Semantic Web]]></category>
		<category><![CDATA[Semantics]]></category>
		<category><![CDATA[SMW]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1245</guid>
		<description><![CDATA[Are you a student, do you want to have an awesome job during the holiday and do you want to make an impact on the world? Then definitly check out the amazing Google Summer of Code program! In a nutshell: Google Summer of Code (or GSoC for short) is a program in which Google sponsors [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://blog.bn2vs.com/wp-content/uploads/2012/03/SMW_logo_142px.png"><img class="alignright size-full wp-image-1248" title="Semantic MediaWiki" src="http://blog.bn2vs.com/wp-content/uploads/2012/03/SMW_logo_142px.png" alt="" width="142" height="142" /></a>Are you a student, do you want to have an awesome job during the holiday and do you want to make an impact on the world? Then definitly check out the amazing <a href="https://code.google.com/soc/">Google Summer of Code</a> program! In a nutshell: Google Summer of Code (or GSoC for short) is a program in which Google sponsors students to work on open source projects during the summer holiday. This allows students to get real world experience while being mentored by experts in the field and gets the open source projects potential long term contributors.</p>
<p>One of the open source projects I&#8217;m involved with, <a href="http://semantic-mediawiki.org/">Semantic MediaWiki</a>, is applying this year as mentoring organization. Although no organizations have been officially accepted yet into GSoC, we are confident we&#8217;ll be able to mentor at least two students and already have over a dozen high quality proposals. <a href="http://semantic-mediawiki.org/wiki/GSoC">Check them out</a>! <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>You can contact me or any of the other people that enlisted themselves as mentor on that page for questions and advice.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2012/03/05/semantic-mediawiki-google-summer-of-code/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>WikiData, Wikipedia 2.0?</title>
		<link>http://blog.bn2vs.com/2012/03/04/wikidata-wikipedia-2-0/</link>
		<comments>http://blog.bn2vs.com/2012/03/04/wikidata-wikipedia-2-0/#comments</comments>
		<pubDate>Sun, 04 Mar 2012 22:59:58 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Berlin]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[Semantic Web]]></category>
		<category><![CDATA[Semantics]]></category>
		<category><![CDATA[WikiData]]></category>
		<category><![CDATA[Wikimedia]]></category>
		<category><![CDATA[Wikimedia Germany]]></category>
		<category><![CDATA[Wikipedia]]></category>
		<category><![CDATA[WMDE]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1238</guid>
		<description><![CDATA[I just moved to Berlin to work on the WikiData project for a year at Wikimedia Germany. The WikiData project will start on April 1st (yes, really) and will tackle many data re-usability issues by having structured storage much like done by Semantic MediaWiki (although it will not use SMW). The basic idea is to [...]]]></description>
			<content:encoded><![CDATA[<p>I just <a href="http://blog.bn2vs.com/2012/03/04/moving-to-berlin/">moved to Berlin</a> to work on the <a href="https://meta.wikimedia.org/wiki/WikiData_WMDE">WikiData</a> project for a year at <a href="http://wikimedia.de/wiki/Hauptseite">Wikimedia Germany</a>.</p>
<p>The WikiData project will start on April 1st (yes, really) and will  tackle many data re-usability issues by having structured storage much  like done by <a href="http://semantic-mediawiki.org/">Semantic MediaWiki</a> (although it will not use SMW). The  basic idea is to have a &#8220;data-wiki&#8221;, which will hold common data, much  like <a href="https://commons.wikimedia.org/wiki/Main_Page">Wikimedia Commons</a> holds common media (mainly images). Initially  this wiki will serve as an entity base for the different (language)  Wikipedias, enabling the removal of inter-language links where people  want to use the new data wiki instead. After that we&#8217;ll allow for adding  properties to the entities, which articles will be able to pull into  factboxes and have some editing UI on the Wikipedias to edit this data  in place and send it back to the data-wiki. The final phase will be  allowing for (limited) queries on the structured data of the data wiki  from the Wikipedias to automatically generate lists and tables.</p>
<p>This  is a real game changer, and if you ask me the most fundamental change  Wikipedia will have seen since it&#8217;s inception. The goal of the <a href="https://wikimediafoundation.org/wiki/Home">Wikimedia  Foundation</a> is to make all human knowledge freely available to everyone.  Having it in a structured format that can be queried makes this data  available to so many more people and more much more easy to actually  make sense of. External applications will be able to build on top of  Wikipedia like never before. And of course the win for Wikipedia itself  is huge as well. Data will be nicely consolidated instead of duplicated  across wikis, and so be more consistent. And data that is now available  on <em>any</em> Wikipedia will be available on <em>all</em> Wikipedias,  vastly increasing the content on all non-English Wikipedias. The world  encyclopedia will turn into the worlds database (ofc it&#8217;s function as  encyclopedia will not get lost) <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>I can&#8217;t wait to get started on this!</p>
<p>A high level overview of the project and it&#8217;s phases can be found <a href="https://meta.wikimedia.org/wiki/WikiData_WMDE">here</a>. You can also follow <a href="https://twitter.com/#!/JeroenDeDauw">me</a> and <a href="https://twitter.com/#!/vrandezo">Denny</a> on twitter of updates. We might get a dedicated account later on, but for now @WikiData is not under our control :/</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2012/03/04/wikidata-wikipedia-2-0/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Moving to Berlin</title>
		<link>http://blog.bn2vs.com/2012/03/04/moving-to-berlin/</link>
		<comments>http://blog.bn2vs.com/2012/03/04/moving-to-berlin/#comments</comments>
		<pubDate>Sun, 04 Mar 2012 22:59:30 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[Berlin]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1236</guid>
		<description><![CDATA[Three days ago I moved from Gent (in Belgium) to Berlin for at least a year. This is because I will be working on WikiData for Wikimedia Germany, an awesome project that will bring semantic capabilities to Wikipedia. Although I have moved to Berlin, I do not have my own apartment yet and am currently [...]]]></description>
			<content:encoded><![CDATA[<p>Three days ago I moved from Gent (in Belgium) to Berlin for at least a year. This is because I will be working on <a href="https://meta.wikimedia.org/wiki/WikiData_WMDE">WikiData</a> for <a href="http://wikimedia.de/wiki/Hauptseite">Wikimedia Germany</a>, an <strong>awesome</strong> project that will bring semantic capabilities to <a href="https://en.wikipedia.org/wiki/">Wikipedia</a>.</p>
<p>Although I have moved to Berlin, I do not have my own apartment yet and am currently staying at a private room in shared apartment thing for a month, by which I hope to have found something more permanent. I have not found anything so far, many due to looking for something that&#8217;s fully furnished, in a quit neighborhood, not over 900 eur/month with everything includes (ie heating, interwebs, commission, ect) and within 15 to 20 mins walking distance from where the office will be. Turns out not a lot of stuff matches all these criteria <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>So far I&#8217;m definitely enjoying Berlin, which I think is a great city. I became a member of <a href="https://www.c-base.org/">c-base</a>, the huge and <strong>awesome</strong> <a href="https://en.wikipedia.org/wiki/Hackerspace">hackerspace</a> of Berlin and already met quite some interesting people there, including some of my soon to be colleagues on WikiData.</p>
<p><a href="http://blog.bn2vs.com/2012/03/04/wikidata-wikipedia-2-0/">More on WikiData here</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2012/03/04/moving-to-berlin/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Wikipedia Education Program</title>
		<link>http://blog.bn2vs.com/2011/12/23/wikipedia-education-program/</link>
		<comments>http://blog.bn2vs.com/2011/12/23/wikipedia-education-program/#comments</comments>
		<pubDate>Fri, 23 Dec 2011 14:44:44 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Education]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[MediaWiki extensions]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Education Program]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[Online education]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[WEP]]></category>
		<category><![CDATA[Wikimedia]]></category>
		<category><![CDATA[Wikimedia Foundation]]></category>
		<category><![CDATA[Wikipedia]]></category>
		<category><![CDATA[Wikipedia Education Program]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1226</guid>
		<description><![CDATA[It&#8217;s been a while since I last wrote a blog post, and this is in part due to the last extension I wrote sadly enough not being available under an open license due to client demands :/ This blog post is about what I&#8217;m currently working on, new infrastructure for a project that I hope [...]]]></description>
			<content:encoded><![CDATA[<p>It&#8217;s been a while since I last wrote a blog post, and this is in part due to the last extension I wrote sadly enough not being available under an open license due to client demands :/ This blog post is about what I&#8217;m currently working on, new infrastructure for a project that I hope you&#8217;ll agree upon is totally <strong>awesome</strong>.</p>
<p>Open knowledge and open learning tools go hand in hand, thus Wikipedia can be an amazing resource for education further then simply looking up things. The Wikipedia Education Program strives to involve university students with the Wikipedia community, by creating and editing articles as part of their coursework. This is a real win-win for everyone involved. The students get to do something which is actually useful, as their work won&#8217;t disappear into some dusty archive of their university, and they learn working collaboratively with other people in the Wikipedia community. The gains for Wikipedia, and it&#8217;s community, are probably pretty obvious; more contributors, more content, more people to help increase the quality of the encyclopaedia as a whole.</p>
<p>If you are interested in bringing this program to your university, definitely check out the <a href="https://outreach.wikimedia.org/wiki/Global_Education_Program">Wikipedia Education Program</a> (WEP). Also, you can find more comprehensive posts about the program itself, as well as many success stories, on the <a href="https://blog.wikimedia.org/c/global/global-education-program/">Wikimedia blog</a>.</p>
<p>The WEP started several years ago with a handful of universities participating. Such participation and enrolment was kept track of manually on wiki pages. Obviously, this does not scale well, and now that the program has two or three orders of magnitude more students, new tools are urgently needed. The main goal is having a way for students to enrol themselves, and then be tracked by their mentors and people of the community wanting to provide assistance where needed. Further a lot of nice things can be done, such as keeping track of contributions, drop-out rates, ect, so that problems can be spotted, and measures can be taken to avoid these in the future. You can find an initial draft of the requirements <a href="https://www.mediawiki.org/wiki/Wikipedia_Education_Program">here</a>.</p>
<p>I&#8217;m implementing this as a new MediaWiki extension, which will when completed, be placed onto Wikipedia. The extension is, probably unsurprisingly, called <a href="https://www.mediawiki.org/wiki/Extension:Education_Program">Education Program</a>. It&#8217;s currently in early alpha stage, so not much to see there yet. However, a draft of it&#8217;s functionality can be found <a href="https://www.mediawiki.org/wiki/Wikipedia_Education_Program/design">here</a>. Management wise it&#8217;ll be somewhat similar to Contest, but more extensive (since there is more stuff to manage), and hopefully improved along multiple dimensions. I still need to put more thoughts into the exact flow for students though, and discuss this with the other people involved.</p>
<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/12/specialcourses.png"><img class="size-large wp-image-1232 alignnone" style="border: 1px solid black;" title="Special:Courses, part of the Education Program extension" src="http://blog.bn2vs.com/wp-content/uploads/2011/12/specialcourses-1024x341.png" alt="Special:Courses, part of the Education Program extension" width="1024" height="341" /></a></p>
<p>This is a screenshot of one of the many special pages making up the  management interface. It lists all courses, allows you to browse through  them (paged) and filter on criteria. Program administrators and mentors  also get to see a control to add new courses, which then takes them to a  new page with a form. Very similar pages exist for other types of objects, such as Institutions, Terms, Mentors and Students (although the later two are somewhat different, since they cannot be modified by people other then the students or mentors themselves).</p>
<p>I will likely be working on this for another 2 months, after which I will start work on an even more <strong>awesome</strong> project (don&#8217;t get me wrong, the WEP is definitely awesome), on which I&#8217;ll post more later on.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/12/23/wikipedia-education-program/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Stanfords Machine Learning class</title>
		<link>http://blog.bn2vs.com/2011/12/23/stanfords-machine-learning-class/</link>
		<comments>http://blog.bn2vs.com/2011/12/23/stanfords-machine-learning-class/#comments</comments>
		<pubDate>Fri, 23 Dec 2011 14:20:25 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Education]]></category>
		<category><![CDATA[AI]]></category>
		<category><![CDATA[ai-class]]></category>
		<category><![CDATA[Artificial intelligence]]></category>
		<category><![CDATA[Machine learning]]></category>
		<category><![CDATA[ml-class]]></category>
		<category><![CDATA[Octave]]></category>
		<category><![CDATA[Online education]]></category>
		<category><![CDATA[Stanford]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1227</guid>
		<description><![CDATA[During the last 3 months I&#8217;ve been doing Stanfords online machine learning class. This as a great experience, and I now at least have a solid feel on the subjects covered in the course. I actually started off doing the Artificial Intelligence class, and then found that the Machine Learning one was more interesting for [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/12/Gnu-octave.png"><img class="alignright size-full wp-image-1229" title="GNU Octave" src="http://blog.bn2vs.com/wp-content/uploads/2011/12/Gnu-octave.png" alt="" width="200" height="200" /></a>During the last 3 months I&#8217;ve been doing Stanfords <a href="http://www.ml-class.org/">online machine learning class</a>. This as a great experience, and I now at least have a solid feel on the subjects covered in the course.</p>
<p>I actually started off doing the <a href="http://www.ai-class.com/">Artificial Intelligence class</a>, and then found that the Machine Learning one was more interesting for me, and even of higher quality. So I decided to do both classes. After a few weeks I found this was really to much to do on top of my regular work, and decided to drop the AI class, so I could focus on the ML class and get good results there, rather then mediocre results on both. The ML class is made up of 18 lessons, each consisting of a set of videos with in-video mini-quizzes, review questions and programming exercises (in <a href="https://en.wikipedia.org/wiki/GNU_Octave">GNU Octave</a>, similar to MatLab). Although I don&#8217;t have the official score yet, by my own counting I have 800 of 890 points, of which 70 I lost by not making all of the last set of programming exercises due to being sick.</p>
<p>Stanford offered 3 such online classes during Q4 of 2011 (AI, ML and databases), and is tripping this number in Q1 2012. As a response, MIT is going to extend on it&#8217;s <a href="http://ocw.mit.edu/index.htm">OpenCourseWare</a> platform. This is great news for online education, which has made huge strides in the last few years with things such as <a href="http://www.khanacademy.org/">Khan Academy</a>, these online courses by universities and the <a href="https://outreach.wikimedia.org/wiki/Wikipedia_Education_Program">Wikipedia Education Program</a> (more on which in my next blog post). If you want to teach yourself some new things, definitely check out these <strong>awesome</strong> programs <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/12/23/stanfords-machine-learning-class/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Contest extension for MediaWiki</title>
		<link>http://blog.bn2vs.com/2011/11/08/contest-extension-for-mediawiki/</link>
		<comments>http://blog.bn2vs.com/2011/11/08/contest-extension-for-mediawiki/#comments</comments>
		<pubDate>Tue, 08 Nov 2011 13:36:17 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Coding challenge]]></category>
		<category><![CDATA[Contest]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[MediaWiki extensions]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[Wikimedia]]></category>
		<category><![CDATA[Wikipedia]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1212</guid>
		<description><![CDATA[As it&#8217;s been 2 months since my last blog post, I figured it was time for another one. Quite a few things I could write about (SMWCon, my new awesome laptop, Stanfords AI and ML classes, me moving to Berlin, &#8230;), but I decided to give some introduction to my most recent MediaWiki extension: Contest. [...]]]></description>
			<content:encoded><![CDATA[<p><a href="../wp-content/uploads/2011/11/CodeChallengeLogo-301x301.png"><img class="alignright" title="Logo of the October coding challenge" src="../wp-content/uploads/2011/11/CodeChallengeLogo-301x301.png" alt="Logo of the October coding challenge" width="152" height="152" /></a>As it&#8217;s been 2 months since my last blog post, I figured it was time for another one. Quite a few things I could write about (SMWCon, my new <strong>awesome</strong> laptop, Stanfords AI and ML classes, me moving to Berlin, &#8230;), but I decided to give some introduction to <a href="https://www.mediawiki.org/wiki/Extension:Contest">my most recent MediaWiki extension: Contest</a>.</p>
<p>Contest extension that allows users to participate in admin defined  contest challenges. Via a judging interface, judges can discuss and vote  on submissions. I created it for the <a href="https://blog.wikimedia.org/2011/10/20/announcing-the-october-2011-coding-challenge/">Wikimedia October coding challenge</a>, so it got a nice amount of review, uncovering some minor misconceptions I had about some core MW code, and it got deployed on MediaWiki.org. The coding challenge is quite <strong>awesome</strong>, but I won&#8217;t discuss it any further here, so check out the linked blog post if you&#8217;re curious/interested.</p>
<p><strong>Feature overview:</strong></p>
<ul>
<li>Admin interface for managing contests and their challenges.</li>
<li>Landing and signup pages for each contest.</li>
<li>Personal contest list and submission interface for each user.</li>
<li>Summary pages per contest listing contestants, which can be filtered and sorted.</li>
<li>Judging interface that allows for rating and commenting on each participant.</li>
<li>All contests, challenges, contestants, comments and votes can be queried and exported via the API.</li>
<li>Signup and reminder emails.</li>
</ul>
<p><strong>Requirements</strong></p>
<ul>
<li><a title="MediaWiki" href="https://www.mediawiki.org/wiki/MediaWiki">MediaWiki</a> 1.18 or above &#8211; yeah! my first <strong>awesome</strong> MediaWiki 1.18 or later extension <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </li>
<li>PHP 5.2 or above</li>
<li>MySQL</li>
</ul>
<p><strong>Some screenshots</strong></p>
<div id="attachment_1215" class="wp-caption alignnone" style="width: 810px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-welcome-click.png"><img class="size-full wp-image-1215" title="Contest welcome interface" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-welcome-click.png" alt="Contest welcome interface" width="800" height="508" /></a><p class="wp-caption-text">Contest welcome interface</p></div>
<div id="attachment_1216" class="wp-caption alignnone" style="width: 810px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-mycontest.png"><img class="size-full wp-image-1216" title="Contest submission and management interface for a single user" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-mycontest.png" alt="Contest submission and management interface for a single user" width="800" height="566" /></a><p class="wp-caption-text">Contest submission and management interface for a single user</p></div>
<div id="attachment_1217" class="wp-caption alignnone" style="width: 810px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contests.png"><img class="size-full wp-image-1217" title="Contest administration and judging interface listing all contests" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contests.png" alt="Contest administration and judging interface listing all contests" width="800" height="271" /></a><p class="wp-caption-text">Contest administration and judging interface listing all contests</p></div>
<div id="attachment_1218" class="wp-caption alignnone" style="width: 810px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contestitem.png"><img class="size-full wp-image-1218" title="Contest administration and judging interface for a single contest" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contestitem.png" alt="Contest administration and judging interface for a single contest" width="800" height="311" /></a><p class="wp-caption-text">Contest administration and judging interface for a single contest</p></div>
<div id="attachment_1219" class="wp-caption alignnone" style="width: 774px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/764px-Contest-editcontest.png"><img class="size-full wp-image-1219" title="Contest editing interface" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/764px-Contest-editcontest.png" alt="Contest editing interface" width="764" height="600" /></a><p class="wp-caption-text">Contest editing interface</p></div>
<div id="attachment_1220" class="wp-caption alignnone" style="width: 810px"><a href="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contestant-judging.png"><img class="size-full wp-image-1220" title="Judging interface for a single submission" src="http://blog.bn2vs.com/wp-content/uploads/2011/11/800px-Contest-contestant-judging.png" alt="Judging interface for a single submission" width="800" height="554" /></a><p class="wp-caption-text">Judging interface for a single submission</p></div>
<p><strong>Some background</strong></p>
<p>When starting with this extension, it was clear pretty quickly that it could really use the <strong>awesome</strong> DBObject class I&#8217;ve been incrementally creating over my last few extensions and mostly finished in <a href="https://www.mediawiki.org/wiki/Extension:Survey">Survey</a>. This class is a wrapper for objects of a certain type, which is equivalent to a row in some db table. Even though it&#8217;s in essence very simple &#8211; it just has a field that is an associative array with field =&gt; value &#8211; it&#8217;s also very powerful and flexible. When I started with this, I had no idea it would turn out to be so neat. The bad news was that I could not use PHP 5.3 or later for Contest, while the DBObject class uses late static binding, which was introduces in PHP 5.3. I came up with a simple hack: all static methods in the base class have been made-non static, but are marked as &#8220;should be static&#8221;. Then, every deriving class has a public static function s(), which returns a (cached) instance of the class. So then for every &#8220;static&#8221; method you need to call, instead of ClassName::methodName(), you do ClassName::s()-&gt;methodName(). If you know this, and do not misuse the non-static-but-should-be-static methods in the base class, it retains all it&#8217;s niceness, at the cost of something that&#8217;s pretty much a tiny bit of syntactic sugar. And it&#8217;s quite obvious how easy it will be to replace this with actual LSB usage once this becomes possible <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<ul>
<li><a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Survey/includes/SurveyDBClass.php?view=markup">Survey DBObject class</a> &#8211; <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Survey/includes/Survey.class.php?view=markup">deriving class</a></li>
<li><a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Contest/includes/ContestDBObject.php?view=markup">Contest DBObject class</a> &#8211; <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Contest/includes/Contest.class.php?view=markup">deriving class</a></li>
</ul>
<p><strong>Download</strong></p>
<ul>
<li><a href="https://code.google.com/p/mwcontest/downloads/list">Release tarballs</a></li>
<li><a href="http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/Contest/">SVN tags</a></li>
<li><a href="http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/Contest/">SVN trunk</a></li>
</ul>
<p><strong>What&#8217;s next?</strong></p>
<p>There are various small additions that could be made, but one things really stands out: contest configuration with version history. Right now, you can create contests and challenges, modify them and delete them. But once you make a change, the previous version is lost. You cannot revert. You cannot compare. You can&#8217;t even see who made the change or when. Implementing such a thing is not trivial, especially if you want to have a generic system that can be used by any extension that wants to store data and have version history for it. And if you think about it, quite a few extensions could use this. Let&#8217;s have a look at my extensions, latest first, and see if they can use it:</p>
<ul>
<li><a href="https://www.mediawiki.org/wiki/Extension:Contest">Contest</a> &#8211; well yeah, obviously</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Survey">Survey</a> &#8211; yes, for the surveys, their configuration, and their questions</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Semantic_Watchlist">Semantic Watchlist</a> &#8211; yeah, for the watchlist groups</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Include_WP">IncludeWP</a> &#8211; no</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:SubPageList">SubPageList</a> &#8211; no</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Live_Translate">Live Translate</a> &#8211; yeah, for the translation memory admin</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Push">Push</a> &#8211; no, although it could, if it had an admin interface for the push targets</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Validator">Validator</a> &#8211; no</li>
<li><a href="https://www.mediawiki.org/wiki/Extension:Maps">Maps</a> and <a href="https://www.mediawiki.org/wiki/Extension:Semantic_Maps">SM</a> &#8211; yeah, for the map layer definitions currently done as key=value pairs, one per line, in the Layer namespace</li>
</ul>
<p>That&#8217;s 6 out of 10 just for the extensions I wrote. What it comes down to is that pretty much any extension that has some sort of settings interface that is not user-specific, could use this. And maybe even the user specific ones, which would obviously include the user preferences in MediaWiki core. So why not store this data in wiki pages, such as done by Maps for layers? You could even store it as JSON or serialized PHP objects if you need more complexity&#8230; The things with this is that it only works for simple use cases (such as the layers in Maps), and even then is limited. You cannot query over the data as you do not have it in relational form. And you cannot have fine grained access and write rights control over the data, which in a lot of cases is quite important. So a generic solution here would be an <strong>awesome</strong> addition to MediaWiki if you ask me.</p>
<p>More info on Contest can be found on <a href="https://www.mediawiki.org/wiki/Extension:Contest">it&#8217;s documentation page</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/11/08/contest-extension-for-mediawiki/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Survey extension for MediaWiki</title>
		<link>http://blog.bn2vs.com/2011/09/14/survey-extension-for-mediawiki/</link>
		<comments>http://blog.bn2vs.com/2011/09/14/survey-extension-for-mediawiki/#comments</comments>
		<pubDate>Wed, 14 Sep 2011 16:08:14 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[MediaWiki extensions]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[Survey]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1205</guid>
		<description><![CDATA[Over the past 3 weeks I&#8217;ve been working on a new MediaWiki extension that allows creation of on-wiki surveys by admins. It comes with a whole bunch of neat features, and is the most awesome (code wise) extensions I&#8217;ve created so far.It&#8217;s aptly titled Survey. Feature overview Surveys get displayed to wiki users using a [...]]]></description>
			<content:encoded><![CDATA[<p>Over the past 3 weeks I&#8217;ve been working on a new <a href="http://www.mediawiki.org/wiki/">MediaWiki</a> extension that allows creation of on-wiki surveys by admins. It comes with a whole bunch of neat features, and is the most awesome (code wise) extensions I&#8217;ve created so far.It&#8217;s aptly titled <a href="http://www.mediawiki.org/wiki/Extension:Survey">Survey</a>.</p>
<p><strong>Feature overview</strong></p>
<ul>
<li>Surveys get displayed to wiki users using a nice pop-up form.</li>
<li>Surveys can be created and modified via an admin panel (Special:Surveys).</li>
<li>Surveys can be shown to specific types of users (logged in, anonymous, editor, confirmed, &#8230;)</li>
<li>Surveys can be shown for a specified percentage of users, and only after a certain amount of page views.</li>
<li>Survey questions can have different types of inputs, of which some allow restricting answers.</li>
<li>Surveys can be tested by admins via Special:TakeSurvey without them being live on the wiki.</li>
<li>Summaries of survey submissions can be found on Special:SurveyStats.</li>
<li>The survey submission data (ie user answers) can be exported via an API.</li>
</ul>
<p><strong>Requirements</strong></p>
<p>Survey makes use of many new features introduced in MediaWiki 1.17, and therefore requires this version or later. It even makes use of MW 1.18 features, with fallback code for MW 1.17 <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  It also makes use of 5.3 features, these being late static binding and anonymous functions, so it won&#8217;t work with PHP 5.2.x and earlier.</p>
<p><strong>Some screenshots</strong></p>
<div id="attachment_1206" class="wp-caption alignnone" style="width: 720px"><a href="http://www.mediawiki.org/wiki/Extension:Survey"><img class="size-full wp-image-1206" title="Special:Surveys: the main administration interface for Surveys" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/Survey-surveys.png" alt="Special:Surveys: the main administration interface for Surveys" width="710" height="271" /></a><p class="wp-caption-text">Special:Surveys: the main administration interface for Surveys</p></div>
<div id="attachment_1207" class="wp-caption alignnone" style="width: 810px"><a href="http://www.mediawiki.org/wiki/Extension:Survey"><img class="size-full wp-image-1207" title="Special:EditSurvey: administration interface to create and edit surveys" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/800px-Survey-survey.png" alt="Special:EditSurvey: administration interface to create and edit surveys" width="800" height="550" /></a><p class="wp-caption-text">Special:EditSurvey: administration interface to create and edit surveys</p></div>
<div id="attachment_1209" class="wp-caption alignnone" style="width: 604px"><a href="http://www.mediawiki.org/wiki/Extension:Survey"><img class="size-full wp-image-1209" title="Example of a survey as it appears to users" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/594px-Survey-dialog.png" alt="Example of a survey as it appears to users" width="594" height="600" /></a><p class="wp-caption-text">Example of a survey as it appears to users</p></div>
<div id="attachment_1208" class="wp-caption alignnone" style="width: 810px"><a href="http://www.mediawiki.org/wiki/Extension:Survey"><img class="size-full wp-image-1208" title="Special:SurveyStats: summarizes the submissions for a single survey" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/800px-Survey-stats.png" alt="Special:SurveyStats: summarizes the submissions for a single survey" width="800" height="396" /></a><p class="wp-caption-text">Special:SurveyStats: summarizes the submissions for a single survey</p></div>
<p><strong>Downloads</strong></p>
<ul>
<li><a href="https://code.google.com/p/mwsurvey/downloads/list">Survey release downloads</a></li>
<li><a href="http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/Survey/">Survey SVN tags</a></li>
<li><a href="http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/Survey">Survey SVN trunk</a></li>
</ul>
<p><strong>Some background</strong></p>
<p>I developed the <a href="http://www.mediawiki.org/wiki/Extension:Survey">Survey</a> extension as <a href="http://wikiworks.com/">WikiWorks</a> consultant for <a href="http://www.ieee.org/">the IEEE</a>, with some help from <a href="http://www.yaronkoren.com/">Yaron Koren</a>.</p>
<p><a href="http://wikiworks.com"><img class="alignnone size-full wp-image-1210" title="WikiWorks" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/wikiworks-header-logo.png" alt="WikiWorks" width="429" height="91" /></a></p>
<p><strong>What&#8217;s next?</strong></p>
<p>There are many many features that can be added to this extension to make it even more awesome. I&#8217;d like to get some initial feedback on version 0.1, so the usability issues and bugs that might be there can be ironed out. Please place any feedback you might have on <a href="http://www.mediawiki.org/wiki/Extension_talk:Survey">the discussion page</a>. This initial release contains all the features my client needed, so if you want to have new capabilities added and can fund the work, definitely contact me <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<div id="_mcePaste" class="mcePaste" style="position: absolute; left: -10000px; top: 0px; width: 1px; height: 1px; overflow: hidden;">http://www.mediawiki.org/wiki/Extension:SurveySurvey</div>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/09/14/survey-extension-for-mediawiki/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Earth and KML support in (Semantic) Maps 1.0.3</title>
		<link>http://blog.bn2vs.com/2011/09/14/earth-and-kml-support-in-semantic-maps-1-0-3/</link>
		<comments>http://blog.bn2vs.com/2011/09/14/earth-and-kml-support-in-semantic-maps-1-0-3/#comments</comments>
		<pubDate>Wed, 14 Sep 2011 14:37:54 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[Google Earth]]></category>
		<category><![CDATA[Google Maps]]></category>
		<category><![CDATA[KML]]></category>
		<category><![CDATA[Mapping]]></category>
		<category><![CDATA[Maps]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[Semantic Maps]]></category>
		<category><![CDATA[Semantic MediaWiki]]></category>
		<category><![CDATA[Semantics]]></category>
		<category><![CDATA[SMW]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1194</guid>
		<description><![CDATA[Yesterday I released version 1.0.3 of the Maps and Semantic Maps MediaWiki extensions. This release re-introduces Google Earth support, this time for Google Maps v3, and enhances the KML/KMZ support for this mapping service as well. Many thanks go to Jon Povey for funding the implementation of these features! Since I didn&#8217;t make any release [...]]]></description>
			<content:encoded><![CDATA[<p>Yesterday I released version 1.0.3 of the <a href="http://www.mediawiki.org/wiki/Extension:Maps">Maps</a> and <a href="http://www.mediawiki.org/wiki/Extension:Semantic_Maps">Semantic Maps</a> MediaWiki extensions. This release re-introduces Google Earth support, this time for Google Maps v3, and enhances the KML/KMZ support for this mapping service as well. Many thanks go to Jon Povey for funding the implementation of these features! Since I didn&#8217;t make any release announcements for 1.0.1 or 1.0.2, I&#8217;ll just include changes made in these versions as well, effectively treating this as the release after 1.0.</p>
<p><strong>KML/KMZ support</strong></p>
<p>The Google Maps v3 service now supports 2 new KML related parameters: kml and gkml. Both accept a url pointing to a KML (or KMLZ) file. The first one uses a KML parsing library (<a href="https://code.google.com/p/geoxml3/">geoxml3</a>) included in the extension to translate the features described in the KML file into elements to place onto the map. This is very nice for people that do not want to be dependent on third party services, but sadly enough, the library is somewhat limited. It lacks support for more advanced KML features such as polygons and paths. The gkml parameter uses Googles KML service, which pulls the KML file to some Google server, and then decides if it should be send to the client (for simple and small files), or if it should be rendered server side and send as tiles to the client (for big files or files containing advanced features such as polygons).</p>
<p>You can now also choose if you want the map to rezoom after the KML layers have been loaded or not using the kmlrezoom parameter. KML layers will load a bit after the map, since they require extra resources to be loaded, and there is no need to let the user wait to see the normal map until those are done loading.</p>
<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/09/kmlpath.png"><img class="alignnone size-full wp-image-1195" title="A path with waypoints on a Google Maps map" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/kmlpath.png" alt="A path with waypoints on a Google Maps map" width="407" height="191" /></a></p>
<p><strong>Google Earth support</strong></p>
<p>Maps already has support for Google Earth since on of it&#8217;s earliest versions. This was quite easy to achieve as Google Maps v2 natively supported it. Now with the switch to Google Maps v3 in Maps 1.0, people asked for Google Maps support in that as well. Unfortunately Google Earth is not natively supported here. Maps now provides support for GE using the <a href="https://code.google.com/p/google-maps-utility-library-v3/">Google Maps utility library v3</a>. The earth type can be enabled by adding &#8220;earth&#8221; to the types parameter, or setting it as the default type using &#8220;type&#8221;. Do however note that due to this not being officially supported by Google, it has some deficiencies. For one, when switching to GE, the map controls won&#8217;t be displayed any more, preventing you from switching back. Also, the GE plugin is only supported on Windows and Mac, so won&#8217;t be usable for mobile or Linux users.</p>
<p>A completely new thing added in 1.0.3 is the tilt parameter, which, as you can probably guess, allows you to set the initial tilt of the GE layer.</p>
<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/09/gearth.png"><img class="alignnone size-full wp-image-1196" title="Google Earth in the browser" src="http://blog.bn2vs.com/wp-content/uploads/2011/09/gearth.png" alt="Google Earth in the browser" width="427" height="191" /></a></p>
<p><strong>Full list of changes since 1.0:</strong></p>
<ul>
<li> Added support for Google Earth in Google Maps v3.</li>
<li> Added tilt parameter for Google Earth in Google Maps v3.</li>
<li> Added kmlrezoom parameter for Google Maps v3 and general $egMapsRezoomForKML setting.</li>
<li> Added API module for geocoding.</li>
<li> Added &#8216;geocoding&#8217; right.</li>
<li> Added language parameter to the mapsdoc hook.</li>
<li> Use of Validator 0.4.10s setMessage method instead of setDescription for better i18n.</li>
<li> Minor improvement to script loading.</li>
<li> Fixed Google Maps v3 JavaScript issue occurring on MediaWiki 1.17.</li>
<li> Fixed internationalization of distances (bug 30467).</li>
<li> Fixed zoom and types parameters for Google Maps v3.</li>
</ul>
<ul>
<li> Added geocodecontrol parameter for the form inputs.</li>
<li> Fixed handling of the semantic link caption in the geographical coordinate datavalue class.</li>
</ul>
<p><strong>What&#8217;s next?</strong></p>
<p>For now, I have no specific plans for changes or addition to either of the  mapping extensions, further then some minor script loading improvements,  as I &#8216;m working on several other projects. However it&#8217;s likely that  people will have suggestions for new features at <a rel="nofollow" href="http://semantic-mediawiki.org/wiki/SMWCon_Fall_2011">SMWCon Fall 2011</a>, which is next week.</p>
<p><strong>Download</strong></p>
<ul>
<li><a href="https://code.google.com/p/mwmaps/downloads/list">Maps downloads</a></li>
<li><a href="https://code.google.com/p/semanticmaps/downloads/list">Maps and Semantic Maps downloads</a></li>
<li>Maps SVN: <a href="http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/Maps">tags</a>, <a href="http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/Maps/">trunk</a></li>
<li>Semantic Maps SVN: <a href="http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/Semantic_Maps">tags</a>, <a href="http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/SemanticMaps/">trunk</a></li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/09/14/earth-and-kml-support-in-semantic-maps-1-0-3/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>WikiLovesMonuments and the Upload Wizard</title>
		<link>http://blog.bn2vs.com/2011/08/24/wikilovesmunuments-and-the-upload-wizard/</link>
		<comments>http://blog.bn2vs.com/2011/08/24/wikilovesmunuments-and-the-upload-wizard/#comments</comments>
		<pubDate>Wed, 24 Aug 2011 12:19:40 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Planet Wikimedia]]></category>
		<category><![CDATA[UploadWizard]]></category>
		<category><![CDATA[WikiLovesMonuments]]></category>
		<category><![CDATA[Wikimedia]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1188</guid>
		<description><![CDATA[As this particular project is coming to and end, I figured I&#8217;d do a quick blog post on it. Wiki Loves Monuments (WLM) is a photo contest for European monuments, organized by Wikimedia this September. Last year some JavaScrip hacks on the regular Wikimedia Commons (the media repository for Wikipedia and other Wikimedia Foundation projects) [...]]]></description>
			<content:encoded><![CDATA[<p>As this particular project is coming to and end, I figured I&#8217;d do a quick blog post on it.</p>
<p><a href="http://www.wikilovesmonuments.eu/">Wiki Loves Monuments</a> (WLM) is a photo contest for European monuments, organized by Wikimedia this September. Last year some JavaScrip hacks on the regular <a href="https://secure.wikimedia.org/wikipedia/commons/wiki/">Wikimedia Commons</a> (the media repository for Wikipedia and other <a href="http://wikimediafoundation.org/">Wikimedia Foundation</a> projects) upload interface where used for this contest. This year the new and completely awesome <a href="https://secure.wikimedia.org/wikipedia/mediawiki/wiki/Extension:UploadWizard">Upload Wizard</a> (UW) will be used, with configuration optimized for WLM. I created a campaign-based configuration system from the UW and also added a bunch of new settings.</p>
<p>2 new special pages where added. One listing all campaigns, their status, and edit and delete links. This is at Special:UploadCampaigns.</p>
<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/08/uploadCampaigns.png"><img class="size-full wp-image-1189 alignnone" title="Upload campaign management interface" src="http://blog.bn2vs.com/wp-content/uploads/2011/08/uploadCampaigns.png" alt="Upload campaign management interface" width="634" height="242" /></a></p>
<p>The other special page handles the edit action and displays a list of all available settings that can be modified for the campaign. This is at Special:UploadCampaign/name.</p>
<p><a href="http://blog.bn2vs.com/wp-content/uploads/2011/08/uploadCampaign.png"><img class="size-large wp-image-1190 alignnone" title="Upload campaign admin" src="http://blog.bn2vs.com/wp-content/uploads/2011/08/uploadCampaign-1024x376.png" alt="Upload campaign admin" width="1024" height="376" /></a></p>
<p>A campaign can be applied to the UW by adding the &#8220;campaign&#8221; url parameter with as value the campaign name, ie ?campaign=wlm-be.</p>
<p>One fun thing about the architecture of the campaign system is that the setting support is very generic. I created a <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/UploadWizard/includes/UploadWizardConfig.php?view=markup">new settings class</a> that pulls in the default settings, overrides these with the wikis config (ie PHP vars in LocalSettings.php), passed URL arguments and finally the upload campaign settings if a campaign is specified. I like this kind of setup, as it&#8217;s a lot nicer then dealing with over 9000 global variables, and in the meanwhile already applied some variation of it <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/SemanticSignup/SemanticSignup.settings.php?view=markup">in Semantic Signup</a> and <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Survey/Survey.settings.php?view=markup">in my new Surveys extension</a>. And I wrote up a <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/Maps/includes/Maps_Settings.php?revision=94439&amp;view=markup">more general and powerful version</a> of such setting handling in the Maps extension. Unfortunately this code uses late static bindings and thus requires PHP 5.3, making it not usable in actual code for quite a while <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_sad.gif' alt=':(' class='wp-smiley' />  Another neat thing is that the <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/UploadWizard/includes/UploadWizardCampaign.php?view=markup">upload campaign class</a> only specifies a lift of settings that should be configurable for upload campaigns, together with what kind of HTML form input they should be displayed. That info is then merged with the settings obtained from the settings class and put into a FormSpecialPage, which uses HTMLForm to display anything without any further hassle <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Not used the Upload Wizard before and curious how it works? Go <a href="https://secure.wikimedia.org/wikipedia/commons/wiki/Special:UploadWizard">upload some nice stuff to commons</a> then <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/08/24/wikilovesmunuments-and-the-upload-wizard/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Live Translate 1.2</title>
		<link>http://blog.bn2vs.com/2011/08/17/live-translate-1-2/</link>
		<comments>http://blog.bn2vs.com/2011/08/17/live-translate-1-2/#comments</comments>
		<pubDate>Wed, 17 Aug 2011 15:58:15 +0000</pubDate>
		<dc:creator>Jeroen De Dauw</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[Caching]]></category>
		<category><![CDATA[GNU GPL]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[Live Translate]]></category>
		<category><![CDATA[localStorage]]></category>
		<category><![CDATA[MediaWiki]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Refactoring]]></category>

		<guid isPermaLink="false">http://blog.bn2vs.com/?p=1182</guid>
		<description><![CDATA[A few days ago I released version 1.2 of the Live Translate MediaWiki extension, which is a major update bringing mainly under-the-hood improvements. I&#8217;ve worked on this for about 3 days in my free time, mainly to try out some JavaScript techniques I had not utilized yet. These are the changes for 1.2: Rewrote translation [...]]]></description>
			<content:encoded><![CDATA[<p>A few days ago I released version 1.2 of the <a href="https://secure.wikimedia.org/wikipedia/mediawiki/wiki/Extension:Live_Translate">Live Translate</a> MediaWiki extension, which is a major update bringing mainly under-the-hood improvements. I&#8217;ve worked on this for about 3 days in my free time, mainly to try out some JavaScript techniques I had not utilized yet.</p>
<p>These are the changes for 1.2:</p>
<ul>
<li>Rewrote translation control JavaScript to a <a href="http://www.jquery.com/">jQuery</a> plugin.</li>
<li>Added caching layer utilizing memory and <a href="https://secure.wikimedia.org/wikipedia/en/wiki/LocalStorage">LocalStorage</a> when available to speed up local translations.</li>
<li>Added API module to query translation memories.</li>
<li>Added i18n alias file.</li>
<li>Added TMX admin user rights group.</li>
</ul>
<p>This post is about the first two.</p>
<p><strong>Some background</strong></p>
<p>The Live Translate (LT) extension allows live translation of content in wiki pages. For this it uses translation services such as Google Translate or Microsoft Translator. It also allows specifying your own translations for certain words within the wiki, which will then be left alone by the (remote) translation services. Such specifications of translations are called translation memories (TM), and are typically done in a special XML-based format called Translation Memory eXchange (TMX). LT also supports a more wiki-friendly format, custom written, which is DSV-based. Translation memories in both these formats can be embedded in wiki pages designated as TM or you can point to files hosted somewhere else. What it comes down to is that there are a set of local translations, which require special handling: local translation and be ignored by the remote translation service.</p>
<p>On every translation, the JavaScript needs to know which are the special  words that have a local translation, so translations for these can be  requested, and measures can be taken to not send them to the remote  translation services. This means doing a call to the wikis API to obtain  these words. In case of big translation memories, this requires several  calls to obtain all words, often resulting in a few seconds wait before  local translations are even requested.  If there are words that  have local translations on the page, a single request I send to another part of the API to obtain these translations for the language currently translated to. This usually bring the total time to complete local translation to somewhere between 2 and 5 seconds, after which, in version 1.1 and earlier, remote translation is kicked of.</p>
<p><strong>The idea</strong></p>
<p>Translation memories do not tend to change all the time, so it&#8217;s very inefficient to request all special words for every translation, and in somewhat lesser degree to always request the translations. The obvious answer to this is local caching, and since I wanted to play around with HTML5 localStorage a bit, this is exactly what I did. I also wanted to make use of JavaScript capabilities I was not really aware of back in last December, when writing Live Translate, so took this as an opportunity to also do some JavaScript refactoring. These being primarily prototypes, closure scopes and callbacks.</p>
<p><strong>The realization</strong></p>
<p>I made a whole bunch of client side changes (and some server side changes to the API), but the most significant ones are the creation of a translation memory object which takes care of all caching, and the rewrite of the translation control to a jQuery plugin.</p>
<p><span style="text-decoration: underline;">Translation memory object</span></p>
<p>In file <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/LiveTranslate/includes/ext.lt.tm.js?revision=94102&amp;view=markup">includes/ext.lt.tm.js</a>.</p>
<p>The translation memory object class is named simply &#8220;memory&#8221; and resides in the &#8220;lt&#8221; namespace. It acts as abstraction layer via which special words and translations of those special words can be accessed. It takes care of all API interaction and caching and exposes 2 simple functions, getSpecialWords and getTranslations, which are called by the translation control.</p>
<p>When the cache is empty, the memory will request a new hash via the API, which indicates the &#8220;version&#8221; of the translation memories on the server, and is later used for cache invalidation. It the proceeds fetching the requested special words or translations of special words and returns these via a callback passed to either getSpecialWords or getTranslations. Before this last step is done, the obtained data is cached in memory (the words and translations fields, one lines 26 and 30, respectively), and, when available, also in HTML5 localStorage. The in memory caching only yields advantages when doing multiple translations on a single page, which is rather rare, so is not that much of a win. The data stored in localStorage on the other hand, persists when navigating to other pages, even when closing the browser and re-opening it. localStorage really isn&#8217;t a cache on it&#8217;s own, but the lt.memory class uses it as one.</p>
<p>When the cache is not empty, a single request to the API is made to compare the earlier obtained hash and see if any changes to the TMs have been made, and thus if the cache should be invalidated. If changes have been made, the stored data is discarded and pretty much the same as when the cache was empty happens. If no changes have been made, locally stored data is used where possible. In case of the list of special words, no requests will have to be made at all, since all such words are already known. For the translations of these words it&#8217;s a little trickier, since the needed data here varies from page to page, and also depends on both the source and destination language. The lt.memory class checks which of the needed data if available, and in case there is a remainder of non-known translations, requests these. The newly obtained translations are then of course also added to the cache.</p>
<p><span style="text-decoration: underline;">jQuery plugin</span></p>
<p>In file <a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/LiveTranslate/includes/jquery.liveTranslate.js?revision=94440&amp;view=markup">jquery.liveTranslate.js</a>.</p>
<p>This plugin contains a lot of already existing code from Live Translate 1.1, but is structured a lot better. It takes care of creating all the HTML needed for the control (while in 1.1, the HTML was provided, and only events where bound to it) in it&#8217;s setup function (line 147). The click event handler for the translation button calls the obatinAndInsetSpecialWords which uses the getSpecialWords function of the lt.memory class to obtain the words with local translations, and then inserts them, meaning that occurrences of these words are wrapped into notranslate spans, which then enables finding all words which should be translated locally, and makes them be ignored by the remote translation services. The click handler function passed doTranslations as completion callback to obatinAndInsetSpecialWords, which starts both local and remote translation in parallel. Local translation is done, as you can uncountably guess, by calling getTranslations function.</p>
<p><strong>The results</strong></p>
<p>Once the cache is warm (the user made a translation before) and valid (the TMs have not changed), local translation is practically instant (~0.4 seconds in my tests). Since remote translation now starts as soon as the special words are known, this can take as little as ~0.2 seconds, a huge difference compares to the earlier up to 5 seconds and possibly longer. All assuming you are using a modern browser of course <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Not to forget, the code is a lot better structures now. It should be a lot easier to track the order of execution, and it&#8217;s now possible (JavaScript wise) to place multiple translation controls onto a single page (which has little practical value, but indicates a better design).</p>
<p>And, maybe most importantly for me, I now have a much better grasp of the earlier mentioned prototypes, callbacks and closure scopes. Perhaps most of the time I spend on this version was figuring out how to properly use these and debugging out misconceptions I had about how they worked <img src='http://blog.bn2vs.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p><strong>Live Translate</strong></p>
<ul>
<li><a href="https://secure.wikimedia.org/wikipedia/mediawiki/wiki/Extension:Live_Translate">Documentation</a></li>
<li><a href="https://code.google.com/p/livetranslate/downloads/list">Downloads</a></li>
<li>SVN trunk (<a href="http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/LiveTranslate/">viewvc</a>, <a href="http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/LiveTranslate/">svnroot</a>)</li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://blog.bn2vs.com/2011/08/17/live-translate-1-2/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

