<?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>my 2 cents &#187; tine 2.0</title>
	<atom:link href="http://corneliusweiss.de/category/tine-20/feed/" rel="self" type="application/rss+xml" />
	<link>http://corneliusweiss.de</link>
	<description>Exciting brainjunk of Cornelius Weiss</description>
	<lastBuildDate>Sat, 26 Mar 2011 10:25:07 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.2-alpha</generator>
		<item>
		<title>Tine 2.0 moved to GIT</title>
		<link>http://corneliusweiss.de/2011/03/26/tine-2-0-moved-to-git/</link>
		<comments>http://corneliusweiss.de/2011/03/26/tine-2-0-moved-to-git/#comments</comments>
		<pubDate>Sat, 26 Mar 2011 10:25:07 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=292</guid>
		<description><![CDATA[The Tine 2.0 Project changes its Sourcecode-Management-System from Subversion to GIT. The main reasons for this change are the fast and reliable branching and merging capabilities of GIT. With this, the project hopes to reach an even higher level of development productivity. As all Contents from the old Subversion got migrated into the new GIT [...]]]></description>
			<content:encoded><![CDATA[<p>The <a href="http://www.tine20.org/">Tine 2.0 Project</a> changes its Sourcecode-Management-System from <a href="http://subversion.tigris.org/">Subversion</a> to <a href="http://git-scm.com/">GIT</a>.</p>
<p>The main reasons for this change are the fast and reliable branching and merging capabilities of GIT. With this, the project hopes to reach an even higher level of development productivity.</p>
<p>As all Contents from the old Subversion got migrated into the <a href="http://git.tine20.org/git/tine20/">new GIT repository</a> the Subversion service got switched off.</p>
<p><strong>Anonymous Access</strong><br />
Anonymous cloning the sources could be done with:<br />
<code>
<pre>git clone http://git.tine20.org/git/tine20</pre>
<p></code></p>
<p>Switch go the stable branch with<br />
<code>
<pre>git checkout -b 2011-01 origin/2011-01</pre>
<p></code></p>
<p>Updates could be retrieved with<br />
<code>
<pre>git pull</pre>
<p></code></p>
<p><strong>Contributors Access</strong><br />
As a contributor please make sure to familiarize yourself with GIT and read one of the dozens of introductions out in the net.</p>
<p>Contributors need to check out per https:<br />
<code>
<pre>git clone https://git.tine20.org/git/tine20</pre>
<p></code></p>
<p>Usersames and passwords got migrated from the old subversion service</p>
<p>Depending on your Operating system / tools you might need to add a
<pre>~/.netrc</pre>
<p> with the following content:<br />
<code>
<pre>
machine git.tine20.org
login MYCONTRIBUTORSLOGINNAME
password MYCONTRIBUTORSPASSWORD
</pre>
<p></code></p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2011/03/26/tine-2-0-moved-to-git/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>New Features in Calendar for Tine 2.0 Neele (2011-01)</title>
		<link>http://corneliusweiss.de/2011/01/21/new-features-in-calendar-for-tine-2-0-neele-2011-01/</link>
		<comments>http://corneliusweiss.de/2011/01/21/new-features-in-calendar-for-tine-2-0-neele-2011-01/#comments</comments>
		<pubDate>Fri, 21 Jan 2011 10:48:50 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[extJS]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[tine 2.0]]></category>
		<category><![CDATA[Zend Framework]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=286</guid>
		<description><![CDATA[I just assembled a small video, describing the new feature which came in Tine 2.0Version Neele: Printing Color definition Fast responses to invitations Quick tip symbols Out of view hints]]></description>
			<content:encoded><![CDATA[<p>I just assembled a small video, describing the new feature which came in <a href="http://www.tine20.org/">Tine 2.0</a>Version Neele:</p>
<ul>
<li>Printing</li>
<li>Color definition</li>
<li>Fast responses to invitations</li>
<li>Quick tip symbols</li>
<li>Out of view hints</li>
</ul>
<p><iframe title="YouTube video player" class="youtube-player" type="text/html" width="650" height="395" src="http://www.youtube.com/embed/rN-VbjmP4hE" frameborder="0" allowFullScreen></iframe></p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2011/01/21/new-features-in-calendar-for-tine-2-0-neele-2011-01/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>How to Speed up the Slow Zend_Date Class</title>
		<link>http://corneliusweiss.de/2010/11/09/how-to-speed-up-the-slow-zend_date-class/</link>
		<comments>http://corneliusweiss.de/2010/11/09/how-to-speed-up-the-slow-zend_date-class/#comments</comments>
		<pubDate>Tue, 09 Nov 2010 14:29:21 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[php]]></category>
		<category><![CDATA[tine 2.0]]></category>
		<category><![CDATA[Zend Framework]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=270</guid>
		<description><![CDATA[Is Zend_Date slow? Well, it&#8217;s always easy to state that something is slow, so let me be a bit more precise: If you need to do a lot of complex date/time operations in you applications, Zend_Date might turn out to be the major bottleneck. If you just need localization for some date&#8217;s Zend_Date presumably won&#8217;t [...]]]></description>
			<content:encoded><![CDATA[<h4>Is Zend_Date slow?</h4>
<p>Well, it&#8217;s always easy to state that something is slow, so let me be a bit more precise: If you need to do a lot of complex date/time operations in you applications, <a href="http://framework.zend.com/manual/en/zend.date.html">Zend_Date</a> might turn out to be the major bottleneck. If you just need localization for some date&#8217;s Zend_Date presumably won&#8217;t be your problem.</p>
<p>In the Calendar app of <a href="http://www.tine20.org/">Tine 2.0</a> it turned out, that Zend_Date consumes 66% of the time of a Month view Request in a realistic szenario.</p>
<p>Just bashing Zend_Date would be to easy, as it has a remarkable feature set. Most notably in my view:<br />
- solves the year 2038 problem on 32 bit systems<br />
- full timezone support<br />
- full localization support<br />
- full support for ISO 8601 date string identifiers</p>
<p>As Date/Time is a really complex topic, here my full acknowledgement for this feature set at a time when PHP couldn&#8217;t help on all this.</p>
<p>On the other hand you don&#8217;t always need all the nice features it has, but you might want to use Zend_Date as generic date/time abstraction all over your applications. In this case Zend_Date is slow and has a lot of potential for improvements.</p>
<h4>Patching Zend_Date</h4>
<h5>Zend_Date::__construct($date, $format, $locale)</h5>
<p>Zend_Dates could be created from a date string in an arbitrary format and locale. This is great if you need to parse custom date strings.</p>
<p>When dealing with Zend_Date in backend operations, you normally only use very few date/time representation formats. e.g. &#8216;yyyy-MM-dd HH:mm:ss&#8217; which is the mysql date/time format.</p>
<p>For this kind of input Zend_Date has no optimization. An easy performance patch for this problem could be:</p>
<p><code> </code></p>
<p><code></p>
<pre>if ($format === 'yyyy-MM-dd HH:mm:ss') {
    $matches = array();
    preg_match("/^(\d{4})-(\d{2})-(\d{2})[T ]{1}(\d{2}):(\d{2}):(\d{2})/", $_ISO, $matches);

    if (count($matches) == 7) {
        list($match, $year, $month, $day, $hour, $minute, $second) = $matches;
        // NOTE: PHP5 timestamp support is 32 bit and ends on 2038-01-19 03:14:07
        if ($year &lt; 2038) {
           $date = mktime($hour, $minute, $second, $month, $day, $year);
           $format = Zend_Date::TIMESTAMP
       }
    }
}</pre>
<p></code></p>
<h5>Zend_Date::get($part, $locale)</h5>
<p>When converting Zend_Dates to strings, the same as above applies. Here an easy patch could be:<br />
<code> </code></p>
<p><code></p>
<pre>if (! $part) {
    $part = self::TIMESTAMP;
}

if (array_key_exists($part, self::$_dateMap)) {
    $dt = new DateTime('@' . $this-&gt;getUnixTimestamp());
    $dt-&gt;setTimezone(new DateTimeZone($this-&gt;getTimezone()));

    $s = $dt-&gt;format(self::$_dateMap[$part]);
    switch($part) {
        case 'm':
            $s = (int) preg_replace('/^0/', '', $s);
            break;
        }
    return $s;
}</pre>
<p></code></p>
<p>with this dateMap<br />
<code> </code></p>
<p><code></p>
<pre>private static $_dateMap = array(
    'yyyy-MM-dd HH:mm:ss' =&gt; 'Y-m-d H:i:s',
    'MM' =&gt; 'm',
    'm'  =&gt; 'i', // spechial handling required!
    'M'  =&gt; 'n',
    'd'  =&gt; 'j',
    'h'  =&gt; 'g',
    'H'  =&gt; 'G',
    'HH' =&gt; 'H',
    's'  =&gt; 's',
    'I'  =&gt; 'I',
    'z'  =&gt; 'T',
    'U'  =&gt; 'U',
    'eee' =&gt; 'N',
    'D'  =&gt; 'z',
    'e'  =&gt; 'w',
    'X'  =&gt; 'Z'
);</pre>
<p></code></p>
<h5>Zend_Date_DateObject::setTimezone($zone)</h5>
<p>As ZF requires PHP 5.2.4 and above, we can use native PHP functions to improve setTimezone:<br />
<code> </code></p>
<p><code></p>
<pre>public function setTimezone($zone = null)
{
    try {
        $dtz = new DateTimeZone($zone);
        $this-&gt;_offset   = $dtz-&gt;getOffset(new DateTime('1970-02-01 00:00:00'));
        $this-&gt;_timezone = $zone;
    } catch (Exception $e) {
        require_once 'Zend/Date/Exception.php';
        throw new Zend_Date_Exception("timezone ($zone) is not a known timezone", $zone);
    }
    if (($zone == 'UTC') or ($zone == 'GMT')) {
        $this-&gt;_dst = false;
    } else {
        $this-&gt;_dst = true;
    }
    return $this;
}</pre>
<p></code></p>
<p>This are just 3 very easy patches, but for a Tine 2.0 Calendar month view request it saves 41% of the request time!</p>
<h4>Avoiding Zend_Date</h4>
<p><a href="http://derickrethans.nl/">Derick Rethans</a> contributed a great <a href="http://php.net/DateTime">DateTime</a> class to PHP which is in included beginning with version 5.2 which got even more improved in version 5.3. This class solves the year 2038 problem, has full timezone support.<br />
<a href="http://corneliusweiss.de/wp-content/uploads/2010/11/DateTime.jpg"><img class="alignleft size-medium wp-image-272" title="DateTime" src="http://corneliusweiss.de/wp-content/uploads/2010/11/DateTime-300x181.jpg" alt="" width="300" height="181" /></a><br />
So my first idea was to write a new Zend_Date class which requires PHP version &gt;= 5.3 to be used as a drop in replacement. Unfortunately it turned out, that the design of Zend_Date is not compatible with the DateTime, or to be more precise, the new class would also be slow due to two base restrictions in Zend_Date:<br />
- ISO representation for date string identifiers<br />
- Zend_Date also represents date intervals which have a separate class in PHP.</p>
<p>At the end I implemented on own wrapper class around DateTime which supports some old Zend_Date signatures, so that we don&#8217;t had to edit all our code. Zend_Date is only used when Server side locale handling is needed, like in exports.</p>
<p>Switching from Zend_Date to native DateTime brought us a speed up of 66% in a calendar month view request.</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2010/11/09/how-to-speed-up-the-slow-zend_date-class/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>How To Pronouce Tine 2.0</title>
		<link>http://corneliusweiss.de/2010/04/24/how-to-pronouce-tine-2-0/</link>
		<comments>http://corneliusweiss.de/2010/04/24/how-to-pronouce-tine-2-0/#comments</comments>
		<pubDate>Sat, 24 Apr 2010 18:26:43 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=246</guid>
		<description><![CDATA[As it&#8217;s becomeing a FAQ, here a small note, how to procounce &#8220;Tine 2.0&#8220;: function bgplay(surl) { document.getElementById("bgplay").innerHTML= ""; } Tine two dot oh For those of you who are curious what Tine 2.0 stands for, please find my post from 2007/12 If you still need some more input for the next nerd party, you [...]]]></description>
			<content:encoded><![CDATA[<p>As it&#8217;s becomeing a FAQ, here a small note, how to procounce &#8220;<a href="http://www.tine20.org">Tine 2.0</a>&#8220;:<br />
<a href="http://corneliusweiss.de/wp-content/uploads/2010/04/tine-pronouce.gif"><img class="size-full wp-image-253 alignnone" title="tine-pronouce" src="http://corneliusweiss.de/wp-content/uploads/2010/04/tine-pronouce.gif" alt="" width="230" height="25" /></a><br />
<a href="http://www.leo.org/dict/audio_en/tine.mp3"></a></p>
<p><script>function bgplay(surl) {
  document.getElementById("bgplay").innerHTML=
    "<embed src='"+surl+"' hidden=true autostart=true loop=false>";
}</script></p>
<p><a href="http://www.leo.org/dict/audio_en/tine.mp3" onclick="bgplay('http://www.leo.org/dict/audio_en/tine.mp3'); return false;">Tine</a> <a href="http://www.leo.org/dict/audio_en/two.mp3" onclick="bgplay('http://www.leo.org/dict/audio_en/two.mp3'); return false;">two</a> <a href="http://www.leo.org/dict/audio_en/dot.mp3" onclick="bgplay('http://www.leo.org/dict/audio_en/dot.mp3'); return false;">dot</a> <a href="http://www.leo.org/dict/audio_en/oh.mp3" onclick="bgplay('http://www.leo.org/dict/audio_en/oh.mp3'); return false;">oh</a></p>
<p>For those of you who are curious what Tine 2.0 stands for, please find <a href="http://corneliusweiss.de/2007/12/12/some-thoughts-on-the-name-tine-20/">my post from 2007/12</a></p>
<p>If you still need some more input for the next nerd party, <a href="http://www.tine20.org/wiki/index.php/Releases">you can find the meaning of our version names here.</a></p>
<p><span id="bgplay" height=0"></span></p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2010/04/24/how-to-pronouce-tine-2-0/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
<enclosure url="http://www.leo.org/dict/audio_en/tine.mp3" length="9113" type="audio/mpeg" />
<enclosure url="http://www.leo.org/dict/audio_en/dot.mp3" length="6605" type="audio/mpeg" />
<enclosure url="http://www.leo.org/dict/audio_en/oh.mp3" length="7650" type="audio/mpeg" />
<enclosure url="http://www.leo.org/dict/audio_en/two.mp3" length="7441" type="audio/mpeg" />
		</item>
		<item>
		<title>Impressions from the CLT 2010</title>
		<link>http://corneliusweiss.de/2010/03/16/impressions-from-the-clt-2010/</link>
		<comments>http://corneliusweiss.de/2010/03/16/impressions-from-the-clt-2010/#comments</comments>
		<pubDate>Mon, 15 Mar 2010 22:27:54 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=243</guid>
		<description><![CDATA[Superb organisation! Congrats to the whole Team of the &#8220;Chemnitzer Linux Tage&#8221;. CLT is definitely on the road of becoming _THE_ german Linux community event. Tine 2.0 will be there again next year!]]></description>
			<content:encoded><![CDATA[<p><object style="height: 344px; width: 425px"><param name="movie" value="http://www.youtube.com/v/EC5jjlG63mw"><param name="allowFullScreen" value="true"><param name="allowScriptAccess" value="always"><embed src="http://www.youtube.com/v/EC5jjlG63mw" type="application/x-shockwave-flash" allowfullscreen="true" allowScriptAccess="always" width="425" height="344"></object></p>
<p>Superb organisation! Congrats to the whole Team of the &#8220;Chemnitzer Linux Tage&#8221;. CLT is definitely on the road of becoming _THE_ german Linux community event. Tine 2.0 will be there again next year!</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2010/03/16/impressions-from-the-clt-2010/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>HTML 5 Multi + Drag and Drop File Uploads with ExtJS</title>
		<link>http://corneliusweiss.de/2010/03/04/html-5-multi-drag-and-drop-file-uploads-with-extjs/</link>
		<comments>http://corneliusweiss.de/2010/03/04/html-5-multi-drag-and-drop-file-uploads-with-extjs/#comments</comments>
		<pubDate>Thu, 04 Mar 2010 19:47:31 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[eGroupWare]]></category>
		<category><![CDATA[extJS]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=238</guid>
		<description><![CDATA[In anticipation of the new Tine 2.0 version Mialena which is scheduled for March 2010 I&#8217;d like to show you a sneak preview about the new file upload features. Tine 2.0 is now able to upload multiple files at once. Additionally Files can be uploaded from directly out of the operating systems file manager or [...]]]></description>
			<content:encoded><![CDATA[<p>In anticipation of the new Tine 2.0 version Mialena which is scheduled for March 2010 I&#8217;d like to show you a sneak preview about the new file upload features.</p>
<p><object width="425" height="344"><param name="movie" value="http://www.youtube.com/v/LZvhZDEABgo&#038;hl=de_DE&#038;fs=1"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/LZvhZDEABgo&#038;hl=de_DE&#038;fs=1" type="application/x-shockwave-flash" width="425" height="344" allowscriptaccess="always" allowfullscreen="true"></embed></object></p>
<p>Tine 2.0 is now able to upload multiple files at once. Additionally Files can be uploaded from directly out of the operating systems file manager or desktop using drag &amp; drop.</p>
<p>Being an open source project, it&#8217;s extremely important for us to chose freely available standard technologies. Therefore it has to to be emphasized, that these new features run in FF, Chrome and Safari without any additional plugins.</p>
<p>The ExtJS wrappers for File Browsing are wrapped into<br />
<a href="http://svn.tine20.org/svn/trunk/tine20/Tinebase/js/ux/file/BrowsePlugin.js">Ext.ux.file.BrowsePlugin</a></p>
<p>HTML 5 File uploading for ExtJS is wrapped into<br />
<a href="http://svn.tine20.org/svn/trunk/tine20/Tinebase/js/ux/file/Uploader.js">Ext.ux.file.Uploader</a></p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2010/03/04/html-5-multi-drag-and-drop-file-uploads-with-extjs/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Ext JS 3.0 Cookbook Review</title>
		<link>http://corneliusweiss.de/2010/01/20/ext-js-3-0-cookbook-review/</link>
		<comments>http://corneliusweiss.de/2010/01/20/ext-js-3-0-cookbook-review/#comments</comments>
		<pubDate>Wed, 20 Jan 2010 09:45:09 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[bookreview]]></category>
		<category><![CDATA[extJS]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=233</guid>
		<description><![CDATA[After seeing quite a few reviews of the &#8216;Ext JS 3.0 Cookbook&#8216; on the Ext JS related blogs, I was curious to hold a copy of the book in my hands. As you can guess from the title, the book contains recipes for solving GUI designs with Ext JS 3.0. In total the book comes [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.packtpub.com/ext-js-3-0-cookbook?utm_source=corneliusweiss.de&amp;utm_medium=link&amp;utm_content=blog&amp;utm_campaign=mdb_001538"><img class="alignleft" src="https://www.packtpub.com/images/100x123/1847198708.png" alt="" width="100" height="123" /></a> After seeing quite a few reviews of the &#8216;<a href="http://www.packtpub.com/ext-js-3-0-cookbook?utm_source=corneliusweiss.de&amp;utm_medium=link&amp;utm_content=blog&amp;utm_campaign=mdb_001538">Ext JS 3.0 Cookbook</a>&#8216; on the Ext JS related blogs, I was curious to hold a copy of the book in my hands.</p>
<p>As you can guess from the title, the book contains recipes for solving GUI designs with Ext JS 3.0. In total the book comes with 109 recipes divided into 10 chapters.</p>
<p>Chapter 1 gives a short introduction of the Ext JS way of DOM manipulation and other basic things. Together with Chapter 10, which is about design patterns in Ext JS this are the Chapters I like most in the book, cause they help to understand the whole Ext JS picture and present content you won&#8217;t find easily in the internet.</p>
<p>The 8 Chapters in between contain receipts as you expect from a cookbook. People familiar with the examples provided in the Ext JS SDK will have sawn about 70% of the receipts presented in the book. In Contrast to the examples in the SDK the printed recipes come with a lot of explanation suitable for beginners with Ext JS and non Javascript geeks. The recipes which are not part of the Ext JS SDK are of high quality and fill the gap where beginners might miss examples.</p>
<p>Chapter 2 tries to give an introduction into the Ext JS layout engine. I use the word &#8220;try&#8221; as I would expect that the receipts are not enough to explain a beginner the insights needed to understand and create complex layouts. Moreover this chapter misses to explain the new vbox and hbox layouts introduced in Ext JS 3.0. In my view, this layouts are the most important additions to the Ext JS layout engine in the new version.</p>
<p>Each recipe contains the additional sections &#8220;How it works&#8221; and &#8220;There is more&#8221;. Both of this sections are helpful for people who don&#8217;t just want to cook, but want to gain more insights of the Ext JS framework.</p>
<p>While a recipes book always has newbies and beginners as target audience, this book is not for beginners only. The explanations often stress points which are of importance for experienced users of the Ext JS framework. Moreover the Author frequently gives hints which are of importance for big web applications.</p>
<p>With the precise explanations and the elegance of his own receipts the author proves himself to have an excellent skill level in providing Ext JS based solutions. The examples provided in this book are not just working somehow, they are assembled within the spirit and design constrains of the Ext JS framework itself.</p>
<p>Additionally, it is notable that the version number in the books title reflects the actual state of the contents. In a number of receipts the solution is done using new features which where introduced in the 3.0 version of Ext JS.</p>
<p>In a big online book store, I would rate this book with 4 of 5 stars.</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2010/01/20/ext-js-3-0-cookbook-review/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Cross Site AJAX Window Name Proxy for extjs/ext-core</title>
		<link>http://corneliusweiss.de/2009/12/09/cross-site-ajax-window-name-proxy-for-extjsext-core/</link>
		<comments>http://corneliusweiss.de/2009/12/09/cross-site-ajax-window-name-proxy-for-extjsext-core/#comments</comments>
		<pubDate>Wed, 09 Dec 2009 08:56:44 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[extJS]]></category>
		<category><![CDATA[Internet security]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[tine 2.0]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=222</guid>
		<description><![CDATA[Cross site communication in the browser using the XHTTPRequest Object is prohibited by the Same Domain Policy. With HTML 5 this restriction is relaxed within the so called workers. As of now, normally the browser can only communicate with the domain the document being displayed comes from. As always, most restrictions can be circumvented somehow. [...]]]></description>
			<content:encoded><![CDATA[<p>Cross site communication in the browser using the <a href="http://en.wikipedia.org/wiki/XMLHttpRequest">XHTTPRequest</a> Object is prohibited by the <a href="http://en.wikipedia.org/wiki/Same_origin_policy">Same Domain Policy</a>. With <a href="http://dev.w3.org/html5/spec/Overview.html">HTML 5</a> this restriction is relaxed within the so called <a href="http://www.whatwg.org/specs/web-workers/current-work/">workers</a>.</p>
<p>As of now, normally the browser can only communicate with the domain the document being displayed comes from. As always, most restrictions can be circumvented somehow. Quite a while now, the de facto standard approach for cross-site communication in the wild is <a href="http://en.wikipedia.org/wiki/JSON#JSONP">JSONP</a>.</p>
<p>In short: A javascript located at the foreign domain is inserted in background. Via the GET url parameters the data of the request is send. The script returned by the foreign server contains code which gets directly executed at include time of this script, e.g: callback({jsondata});</p>
<p>It is widely accepted that JSONP should be rated highly insecure for multiple reasons:<br />
- Including a script of a foreign domain is a build in XSS attack.<br />
- All parameters send to the foreign domain are part of the standard access logs of the foreign web servers.<br />
- &#8230;</p>
<p>A new idea for secure cross site communication <a href="http://www.sitepen.com/blog/2008/07/22/windowname-transport/">has come up</a> a year ago utilizes the fact, that the name property of browser windows/frames remains unchanged when a window/frame loads a new document even from a foreign domain. With this, it is possible to create a transport by inserting a hidden iframe which switches its document between the origin- and foreign domain.</p>
<p>This approach has the major advantage, that the data returned by the foreign domain is encoded as a string and could be evaluated in a safely. Moreover the request could be done via POST&#8217;s which solves EOI issues with server logs.</p>
<p>While I was aware of this new technique, I never had the need to do cross site request from the browser. In general my approach is to proxy data from foreign domains via the server as this gives a better control. However for a <a href="http://www.tine20.org/">Tine 2.0</a> related customer project I had the requirement to do cross site request from a website to a <a href="http://www.tine20.org/">Tine 2.0</a> installation directly from the browser.</p>
<p>Unfortunately I didn&#8217;t find any <a href="http://www.extjs.com/products/extjs/">extjs</a>/<a href="http://www.extjs.com/products/extcore/">ext-core</a> implementation of the window.name technique. Moreover I realized, that the implementation of other libraries always POST their request using form submits. But doing all request via form Submits would require an additional API for <a href="http://www.tine20.org/">Tine 2.0</a> as the standard JSON API talks <a href="http://groups.google.com/group/json-rpc/web/json-rpc-1-2-proposal">JSONRPC</a>.</p>
<p>So what I needed was a XHTTPRequest/AJAX solution to be able to utilize the standard Tine 2.0 API&#8217;s. For this I created a windowNameConnection Proxy which based on ext-core does AJAX requests to the foreign domain. This sequence diagram visualizes it&#8217;s simple workings:<br />
<a href="http://corneliusweiss.de/wp-content/uploads/2009/12/windowNameConnectionDiagramm.png"><img src="http://corneliusweiss.de/wp-content/uploads/2009/12/windowNameConnectionDiagramm-300x156.png" alt="windowNameConnectionDiagramm" title="windowNameConnectionDiagramm" width="300" height="156" class="aligncenter size-medium wp-image-227" /></a></p>
<p>You can find the latest version of the implementation <a href="http://svn.tine20.org/svn/trunk/tine20/Tinebase/js/ux/data/">here</a>. The usage of this connection class is straight forward as it works like a normal extjs connection:</p>
<pre><code>
var connection = new Ext.ux.data.windowNameConnection({
    // this url is autodetected if windowNameConnection is loaded
    // from the foreign domain
    proxyUrl: https://foreign.domain/windowNameConnection.html
});

connection.request({
    url: https://foregin.domain/apiurl,
    header: {...}
    params: {...},
    success: someSuccessCb
});
</code></pre>
<p>Of course the ability to do AJAX requests is purchased by a minor performance loss compared to form posts. BUT: The windowNameProxy should only be seen as a fallback for Browsers which are not capable of the HTML5 workers. Users of these old browsers are obviously not keen on enhanced performance. Otherwise they would use an up to date browser.</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2009/12/09/cross-site-ajax-window-name-proxy-for-extjsext-core/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>Data Transport with JSON-RPC via Ext.Direct and Zend Framework Part 3</title>
		<link>http://corneliusweiss.de/2009/09/18/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-3/</link>
		<comments>http://corneliusweiss.de/2009/09/18/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-3/#comments</comments>
		<pubDate>Fri, 18 Sep 2009 08:30:10 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[eGroupWare]]></category>
		<category><![CDATA[extJS]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[tine 2.0]]></category>
		<category><![CDATA[Zend Framework]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=217</guid>
		<description><![CDATA[Now, with the results from Part 1 and Part 2, let&#8217;s take a deeper look into the Ext.Direct Providers to see how they work and what to do. Prepareing a JSON Service Map Description To use the Ext.direct framework we need to register a provider. For a remoting provider we need a service mapping description. [...]]]></description>
			<content:encoded><![CDATA[<p>Now, with the results from <a href="http://corneliusweiss.de/2009/08/17/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-1/">Part 1</a> and <a href="http://corneliusweiss.de/2009/09/04/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-2/">Part 2</a>, let&#8217;s take a deeper look into the Ext.Direct Providers to see how they work and what to do.</p>
<h3>Prepareing a JSON Service Map Description</h3>
<p>To use the Ext.direct framework we need to register a provider. For a remoting provider we need a <em>service mapping description</em>.</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;">Ext.Direct.addProvider(Ext.apply(Ext.app.JSONRPC_API, {</span></p>
<p><code></p>
<pre>    'type'     : 'zfprovider',
    'url'      : Ext.app.JSONRPC_API.target
}));</pre>
<p></code></p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;">Ext.app.JSONRPC_API <span style="font-family: Georgia, 'Times New Roman', 'Bitstream Charter', Times, serif; line-height: 19px; white-space: normal; font-size: 13px;">holds the service mapping description which in the <a href="http://www.tine20.org/">Tine 2.0</a> case we deliver it with our registry data, but you can also fetch it e.g. by a javascript include as suggested in the “<a href="http://www.extjs.com/products/extjs/direct.php">EXT.DIRECT REMOTING SPECIFICATION</a>”.</span></span></p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;"><span style="font-family: Georgia, 'Times New Roman', 'Bitstream Charter', Times, serif; line-height: 19px; white-space: normal; font-size: 13px;"><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;">&lt;script src=&#8221;index.php?method=Tinebase.getServiceMap&#8221; type=&#8221;text/javascript&#8221;&gt;&lt;/script&gt;</span></span></span></p>
<p>The Service Map could be generated like this:</p>
<p><code></p>
<pre>$server = new Zend_Json_Server();

// set all classes you want to expose
$server-&gt;setClass('MyModule_Service_Json', 'MyModul');

$server-&gt;setTarget('index.php')
    -&gt;setEnvelope(Zend_Json_Server_Smd::ENV_JSONRPC_2);

$smdArray = $server-&gt;getServiceMap()-&gt;toArray();
// save some bytes
unset($smdArray['methods']);

echo "Ext.app.JSONRPC_API = " . Zend_Json::encode($smdArray);</pre>
<p></code></p>
<h3>Ext.ux.direct.ZendFrameworkProvider</h3>
<p>To Enable Ext.Direct to understand the <a href="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">JSON-SMD</a> data and also communicate using the <a href="http://groups.google.com/group/json-rpc/web/json-rpc-1-2-proposal">JSON-RPC</a> protocol we create an own provider:</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;">Ext.ux.direct.ZendFrameworkProvider = Ext.extend(Ext.direct.RemotingProvider, {</span></p>
<p><code></p>
<pre>...</pre>
<p></code></p>
<p>At first we need to parse the JSON-SMD and to create the stubs. This is done by overwriting the initAPI method:</p>
<p><code> </code></p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;"> // private</span></p>
<p><code></p>
<pre>    initAPI : function() {
        for (var method in this.services){
            var mparts = method.split('.');
            var cls = this.namespace[mparts[0]] || (this.namespace[mparts[0]] = {});
            cls[mparts[1]] = this.createMethod(mparts[0], Ext.apply(this.services[method], {
                name: mparts[1],
                len: this.services[method].parameters.length
            }));
        }
    },</pre>
<p></code><br />
All we do is to transform the JSON-SMD definition data in to a from the original createMethod method can understand to create the stubs.</p>
<p>It&#8217;s important to understand, that the createMethod creates stubs which do only trigger further processing of the provider and do _NOT_ contain all the code to do requests and protocol processing.</p>
<p>Once a stub is called, it applies the doCall function of our provider. In order to support named parameters we inspect the call and transform a named parameter call into a positional parameter call. This is needed, cause the ZendFrameworks Zend_Json_Server is itself not able to understand named parameter calls witch by the way are indeed part of the JSON-RPC specification.</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;"> // private</span></p>
<p><code></p>
<pre>    doCall : function(c, m, args) {
        // support named parameters
        if (args[args.length-1].paramsAsHash) {
            var o = args.shift();
            for (var i = 0; i &lt; m.parameters.length; i++) {
                args.splice(i,0, o[m.parameters[i].name]);
            }
        }

        return Ext.ux.direct.ZendFrameworkProvider.superclass.doCall.call(this, c, m, args);
    },</pre>
<p></code></p>
<p>After the parameters a prepared, the provider assembles the request according to the protocol definitions. This is done in the getCallData method.</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;"> // private</span></p>
<p><code></p>
<pre>    getCallData: function(t){
        return {
            jsonrpc: '2.0',
            method: t.action + '.' + t.method,
            params: t.data,
            id: t.tid
        };
    },</pre>
<p></code><br />
This protocol encapsulation only deals with single transaction calls. The processing for batched calls is done elsewhere. Luckily The both protocols use the same simple outer array for batched calls, so that we don&#8217;t need to touch it.</p>
<p>Finally the response needs to be decoded according to the protocol and the callback function needs to get called using the decoded data. This is done in the onData method:</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;"> // private</span></p>
<p><code></p>
<pre>    onData: function(opt, success, xhr) {
        var rpcresponse = Ext.decode(xhr.responseText);
        xhr.responseText = {
            type: rpcresponse.result ? 'rpc' : 'exception',
            result: rpcresponse.result,
            tid: rpcresponse.id
        };

        return Ext.ux.direct.ZendFrameworkProvider.superclass.onData.apply(this, arguments);
    }</pre>
<p></code></p>
<p>And voila, thats it. This is our custom provider to enable Ext.Direct to use and talk pure standard JSON-PRC/JSON-SMD.</p>
<p>Finally let&#8217;s register the provider for lazy invocation</p>
<p><span style="font-family: Consolas, Monaco, 'Courier New', Courier, monospace; line-height: 18px; font-size: 12px; white-space: pre;">Ext.Direct.PROVIDERS['zfprovider'] = Ext.ux.direct.ZendFrameworkProvider;</span></p>
<h3>Server Side Batched Requests</h3>
<p>As noted in Part 2, the biggest problem with the Zend_Json_Server is the fact that it&#8217;s not capable to handle batched requests yet. To overcome this in a simple way, you can monitor the first character of an JSON request in your dispatcher and dispatch multiple request if it&#8217;s a &#8216;[&#8216;. Of course this is far away from optimum, but it&#8217;s a start point till we have the feature in the Zend_Json_Server.</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2009/09/18/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-3/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Data Transport with JSON-RPC via Ext.Direct and Zend Framework Part 2</title>
		<link>http://corneliusweiss.de/2009/09/04/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-2/</link>
		<comments>http://corneliusweiss.de/2009/09/04/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-2/#comments</comments>
		<pubDate>Fri, 04 Sep 2009 17:36:27 +0000</pubDate>
		<dc:creator>Cornelius Weiss</dc:creator>
				<category><![CDATA[eGroupWare]]></category>
		<category><![CDATA[extJS]]></category>
		<category><![CDATA[Javascript]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[tine 2.0]]></category>
		<category><![CDATA[Zend Framework]]></category>

		<guid isPermaLink="false">http://corneliusweiss.de/?p=210</guid>
		<description><![CDATA[As promised in my previous post, I&#8217;ll introduce Ext.Direct and discuss how it fits with the new JSON-RPC standards and especially with the Zend_Json_Server component. Ext.direct is a namespace and a bit of a buzzword in the ExtJS 3.0 release. In short, the Ext.direct stuff introduces high level communication features. The key component of these [...]]]></description>
			<content:encoded><![CDATA[<p>As promised in <a href="http://corneliusweiss.de/2009/08/17/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-1/">my previous post</a>, I&#8217;ll introduce <a href="http://www.extjs.com/deploy/dev/docs/output/Ext.Direct.html">Ext.Direct</a> and discuss how it fits with the new JSON-RPC standards and especially with the <a href="http://framework.zend.com/manual/en/zend.json.server.html">Zend_Json_Server</a> component.</p>
<p>Ext.direct is a namespace and a bit of a buzzword in the ExtJS 3.0 release. In short, the Ext.direct stuff introduces high level communication features.</p>
<p>The key component of these new features is the &#8220;<a href="http://www.extjs.com/products/extjs/direct.php">EXT.DIRECT REMOTING SPECIFICATION</a>&#8221; which covers the aspects &#8216;<a href="http://en.wikipedia.org/wiki/Remote_Procedure_Call">remote procedure call</a>&#8216; and &#8216;service description&#8217;. <code>Ext.Direct</code> implements this specifications within the ExtJS framework as service consumer and for multiple server side stacks as service provider.</p>
<p>Besides having a well defined and documented communication and transport layer Ext.direct also has the advantage, that other ExtJs classes dealing with data can work on the stubs, created based on the &#8216;service map descriptions&#8217;. The <code>Ext.tree.TreeLoader</code> can be configured with a directFn to fetch it&#8217;s data. More over the <code>Ext.data.DirectStore</code> can be configured with a complete set of direct functions for CRUD actions.</p>
<p>An other cool thing about the javascript implementation of the <code>Ext.direct.RemotingProvider</code> is, that is queues request of the direct stubs for a configurable time span. After this span, it sends one batched request to the server.</p>
<p>However, its important to note, that the &#8220;EXT.DIRECT REMOTING SPECIFICATION&#8221; is different form the <a href="http://groups.google.com/group/json-rpc/web/json-rpc-1-2-proposal">JSON-RPC</a>/<a href="http://groups.google.com/group/json-schema/web/service-mapping-description-proposal">JSON-SMD</a> specifications introduced in part 1.</p>
<p>While digging in the specs I found some pros and cons for the &#8220;EXT.DIRECT REMOTING SPECIFICATION&#8221; compared to the JSON-RPC standardization:</p>
<ul>
<li>+ It covers form posts which are needed for special actions like file upload</li>
<li>+ It covers events send by the server</li>
<li>- It lacks of function parameter description</li>
<li>- It does not support named function parameters</li>
<li>- It does not support optional parameters</li>
<li>- It is not compatible to the JSON-RPC standardization efforts</li>
</ul>
<p>The last point is IMHO the strongest point why not to use this specification. While the rest of the javascript/webservice addicted world tries to find a common standard, ExtJs goes its own way. There are already a number of implementations for the JSON-RPC and JSON-SMD out there, and more and more will follow. I also expect to see service consumers written in PHP which ease writing server-server web-services using the same API.</p>
<p>For that reasons I choose to take the standard Zend_Json_Server implementation and to write a <code>Ext.ux.direct.ZendFrameworkProvider</code> we can use in <a href="http://www.tine20.org">Tine 2.0</a> and other Zend Framework based projects.</p>
<p>It&#8217;s only fair to note, the the Zend_Json_Server also has several issues which needs to be improved. Most notably:</p>
<ul>
<li>- It does not support batched requests</li>
<li>- It does not support named parameters</li>
</ul>
<p>After all this theory I&#8217;ll cover the actual implementation of the Ext.ux.direct.ZendFrameworkProvider in part 3.</p>
]]></content:encoded>
			<wfw:commentRss>http://corneliusweiss.de/2009/09/04/data-transport-with-json-rpc-via-ext-direct-and-zend-framework-part-2/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

