summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorGeorg Ehrke <dev@georgswebsite.de>2012-01-31 11:58:40 +0100
committerGeorg Ehrke <dev@georgswebsite.de>2012-01-31 11:58:40 +0100
commit538618df624176dce2b750a07328f6d3ece47daf (patch)
tree6ba5b4d9f0bb6652ffa7f894412af3575f014d84 /core
parentfc70c7094a32be06329e1674339a4d6d7329db65 (diff)
parent6a1121ab2e91a362ed1e13e18c44fca40761f97a (diff)
downloadnextcloud-server-538618df624176dce2b750a07328f6d3ece47daf.tar.gz
nextcloud-server-538618df624176dce2b750a07328f6d3ece47daf.zip
Merge branch 'master' into calendar
Diffstat (limited to 'core')
-rw-r--r--core/js/eventsource.js99
-rw-r--r--core/js/setup.js12
-rw-r--r--core/templates/installation.php3
3 files changed, 114 insertions, 0 deletions
diff --git a/core/js/eventsource.js b/core/js/eventsource.js
new file mode 100644
index 00000000000..30b942f59e8
--- /dev/null
+++ b/core/js/eventsource.js
@@ -0,0 +1,99 @@
+/**
+ * ownCloud
+ *
+ * @author Robin Appelman
+ * @copyright 2012 Robin Appelman icewind1991@gmail.com
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU AFFERO GENERAL PUBLIC LICENSE for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+/**
+ * wrapper for server side events (http://en.wikipedia.org/wiki/Server-sent_events)
+ * includes a fallback for older browsers and IE
+ *
+ * use server side events with causion, to many open requests can hang the server
+ */
+
+OC.EventSource=function(src){
+ if(!this.useFallBack && typeof EventSource !='undefined'){
+ this.source=new EventSource(src);
+ this.source.onmessage=function(e){
+ for(var i=0;i<this.typelessListeners.length;i++){
+ this.typelessListeners[i](JSON.parse(e.data));
+ }
+ }
+ }else{
+ iframeId='oc_eventsource_iframe_'+OC.EventSource.iframeCount;
+ OC.EventSource.fallBackSources[OC.EventSource.iframeCount]=this;
+ this.iframe=$('<iframe/>');
+ this.iframe.attr('id',iframeId);
+ this.iframe.hide();
+ this.iframe.attr('src',src+'?fallback=true&fallback_id='+OC.EventSource.iframeCount);
+ $('body').append(this.iframe);
+ this.useFallBack=true;
+ OC.EventSource.iframeCount++
+ }
+ //add close listener
+ this.listen('__internal__',function(data){
+ if(data=='close'){
+ this.close();
+ }
+ }.bind(this));
+}
+OC.EventSource.fallBackSources=[];
+OC.EventSource.iframeCount=0;//number of fallback iframes
+OC.EventSource.fallBackCallBack=function(id,type,data){
+ OC.EventSource.fallBackSources[id].fallBackCallBack(type,JSON.parse(data));
+}
+OC.EventSource.prototype={
+ typelessListeners:[],
+ iframe:null,
+ listeners:{},//only for fallback
+ useFallBack:false,
+ fallBackCallBack:function(type,data){
+ if(type){
+ for(var i=0;i<this.listeners[type].length;i++){
+ this.listeners[type][i](data);
+ }
+ }else{
+ for(var i=0;i<this.typelessListeners.length;i++){
+ this.typelessListeners[i](data);
+ }
+ }
+ },
+ lastLength:0,//for fallback
+ listen:function(type,callback){
+ if(callback && callback.call){
+
+ if(type){
+ if(this.useFallBack){
+ if(!this.listeners[type]){
+ this.listeners[type]=[];
+ }
+ this.listeners[type].push(callback);
+ }else{
+ this.source.addEventListener(type,function(e){
+ callback(JSON.parse(e.data));
+ },false);
+ }
+ }else{
+ typelessListeners.push(callback);
+ }
+ }
+ },
+ close:function(){
+ this.source.close();
+ }
+}
diff --git a/core/js/setup.js b/core/js/setup.js
index 94097785e42..6e056cc90d1 100644
--- a/core/js/setup.js
+++ b/core/js/setup.js
@@ -1,4 +1,11 @@
+var dbtypes
$(document).ready(function() {
+ dbtypes={
+ sqlite:!!$('#hasSQLite').val(),
+ mysql:!!$('#hasMySQL').val(),
+ postgresql:!!$('#hasPostgreSQL').val(),
+ }
+
$('#selectDbType').buttonset();
$('#datadirContent').hide(250);
$('#databaseField').hide(250);
@@ -60,4 +67,9 @@ $(document).ready(function() {
form.submit();
return false;
});
+
+ if(!dbtypes.sqlite){
+ $('#showAdvanced').click();
+ $('input[type="radio"]').first().click();
+ }
});
diff --git a/core/templates/installation.php b/core/templates/installation.php
index f1cde6b3904..4558f97bc08 100644
--- a/core/templates/installation.php
+++ b/core/templates/installation.php
@@ -1,3 +1,6 @@
+<input type='hidden' id='hasMySQL' value='<?php echo $_['hasMySQL'] ?>'></input>
+<input type='hidden' id='hasSQLite' value='<?php echo $_['hasSQLite'] ?>'></input>
+<input type='hidden' id='hasPostgreSQL' value='<?php echo $_['hasPostgreSQL'] ?>'></input>
<form action="index.php" method="post">
<input type="hidden" name="install" value="true" />