[kune-commits] r1140 - in trunk: . img img/icons script
src/main/java/org/ourproject/kune/app/server
src/main/java/org/ourproject/kune/app/server/wave
src/main/java/org/ourproject/kune/platf/server
src/main/java/org/ourproject/kune/platf/server/properties
src/main/resources
vjrj
vjrj at ourproject.org
Mon Aug 31 12:49:16 CEST 2009
Author: vjrj
Date: 2009-08-31 12:49:15 +0200 (Mon, 31 Aug 2009)
New Revision: 1140
Added:
trunk/img/icons/lock.png
trunk/img/icons/lock_break.png
trunk/script/repopubli.sh
trunk/src/main/java/org/ourproject/kune/app/server/wave/
trunk/src/main/java/org/ourproject/kune/app/server/wave/WaveContainerListener.java
trunk/src/main/java/org/ourproject/kune/app/server/wave/WavePropertiesParser.java
Modified:
trunk/img/icons-base.svg
trunk/pom.xml
trunk/src/main/java/org/ourproject/kune/app/server/KuneRackModule.java
trunk/src/main/java/org/ourproject/kune/platf/server/PlatformServerModule.java
trunk/src/main/java/org/ourproject/kune/platf/server/properties/ChatProperties.java
trunk/src/main/resources/kune.properties
Log:
Wave server first integration (thanks to guice)
Added: trunk/img/icons/lock.png
===================================================================
(Binary files differ)
Property changes on: trunk/img/icons/lock.png
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Added: trunk/img/icons/lock_break.png
===================================================================
(Binary files differ)
Property changes on: trunk/img/icons/lock_break.png
___________________________________________________________________
Name: svn:mime-type
+ application/octet-stream
Modified: trunk/img/icons-base.svg
===================================================================
--- trunk/img/icons-base.svg 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/img/icons-base.svg 2009-08-31 10:49:15 UTC (rev 1140)
@@ -27,15 +27,15 @@
borderopacity="1.0"
inkscape:pageopacity="0.0"
inkscape:pageshadow="2"
- inkscape:zoom="1.3545976"
- inkscape:cx="372.04724"
- inkscape:cy="526.18109"
+ inkscape:zoom="0.8805759"
+ inkscape:cx="368.89944"
+ inkscape:cy="693.88452"
inkscape:document-units="px"
inkscape:current-layer="layer1"
inkscape:window-width="1280"
- inkscape:window-height="730"
- inkscape:window-x="0"
- inkscape:window-y="24"
+ inkscape:window-height="1001"
+ inkscape:window-x="1280"
+ inkscape:window-y="0"
showgrid="false"
showguides="true"
inkscape:guide-bbox="true"
@@ -52,10 +52,24 @@
originy="0px"
originx="0px"
type="xygrid"
- id="GridFromPre046Settings" />
+ id="GridFromPre046Settings"
+ visible="true"
+ enabled="true" />
</sodipodi:namedview>
<defs
id="defs21021">
+ <linearGradient
+ inkscape:collect="always"
+ id="linearGradient3002">
+ <stop
+ style="stop-color:#de1515;stop-opacity:1;"
+ offset="0"
+ id="stop3004" />
+ <stop
+ style="stop-color:#de1515;stop-opacity:0;"
+ offset="1"
+ id="stop3006" />
+ </linearGradient>
<inkscape:perspective
id="perspective511"
inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
@@ -1819,6 +1833,50 @@
id="linearGradient5122"
xlink:href="#linearGradient2467"
inkscape:collect="always" />
+ <inkscape:perspective
+ id="perspective2970"
+ inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
+ inkscape:vp_z="744.09448 : 526.18109 : 1"
+ inkscape:vp_y="0 : 1000 : 0"
+ inkscape:vp_x="0 : 526.18109 : 1"
+ sodipodi:type="inkscape:persp3d" />
+ <linearGradient
+ inkscape:collect="always"
+ xlink:href="#linearGradient3002"
+ id="linearGradient3816"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="translate(0.2007512,0.9033805)"
+ x1="370.68713"
+ y1="453.87259"
+ x2="342.63214"
+ y2="446.19382" />
+ <linearGradient
+ inkscape:collect="always"
+ xlink:href="#linearGradient3002"
+ id="linearGradient3835"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(1.2919055,0,0,1.2919055,-88.927986,-125.13708)"
+ x1="370.68713"
+ y1="453.87259"
+ x2="342.63214"
+ y2="446.19382" />
+ <inkscape:perspective
+ id="perspective3956"
+ inkscape:persp3d-origin="372.04724 : 350.78739 : 1"
+ inkscape:vp_z="744.09448 : 526.18109 : 1"
+ inkscape:vp_y="0 : 1000 : 0"
+ inkscape:vp_x="0 : 526.18109 : 1"
+ sodipodi:type="inkscape:persp3d" />
+ <linearGradient
+ inkscape:collect="always"
+ xlink:href="#linearGradient3002"
+ id="linearGradient3972"
+ gradientUnits="userSpaceOnUse"
+ gradientTransform="matrix(1.2919055,0,0,1.2919055,-88.927986,-125.13708)"
+ x1="370.68713"
+ y1="453.87259"
+ x2="342.63214"
+ y2="446.19382" />
</defs>
<metadata
id="metadata21024">
@@ -3027,8 +3085,8 @@
inkscape:export-ydpi="90"
inkscape:export-xdpi="90"
inkscape:export-filename="/home/vjrj/proyectos/ourproject.org/kune/svn/trunk/img/icons/nobody.png"
- y="244.08676"
- x="525.88586"
+ y="288.13663"
+ x="508.64896"
id="image18392"
height="16"
width="16"
@@ -3041,8 +3099,8 @@
width="10.062655"
height="10.062655"
id="image18398"
- x="533.07184"
- y="243.15987" />
+ x="515.8349"
+ y="287.20975" />
<rect
style="color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.96201754;stroke-linecap:butt;stroke-linejoin:miter;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
id="rect12715"
@@ -4587,5 +4645,150 @@
x="0"
inkscape:transform-center-x="-156.01159"
inkscape:transform-center-y="41.742437" />
+ <image
+ y="450.82797"
+ x="330.84604"
+ id="image2972"
+ height="16"
+ width="16"
+ sodipodi:absref="/home/vjrj/proyectos/dev/kune/trunk/img/icons/lock_break.png"
+ xlink:href="icons/lock_break.png" />
+ <use
+ x="0"
+ y="0"
+ xlink:href="#image2972"
+ id="use2978"
+ transform="translate(25.153961,0.5342102)"
+ width="744.09448"
+ height="1052.3622" />
+ <g
+ id="g3810"
+ transform="translate(-0.5018781,0.6022537)">
+ <image
+ style="fill:#ff0000"
+ y="449.86804"
+ x="363.8681"
+ id="image2982"
+ height="10.062655"
+ width="10.062655"
+ xlink:href=" WXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH1QsKCTQviWADaAAAAypJREFUOMvVlD9oG2cYxn+nu9M/ JyS2hIWlEpk0aWjBiEyph5ZCh9B6z2TSqUuGjoFACoUEMmRPSro6a4dCvCRbhkIhISROLIiKnYJk BVu2zq6kk3T3vh30nXJxVeqO/eDj+3f3vM/3vM/7wf+tWf90sAJZ4AqwBCwA08Ae8AJ4ANxZhu5/ Al6Bb4FbZyqVXPHcOY7l8ziuw7DXw2u+ZatWY+PVqxZwbRl+OhLwCtyYKRSun794kaznEb55g/a6 qCiqirguiVKJ7tQUzx8/xtvdvbkM3x/GsQ8znSkUbi9euoTz7BlSb6DDAaqKiiIqaBAguy1sz6O4 uMhuvf75ku83foanExkbTf/48vLlXHp9HTk4QEUgAlQzioIqqoKmM/TL8/z66GELOBXXPBELcuVM pZLLem10fx8VQVUQFUQVMUEwcxFFOh3SBx4fzM/nTKKZBLw0d/Yjwo1NJGIUjnRVNYAqiIxYj7ow qDeYLc5h3DNuTmy+cCyfQ577qAj516//1aubhQLa75OdOo6x5ETG047jjK95lBbdxrYTGJ9PBN4b +r6xlRwJWGSk98D3McUzUYoX+83mF9mkg/g+W+UyYoKoKMo7bcc5UEVtmz/bbUxF/p2xwGqjVsMq lkY/i4KKATAuUBMg2hfBzufZbm4hsBq3bwRsNeDuZrXa6mYykMmgGo701ncMERnnQEXRVIpuOk2z +bZVgx8NsBVVngUkHoF+DV53Z2dp7sIFZLtlqk7GlReVtapipZIkTn9I9eUarWFw7So8AdR0bMPa BpK/wPpnvp/qNBqfTn/yMW46TdjposHQ6K2oY+PMzuLPzFBdW2Oz17v7HdwzgBKBR4xtIAlkHsBa ud/v9jY2FsRxUslSkVS5jFssIfkcPcelvrNDtVY7+C0I7v0A94EAGJoxiN6KiHGa0XtRAE6dhNlv 4Kt5qJyAogvZAfTa0PwdXt6HVQ/qwDbQAtpABxgAoRUDdw34CaAInDTrpDlzzXcho8fGM97dA/bN 3sAwFiuWyYTpKWAKyBifO2Y/slJoAIZAH/BjMoSRztah5zMewI6t36vkQz2IJS465y8YtvDGyaeW /wAAAABJRU5ErkJggg== "
+ inkscape:export-filename="/home/vjrj/proyectos/ourproject.org/kune/svn/trunk/img/icons/nobody.png"
+ inkscape:export-xdpi="90"
+ inkscape:export-ydpi="90" />
+ <rect
+ y="453.97293"
+ x="366.52155"
+ height="1.4052587"
+ width="4.2659636"
+ id="rect2984"
+ style="fill:url(#linearGradient3816);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
+ <rect
+ y="451.71448"
+ x="367.57547"
+ height="3.3123956"
+ width="2.0576999"
+ id="rect3010"
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
+ <rect
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
+ id="rect3782"
+ width="2.0577002"
+ height="1.7063855"
+ x="367.62567"
+ y="455.91528" />
+ </g>
+ <use
+ height="1052.3622"
+ width="744.09448"
+ transform="translate(45.153961,0.5342102)"
+ id="use3818"
+ xlink:href="#image2972"
+ y="0"
+ x="0" />
+ <g
+ id="g3838">
+ <image
+ inkscape:export-ydpi="90"
+ inkscape:export-xdpi="90"
+ inkscape:export-filename="/home/vjrj/proyectos/ourproject.org/kune/svn/trunk/img/icons/nobody.png"
+ xlink:href=" WXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH1QsKCTQviWADaAAAAypJREFUOMvVlD9oG2cYxn+nu9M/ JyS2hIWlEpk0aWjBiEyph5ZCh9B6z2TSqUuGjoFACoUEMmRPSro6a4dCvCRbhkIhISROLIiKnYJk BVu2zq6kk3T3vh30nXJxVeqO/eDj+3f3vM/3vM/7wf+tWf90sAJZ4AqwBCwA08Ae8AJ4ANxZhu5/ Al6Bb4FbZyqVXPHcOY7l8ziuw7DXw2u+ZatWY+PVqxZwbRl+OhLwCtyYKRSun794kaznEb55g/a6 qCiqirguiVKJ7tQUzx8/xtvdvbkM3x/GsQ8znSkUbi9euoTz7BlSb6DDAaqKiiIqaBAguy1sz6O4 uMhuvf75ku83foanExkbTf/48vLlXHp9HTk4QEUgAlQzioIqqoKmM/TL8/z66GELOBXXPBELcuVM pZLLem10fx8VQVUQFUQVMUEwcxFFOh3SBx4fzM/nTKKZBLw0d/Yjwo1NJGIUjnRVNYAqiIxYj7ow qDeYLc5h3DNuTmy+cCyfQ577qAj516//1aubhQLa75OdOo6x5ETG047jjK95lBbdxrYTGJ9PBN4b +r6xlRwJWGSk98D3McUzUYoX+83mF9mkg/g+W+UyYoKoKMo7bcc5UEVtmz/bbUxF/p2xwGqjVsMq lkY/i4KKATAuUBMg2hfBzufZbm4hsBq3bwRsNeDuZrXa6mYykMmgGo701ncMERnnQEXRVIpuOk2z +bZVgx8NsBVVngUkHoF+DV53Z2dp7sIFZLtlqk7GlReVtapipZIkTn9I9eUarWFw7So8AdR0bMPa BpK/wPpnvp/qNBqfTn/yMW46TdjposHQ6K2oY+PMzuLPzFBdW2Oz17v7HdwzgBKBR4xtIAlkHsBa ud/v9jY2FsRxUslSkVS5jFssIfkcPcelvrNDtVY7+C0I7v0A94EAGJoxiN6KiHGa0XtRAE6dhNlv 4Kt5qJyAogvZAfTa0PwdXt6HVQ/qwDbQAtpABxgAoRUDdw34CaAInDTrpDlzzXcho8fGM97dA/bN 3sAwFiuWyYTpKWAKyBifO2Y/slJoAIZAH/BjMoSRztah5zMewI6t36vkQz2IJS465y8YtvDGyaeW /wAAAABJRU5ErkJggg== "
+ width="13"
+ height="13"
+ id="image3822"
+ x="380.89587"
+ y="454.88284"
+ style="fill:#ff0000" />
+ <rect
+ style="fill:url(#linearGradient3835);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
+ id="rect3824"
+ width="5.5112219"
+ height="1.8154614"
+ x="384.32385"
+ y="460.18597" />
+ <rect
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
+ id="rect3826"
+ width="1.7549734"
+ height="3.7774239"
+ x="386.23749"
+ y="457.77011" />
+ <rect
+ y="462.69531"
+ x="386.15176"
+ height="2.2044888"
+ width="1.9055371"
+ id="rect3828"
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
+ </g>
+ <image
+ y="432.36218"
+ x="-371"
+ id="image3958"
+ height="16"
+ width="16"
+ sodipodi:absref="/home/vjrj/proyectos/dev/kune/trunk/img/icons/lock_break.png"
+ xlink:href="icons/lock_break.png"
+ transform="scale(-1,1)" />
+ <g
+ id="g3962"
+ transform="translate(-43.509019,-21.462476)">
+ <image
+ inkscape:export-ydpi="90"
+ inkscape:export-xdpi="90"
+ inkscape:export-filename="/home/vjrj/proyectos/ourproject.org/kune/svn/trunk/img/icons/nobody.png"
+ xlink:href=" WXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH1QsKCTQviWADaAAAAypJREFUOMvVlD9oG2cYxn+nu9M/ JyS2hIWlEpk0aWjBiEyph5ZCh9B6z2TSqUuGjoFACoUEMmRPSro6a4dCvCRbhkIhISROLIiKnYJk BVu2zq6kk3T3vh30nXJxVeqO/eDj+3f3vM/3vM/7wf+tWf90sAJZ4AqwBCwA08Ae8AJ4ANxZhu5/ Al6Bb4FbZyqVXPHcOY7l8ziuw7DXw2u+ZatWY+PVqxZwbRl+OhLwCtyYKRSun794kaznEb55g/a6 qCiqirguiVKJ7tQUzx8/xtvdvbkM3x/GsQ8znSkUbi9euoTz7BlSb6DDAaqKiiIqaBAguy1sz6O4 uMhuvf75ku83foanExkbTf/48vLlXHp9HTk4QEUgAlQzioIqqoKmM/TL8/z66GELOBXXPBELcuVM pZLLem10fx8VQVUQFUQVMUEwcxFFOh3SBx4fzM/nTKKZBLw0d/Yjwo1NJGIUjnRVNYAqiIxYj7ow qDeYLc5h3DNuTmy+cCyfQ577qAj516//1aubhQLa75OdOo6x5ETG047jjK95lBbdxrYTGJ9PBN4b +r6xlRwJWGSk98D3McUzUYoX+83mF9mkg/g+W+UyYoKoKMo7bcc5UEVtmz/bbUxF/p2xwGqjVsMq lkY/i4KKATAuUBMg2hfBzufZbm4hsBq3bwRsNeDuZrXa6mYykMmgGo701ncMERnnQEXRVIpuOk2z +bZVgx8NsBVVngUkHoF+DV53Z2dp7sIFZLtlqk7GlReVtapipZIkTn9I9eUarWFw7So8AdR0bMPa BpK/wPpnvp/qNBqfTn/yMW46TdjposHQ6K2oY+PMzuLPzFBdW2Oz17v7HdwzgBKBR4xtIAlkHsBa ud/v9jY2FsRxUslSkVS5jFssIfkcPcelvrNDtVY7+C0I7v0A94EAGJoxiN6KiHGa0XtRAE6dhNlv 4Kt5qJyAogvZAfTa0PwdXt6HVQ/qwDbQAtpABxgAoRUDdw34CaAInDTrpDlzzXcho8fGM97dA/bN 3sAwFiuWyYTpKWAKyBifO2Y/slJoAIZAH/BjMoSRztah5zMewI6t36vkQz2IJS465y8YtvDGyaeW /wAAAABJRU5ErkJggg== "
+ width="13"
+ height="13"
+ id="image3964"
+ x="380.89587"
+ y="454.88284"
+ style="fill:#ff0000" />
+ <rect
+ style="fill:url(#linearGradient3972);fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
+ id="rect3966"
+ width="5.5112219"
+ height="1.8154614"
+ x="384.32385"
+ y="460.18597" />
+ <rect
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate"
+ id="rect3968"
+ width="1.7549734"
+ height="3.7774239"
+ x="386.23749"
+ y="457.77011" />
+ <rect
+ y="462.69531"
+ x="386.15176"
+ height="2.2044888"
+ width="1.9055371"
+ id="rect3970"
+ style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:3;marker:none;marker-start:none;marker-mid:none;marker-end:none;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.04705882;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />
+ </g>
+ <path
+ style="fill:#4d4d4d;fill-rule:evenodd;stroke:#cccccc;stroke-width:1.50000000000000000;stroke-linecap:round;stroke-linejoin:miter;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none"
+ d="M 356.90981,433.2195 C 362.64423,438.27174 365.62799,440.99217 365.62799,440.99217 L 361.71179,441.04075 L 370.01039,448.32762"
+ id="path3976"
+ sodipodi:nodetypes="cccc" />
</g>
</svg>
Modified: trunk/pom.xml
===================================================================
--- trunk/pom.xml 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/pom.xml 2009-08-31 10:49:15 UTC (rev 1140)
@@ -340,7 +340,96 @@
<artifactId>jruby-rack</artifactId>
<version>0.9.4</version>
</dependency>
+
+ <!-- wave -->
+ <dependency>
+ <groupId>org.waveprotocol</groupId>
+ <artifactId>kune-wave-server</artifactId>
+ <version>0.0.2</version>
+ </dependency>
+ <dependency>
+ <groupId>commons-cli</groupId>
+ <artifactId>commons-cli</artifactId>
+ <version>1.2</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>commons-codec</groupId>
+ <artifactId>commons-codec</artifactId>
+ <version>1.3</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>dom4j</groupId>
+ <artifactId>dom4j</artifactId>
+ <version>1.6.1</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>com.google.code.guice</groupId>
+ <artifactId>guice-assistedinject</artifactId>
+ <version>2.0</version>
+ </dependency>
+ <dependency>
+ <groupId>jline</groupId>
+ <artifactId>jline</artifactId>
+ <version>0.9.94</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>org.gnu.inet</groupId>
+ <artifactId>libidn</artifactId>
+ <version>1.15</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>com.google.protobuf</groupId>
+ <artifactId>protobuf-java</artifactId>
+ <version>2.1.0</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>xpp3</groupId>
+ <artifactId>xpp3</artifactId>
+ <version>1.1.4c</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>xpp3</groupId>
+ <artifactId>xpp3_xpath</artifactId>
+ <version>1.1.4c</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>aopalliance</groupId>
+ <artifactId>aopalliance</artifactId>
+ <version>1.0</version>
+ <type>jar</type>
+ </dependency>
+ <dependency>
+ <groupId>org.wave-protocol</groupId>
+ <artifactId>xmpp</artifactId>
+ <version>1.0.0</version>
+ </dependency>
+ <dependency>
+ <groupId>org.wave-protocol</groupId>
+ <artifactId>whack</artifactId>
+ <version>1.0.0</version>
+ </dependency>
+ <dependency>
+ <groupId>com.google.common</groupId>
+ <artifactId>collect</artifactId>
+ <version>1.0-rc2</version>
+ </dependency>
</dependencies>
+
+ <distributionManagement>
+ <repository>
+ <id>kune.ourproject.org</id>
+ <url>scpexe://kune.ourproject.org/home/groups/kune/htdocs/mavenrepo/</url>
+ </repository>
+ </distributionManagement>
+
<!--
http://gwt-maven.googlecode.com/svn/docs/maven-googlewebtoolkit2-plugin/index.html
-->
@@ -540,12 +629,12 @@
</plugin>
<plugin>
<groupId>org.mortbay.jetty</groupId>
- <artifactId>maven-jetty-plugin</artifactId>
- <version>6.1.5</version>
<!--
<artifactId>jetty-maven-plugin</artifactId>
<version>7.0.0.1beta0</version>
-->
+ <artifactId>maven-jetty-plugin</artifactId>
+ <version>6.1.5</version>
<configuration>
<contextPath>/</contextPath>
<webAppSourceDirectory>war</webAppSourceDirectory>
@@ -735,6 +824,13 @@
<directory>src/main/java</directory>
</resource>
</resources>
+ <extensions>
+ <extension>
+ <groupId>org.apache.maven.wagon</groupId>
+ <artifactId>wagon-ssh-external</artifactId>
+ <version>1.0-beta-2</version>
+ </extension>
+ </extensions>
</build>
<reporting>
<plugins>
@@ -840,4 +936,4 @@
</reporting>
</profile>
</profiles>
-</project>
\ No newline at end of file
+</project>
Added: trunk/script/repopubli.sh
===================================================================
--- trunk/script/repopubli.sh 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/script/repopubli.sh 2009-08-31 10:49:15 UTC (rev 1140)
@@ -0,0 +1,24 @@
+#!/bin/bash
+
+PARAMS=$#
+JAR=$1
+GROUP=$2
+ARTIFACT=$3
+VER=$4
+USER=$5
+
+# CORRECT PARAMS ###############################################################
+
+if [ $PARAMS -lt 4 ]
+then
+ echo "Use: $0 <jar> <group> <artifact> <version> <username>"
+ echo "$0 target/emite-0.4.6-emiteuimodule.jar com.calclab.emite emite 0.4.6 [luther]"
+ exit
+fi
+
+if [ $PARAMS -gt 4 ]
+then
+ EXTRA=$USER@
+fi
+
+mvn deploy:deploy-file -DgroupId=$2 -DartifactId=$3 -Dversion=$4 -Dpackaging=jar -Dfile=$1 -Durl=scpexe://kune.ourproject.org/home/groups/kune/htdocs/mavenrepo/ -DrepositoryId=kune.ourproject.org
Property changes on: trunk/script/repopubli.sh
___________________________________________________________________
Name: svn:executable
+ *
Modified: trunk/src/main/java/org/ourproject/kune/app/server/KuneRackModule.java
===================================================================
--- trunk/src/main/java/org/ourproject/kune/app/server/KuneRackModule.java 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/java/org/ourproject/kune/app/server/KuneRackModule.java 2009-08-31 10:49:15 UTC (rev 1140)
@@ -19,6 +19,8 @@
*/
package org.ourproject.kune.app.server;
+import org.ourproject.kune.app.server.wave.WaveContainerListener;
+import org.ourproject.kune.app.server.wave.WavePropertiesParser;
import org.ourproject.kune.blogs.server.BlogServerModule;
import org.ourproject.kune.chat.server.ChatServerModule;
import org.ourproject.kune.docs.server.DocumentServerModule;
@@ -49,6 +51,8 @@
import org.ourproject.kune.rack.filters.RedirectFilter;
import org.ourproject.kune.rack.filters.rest.RESTServicesModule;
import org.ourproject.kune.wiki.server.WikiServerModule;
+import org.waveprotocol.wave.examples.fedone.FlagSettings;
+import org.waveprotocol.wave.examples.fedone.ServerModule;
import com.google.inject.AbstractModule;
import com.google.inject.Module;
@@ -86,6 +90,7 @@
installGuiceModules(builder);
builder.add(KuneContainerListener.class);
+ builder.add(WaveContainerListener.class);
builder.exclude("/http-bind.*");
builder.exclude("/public/.*");
@@ -122,6 +127,8 @@
builder.use(new GalleryServerModule());
builder.use(new RESTServicesModule());
builder.use(configModule);
+ builder.use(WavePropertiesParser.parseFlags(FlagSettings.class));
+ builder.use(new ServerModule());
}
}
Added: trunk/src/main/java/org/ourproject/kune/app/server/wave/WaveContainerListener.java
===================================================================
--- trunk/src/main/java/org/ourproject/kune/app/server/wave/WaveContainerListener.java 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/java/org/ourproject/kune/app/server/wave/WaveContainerListener.java 2009-08-31 10:49:15 UTC (rev 1140)
@@ -0,0 +1,70 @@
+package org.ourproject.kune.app.server.wave;
+
+import java.net.InetSocketAddress;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import org.ourproject.kune.rack.ContainerListener;
+import org.waveprotocol.wave.examples.fedone.federation.xmpp.WaveXmppComponent;
+import org.waveprotocol.wave.examples.fedone.rpc.ServerRpcProvider;
+import org.waveprotocol.wave.examples.fedone.waveserver.WaveClientRpc.ProtocolWaveClientRpc;
+import org.xmpp.component.ComponentException;
+
+import com.google.inject.Inject;
+import com.google.inject.name.Named;
+
+public class WaveContainerListener implements ContainerListener {
+
+ /** Creates InetSocketAddresses from injected parameters */
+ public static class RpcInetSocketAddressFactory {
+
+ private final String host;
+ private final Integer port;
+
+ @Inject
+ RpcInetSocketAddressFactory(@Named("client_frontend_hostname") final String host,
+ @Named("client_frontend_port") final Integer port) {
+ this.host = host;
+ this.port = port;
+ // LOG.info("Starting client frontend on host: " + host + " port: "
+ // + port);
+ }
+
+ InetSocketAddress create() {
+ return new InetSocketAddress(host, port);
+ }
+
+ }
+ private final WaveXmppComponent wxComponent;
+ private final ProtocolWaveClientRpc.Interface rpcImpl;
+ private final RpcInetSocketAddressFactory rpcInet;
+ private final Logger log; // NOPMD by vjrj on 30/08/09 20:14
+
+ @Inject
+ public WaveContainerListener(final WaveXmppComponent wxComponent, final ProtocolWaveClientRpc.Interface rpcImpl,
+ final RpcInetSocketAddressFactory rpcInet, final Logger logger) {
+ this.rpcInet = rpcInet;
+ this.wxComponent = wxComponent;
+ this.rpcImpl = rpcImpl;
+ this.log = logger;
+ }
+
+ public void start() {
+ final ServerRpcProvider server = new ServerRpcProvider(rpcInet.create());
+ server.registerService(ProtocolWaveClientRpc.newReflectiveService(rpcImpl));
+ try {
+ wxComponent.run();
+ } catch (final ComponentException e) {
+ log.log(Level.SEVERE, "couldn't connect to XMPP server:" + e);
+ }
+ log.log(Level.INFO, "Starting wave server");
+ try {
+ server.startServer();
+ } catch (final Exception e) {
+ throw new RuntimeException(e); // NOPMD by vjrj on 30/08/09 18:08
+ }
+ }
+
+ public void stop() {
+ }
+}
Added: trunk/src/main/java/org/ourproject/kune/app/server/wave/WavePropertiesParser.java
===================================================================
--- trunk/src/main/java/org/ourproject/kune/app/server/wave/WavePropertiesParser.java 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/java/org/ourproject/kune/app/server/wave/WavePropertiesParser.java 2009-08-31 10:49:15 UTC (rev 1140)
@@ -0,0 +1,136 @@
+package org.ourproject.kune.app.server.wave;
+
+import java.io.InputStream;
+import java.lang.reflect.Field;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.HashSet;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+
+import org.waveprotocol.wave.examples.fedone.Flag;
+
+import com.google.inject.AbstractModule;
+import com.google.inject.Module;
+import com.google.inject.name.Names;
+
+public class WavePropertiesParser {
+ private static final String PREFIX = "kune.wave.";
+ private static final Set<Class<?>> supportedFlagTypes; // NOPMD by vjrj on
+ // 30/08/09 12:37
+
+ static {
+ supportedFlagTypes = new HashSet<Class<?>>();
+ supportedFlagTypes.add(int.class);
+ supportedFlagTypes.add(boolean.class);
+ supportedFlagTypes.add(String.class);
+ }
+
+ public static Module parseFlags(final Class<?>... flagSettings) {
+
+ final Properties properties;
+ try {
+ properties = new Properties();
+ final InputStream input = Thread.currentThread().getContextClassLoader().getResourceAsStream(
+ "kune.properties");
+ properties.load(input);
+ input.close();
+ } catch (final Exception excep) {
+ throw new RuntimeException("Error reading properties", excep); // NOPMD
+ // by
+ // vjrj on
+ // 30/08/09
+ // 16:59
+ }
+
+ final List<Field> fields = new ArrayList<Field>();
+ for (final Class<?> settings : flagSettings) {
+ fields.addAll(Arrays.asList(settings.getDeclaredFields()));
+ }
+
+ // Reflect on flagSettings class and absorb flags
+ final Map<Flag, Field> flags = new LinkedHashMap<Flag, Field>();
+ for (final Field field : fields) {
+ if (!field.isAnnotationPresent(Flag.class)) {
+ continue;
+ }
+
+ // Validate target type
+ // if (supportedFlagTypes.contains(field.getType())) {
+ // throw new IllegalArgumentException(field.getType() +
+ // " is not one of the supported flag types "
+ // + supportedFlagTypes);
+ // }
+
+ final Flag flag = field.getAnnotation(Flag.class);
+
+ flags.put(flag, field);
+ }
+
+ // Now validate them
+ for (final Flag flag : flags.keySet()) {
+ if (flag.mandatory()) {
+ final String help = !"".equals(flag.description()) ? flag.description() : flag.name();
+ mandatoryOption(properties, flag.name(), "must supply " + help);
+ }
+ }
+
+ // bundle everything up in an injectable guice module
+ return new AbstractModule() {
+
+ @Override
+ protected void configure() {
+ // We must iterate the flags a third time when binding.
+ // Note: do not collapse these loops as that will damage
+ // early error detection. The runtime is still O(n) in flag
+ // count.
+ for (final Map.Entry<Flag, Field> entry : flags.entrySet()) {
+ final Class<?> type = entry.getValue().getType();
+ final Flag flag = entry.getKey();
+
+ // Skip non-mandatory, missing flags.
+ if (!flag.mandatory()) {
+ continue;
+ }
+
+ final String flagValue = properties.getProperty(PREFIX + flag.name());
+
+ // Coerce String flag into target type.
+ // NOTE(dhanji): only supported types are int, String and
+ // boolean.
+ if (int.class.equals(type)) {
+ bindConstant().annotatedWith(Names.named(flag.name())).to(Integer.parseInt(flagValue));
+ } else if (boolean.class.equals(type)) {
+ bindConstant().annotatedWith(Names.named(flag.name())).to(Boolean.parseBoolean(flagValue));
+ } else {
+ bindConstant().annotatedWith(Names.named(flag.name())).to(flagValue);
+ }
+ }
+ }
+ };
+ }
+
+ /**
+ * Checks a mandatory option is set, spits out help and dies if not.
+ *
+ * @param cmd
+ * parsed options
+ * @param option
+ * the option to check
+ * @param helpString
+ * the error message to emit if not.
+ */
+ static void mandatoryOption(final Properties properties, final String option, final String helpString) {
+ if (properties.getProperty(PREFIX + option) == null) {
+ throw new RuntimeException("Wave option " + PREFIX + option + " in kune.properties is mandatory"); // NOPMD
+ // by
+ // vjrj
+ // on
+ // 30/08/09
+ // 12:36
+ }
+ }
+}
Modified: trunk/src/main/java/org/ourproject/kune/platf/server/PlatformServerModule.java
===================================================================
--- trunk/src/main/java/org/ourproject/kune/platf/server/PlatformServerModule.java 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/java/org/ourproject/kune/platf/server/PlatformServerModule.java 2009-08-31 10:49:15 UTC (rev 1140)
@@ -180,4 +180,5 @@
bind(I18nTranslationService.class).to(I18nTranslationServiceDefault.class);
bind(SessionService.class).to(SessionServiceDefault.class);
}
+
}
Modified: trunk/src/main/java/org/ourproject/kune/platf/server/properties/ChatProperties.java
===================================================================
--- trunk/src/main/java/org/ourproject/kune/platf/server/properties/ChatProperties.java 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/java/org/ourproject/kune/platf/server/properties/ChatProperties.java 2009-08-31 10:49:15 UTC (rev 1140)
@@ -23,7 +23,7 @@
import com.google.inject.Singleton;
/**
- * sintactic sugar!
+ * Syntactic sugar!
*/
@Singleton
public class ChatProperties {
Modified: trunk/src/main/resources/kune.properties
===================================================================
--- trunk/src/main/resources/kune.properties 2009-08-05 14:56:47 UTC (rev 1139)
+++ trunk/src/main/resources/kune.properties 2009-08-31 10:49:15 UTC (rev 1140)
@@ -57,6 +57,21 @@
kune.media.oggembededobject = <applet code="com.fluendo.player.Cortado.class" archive="/kune/others/cortado.jar" width="352" height="288"> <param name="url" value="###DOC_URL###"/> <param name="local" value="false"/> <param name="showStatus" value="show"/> <param name="keepAspect" value="true"/> <param name="autoPlay" value="false"/> <param name="video" value="true"/> <param name="audio" value="true"/> <param name="bufferSize" value="200"/> </applet>
kune.media.aviembededobject = <object data="###DOC_URL###" type="video/msvideo" />
+### See: http://code.google.com/p/wave-protocol/wiki/Installation
+### wave server configuration
+kune.wave.xmpp_server_hostname = localhost
+kune.wave.xmpp_server_secret = asdfasdf
+kune.wave.xmpp_component_name = wave
+kune.wave.xmpp_server_port = 5275
+kune.wave.xmpp_server_ip = localhost
+kune.wave.xmpp_server_ping =
+kune.wave.client_frontend_hostname = 127.0.0.1
+kune.wave.client_frontend_port = 9876
+kune.wave.certificate_private_key = war/WEB-INF/classes/localhost.key
+kune.wave.certificate_files = war/WEB-INF/classes/localhost.cer
+kune.wave.certificate_domain = localhost
+kune.wave.waveserver_disable_verification = true
+
### More info about properties
# http://en.wikipedia.org/wiki/.properties
# http://java.sun.com/javase/6/docs/api/java/util/Properties.html#load(java.io.Reader)
More information about the kune-commits
mailing list