2014-02-13 23:20:00 +04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2014
|
|
|
|
*
|
|
|
|
* This file is licensed under the Affero General Public License version 3
|
|
|
|
* or later.
|
|
|
|
*
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2015-01-14 13:28:36 +03:00
|
|
|
/* global FileActions, Files, FileList */
|
2014-05-12 21:54:20 +04:00
|
|
|
/* global dragOptions, folderDropOptions */
|
2014-06-05 14:52:08 +04:00
|
|
|
if (!OCA.Sharing) {
|
|
|
|
OCA.Sharing = {};
|
|
|
|
}
|
2014-05-09 00:06:30 +04:00
|
|
|
if (!OCA.Files) {
|
|
|
|
OCA.Files = {};
|
|
|
|
}
|
2014-06-24 01:56:10 +04:00
|
|
|
/**
|
|
|
|
* @namespace
|
|
|
|
*/
|
2014-05-09 00:06:30 +04:00
|
|
|
OCA.Sharing.PublicApp = {
|
|
|
|
_initialized: false,
|
2012-08-27 23:46:05 +04:00
|
|
|
|
2014-06-24 01:56:10 +04:00
|
|
|
/**
|
|
|
|
* Initializes the public share app.
|
|
|
|
*
|
|
|
|
* @param $el container
|
|
|
|
*/
|
2014-06-05 13:29:01 +04:00
|
|
|
initialize: function ($el) {
|
2014-05-20 15:37:58 +04:00
|
|
|
var self = this;
|
2014-05-20 18:01:34 +04:00
|
|
|
var fileActions;
|
2014-05-09 00:06:30 +04:00
|
|
|
if (this._initialized) {
|
|
|
|
return;
|
|
|
|
}
|
2014-05-20 18:01:34 +04:00
|
|
|
fileActions = new OCA.Files.FileActions();
|
|
|
|
// default actions
|
|
|
|
fileActions.registerDefaultActions();
|
|
|
|
// legacy actions
|
|
|
|
fileActions.merge(window.FileActions);
|
|
|
|
// regular actions
|
|
|
|
fileActions.merge(OCA.Files.fileActions);
|
|
|
|
|
2014-06-27 18:10:20 +04:00
|
|
|
// in case apps would decide to register file actions later,
|
|
|
|
// replace the global object with this one
|
|
|
|
OCA.Files.fileActions = fileActions;
|
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
this._initialized = true;
|
2014-05-20 15:37:58 +04:00
|
|
|
this.initialDir = $('#dir').val();
|
|
|
|
|
2015-07-13 18:41:20 +03:00
|
|
|
var token = $('#sharingToken').val();
|
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
// file list mode ?
|
2014-05-20 15:37:58 +04:00
|
|
|
if ($el.find('#filestable').length) {
|
2015-07-13 18:41:20 +03:00
|
|
|
var filesClient = new OC.Files.Client({
|
|
|
|
host: OC.getHost(),
|
|
|
|
port: OC.getPort(),
|
|
|
|
userName: token,
|
|
|
|
// note: password not be required, the endpoint
|
|
|
|
// will recognize previous validation from the session
|
|
|
|
root: OC.getRootPath() + '/public.php/webdav',
|
|
|
|
useHTTPS: OC.getProtocol() === 'https'
|
|
|
|
});
|
|
|
|
|
2014-05-12 21:54:20 +04:00
|
|
|
this.fileList = new OCA.Files.FileList(
|
|
|
|
$el,
|
|
|
|
{
|
2014-12-01 18:17:28 +03:00
|
|
|
id: 'files.public',
|
2015-10-20 16:46:56 +03:00
|
|
|
scrollContainer: $('#content-wrapper'),
|
2014-05-12 21:54:20 +04:00
|
|
|
dragOptions: dragOptions,
|
2014-05-20 18:01:34 +04:00
|
|
|
folderDropOptions: folderDropOptions,
|
2015-07-16 13:28:19 +03:00
|
|
|
fileActions: fileActions,
|
2015-07-13 18:41:20 +03:00
|
|
|
detailsViewEnabled: false,
|
|
|
|
filesClient: filesClient
|
2014-05-12 21:54:20 +04:00
|
|
|
}
|
|
|
|
);
|
|
|
|
this.files = OCA.Files.Files;
|
|
|
|
this.files.initialize();
|
2014-12-01 18:17:28 +03:00
|
|
|
// TODO: move to PublicFileList.initialize() once
|
|
|
|
// the code was split into a separate class
|
|
|
|
OC.Plugins.attach('OCA.Sharing.PublicFileList', this.fileList);
|
2014-05-09 00:06:30 +04:00
|
|
|
}
|
2012-08-27 23:46:05 +04:00
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
var mimetype = $('#mimetype').val();
|
2014-09-30 17:23:16 +04:00
|
|
|
var mimetypeIcon = $('#mimetypeIcon').val();
|
|
|
|
mimetypeIcon = mimetypeIcon.substring(0, mimetypeIcon.length - 3);
|
|
|
|
mimetypeIcon = mimetypeIcon + 'svg';
|
|
|
|
|
|
|
|
var previewSupported = $('#previewSupported').val();
|
2014-05-02 20:36:58 +04:00
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
if (typeof FileActions !== 'undefined') {
|
|
|
|
// Show file preview if previewer is available, images are already handled by the template
|
|
|
|
if (mimetype.substr(0, mimetype.indexOf('/')) !== 'image' && $('.publicpreview').length === 0) {
|
|
|
|
// Trigger default action if not download TODO
|
|
|
|
var action = FileActions.getDefault(mimetype, 'file', OC.PERMISSION_READ);
|
|
|
|
if (typeof action !== 'undefined') {
|
|
|
|
action($('#filename').val());
|
|
|
|
}
|
2012-08-30 05:12:10 +04:00
|
|
|
}
|
2012-08-27 23:46:05 +04:00
|
|
|
}
|
2014-01-24 16:32:31 +04:00
|
|
|
|
2014-05-02 20:36:58 +04:00
|
|
|
|
2014-09-30 17:23:16 +04:00
|
|
|
// dynamically load image previews
|
2015-04-16 16:28:04 +03:00
|
|
|
var bottomMargin = 350;
|
2015-11-18 18:45:19 +03:00
|
|
|
var previewWidth = $(window).width();
|
|
|
|
var previewHeight = $(window).height() - bottomMargin;
|
2015-04-16 16:28:04 +03:00
|
|
|
previewHeight = Math.max(200, previewHeight);
|
2014-09-30 17:23:16 +04:00
|
|
|
var params = {
|
2015-11-18 18:45:19 +03:00
|
|
|
x: Math.ceil(previewWidth * window.devicePixelRatio),
|
|
|
|
y: Math.ceil(previewHeight * window.devicePixelRatio),
|
2014-09-30 17:23:16 +04:00
|
|
|
a: 'true',
|
|
|
|
file: encodeURIComponent(this.initialDir + $('#filename').val()),
|
2015-04-16 20:23:42 +03:00
|
|
|
t: token,
|
2014-09-30 17:23:16 +04:00
|
|
|
scalingup: 0
|
|
|
|
};
|
2013-10-28 23:22:06 +04:00
|
|
|
|
2014-12-18 18:00:55 +03:00
|
|
|
var img = $('<img class="publicpreview" alt="">');
|
2015-11-18 18:45:19 +03:00
|
|
|
img.css({
|
|
|
|
'max-width': previewWidth,
|
|
|
|
'max-height': previewHeight
|
|
|
|
});
|
2015-01-17 14:11:52 +03:00
|
|
|
|
|
|
|
var fileSize = parseInt($('#filesize').val(), 10);
|
|
|
|
var maxGifSize = parseInt($('#maxSizeAnimateGif').val(), 10);
|
|
|
|
|
|
|
|
if (mimetype === 'image/gif' &&
|
|
|
|
(maxGifSize === -1 || fileSize <= (maxGifSize * 1024 * 1024))) {
|
|
|
|
img.attr('src', $('#downloadURL').val());
|
|
|
|
img.appendTo('#imgframe');
|
2015-05-28 16:36:28 +03:00
|
|
|
} else if (mimetype.substr(0, mimetype.indexOf('/')) === 'text' && window.btoa) {
|
2015-04-16 20:46:26 +03:00
|
|
|
// Undocumented Url to public WebDAV endpoint
|
2015-04-20 18:44:41 +03:00
|
|
|
var url = parent.location.protocol + '//' + location.host + OC.linkTo('', 'public.php/webdav');
|
2015-04-16 16:28:04 +03:00
|
|
|
$.ajax({
|
2015-04-16 20:46:26 +03:00
|
|
|
url: url,
|
2015-04-20 18:44:41 +03:00
|
|
|
headers: {
|
|
|
|
Authorization: 'Basic ' + btoa(token + ':'),
|
|
|
|
Range: 'bytes=0-1000'
|
2015-04-16 16:28:04 +03:00
|
|
|
}
|
2015-04-20 18:44:41 +03:00
|
|
|
}).then(function (data) {
|
|
|
|
self._showTextPreview(data, previewHeight);
|
2015-04-16 16:28:04 +03:00
|
|
|
});
|
2015-01-17 14:11:52 +03:00
|
|
|
} else if (previewSupported === 'true' ||
|
|
|
|
mimetype.substr(0, mimetype.indexOf('/')) === 'image' &&
|
|
|
|
mimetype !== 'image/svg+xml') {
|
2014-05-09 00:06:30 +04:00
|
|
|
img.attr('src', OC.filePath('files_sharing', 'ajax', 'publicpreview.php') + '?' + OC.buildQueryString(params));
|
|
|
|
img.appendTo('#imgframe');
|
2014-09-30 17:23:16 +04:00
|
|
|
} else if (mimetype.substr(0, mimetype.indexOf('/')) !== 'video') {
|
|
|
|
img.attr('src', OC.Util.replaceSVGIcon(mimetypeIcon));
|
|
|
|
img.attr('width', 128);
|
|
|
|
img.appendTo('#imgframe');
|
2014-05-09 00:06:30 +04:00
|
|
|
}
|
2013-10-28 23:22:06 +04:00
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
if (this.fileList) {
|
|
|
|
// TODO: move this to a separate PublicFileList class that extends OCA.Files.FileList (+ unit tests)
|
2015-11-23 18:17:54 +03:00
|
|
|
this.fileList.getDownloadUrl = function (filename, dir, isDir) {
|
|
|
|
var path = dir || this.getCurrentDirectory();
|
|
|
|
if (_.isArray(filename)) {
|
2014-05-09 00:06:30 +04:00
|
|
|
filename = JSON.stringify(filename);
|
|
|
|
}
|
|
|
|
var params = {
|
2016-03-07 13:55:55 +03:00
|
|
|
path: path
|
2014-05-09 00:06:30 +04:00
|
|
|
};
|
2016-03-07 13:55:55 +03:00
|
|
|
if (filename) {
|
|
|
|
params.files = filename;
|
|
|
|
}
|
2015-05-19 16:12:08 +03:00
|
|
|
return OC.generateUrl('/s/' + token + '/download') + '?' + OC.buildQueryString(params);
|
2014-05-02 20:36:58 +04:00
|
|
|
};
|
2013-10-28 23:22:06 +04:00
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
this.fileList.getAjaxUrl = function (action, params) {
|
2014-05-09 00:06:30 +04:00
|
|
|
params = params || {};
|
2015-04-16 20:23:42 +03:00
|
|
|
params.t = token;
|
2014-05-09 00:06:30 +04:00
|
|
|
return OC.filePath('files_sharing', 'ajax', action + '.php') + '?' + OC.buildQueryString(params);
|
|
|
|
};
|
2012-08-27 23:46:05 +04:00
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
this.fileList.linkTo = function (dir) {
|
2015-04-20 18:44:41 +03:00
|
|
|
return OC.generateUrl('/s/' + token + '', {dir: dir});
|
2014-05-02 20:36:58 +04:00
|
|
|
};
|
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
this.fileList.generatePreviewUrl = function (urlSpec) {
|
2015-07-20 17:51:28 +03:00
|
|
|
urlSpec = urlSpec || {};
|
|
|
|
if (!urlSpec.x) {
|
2015-09-30 11:49:48 +03:00
|
|
|
urlSpec.x = 32;
|
2015-07-20 17:51:28 +03:00
|
|
|
}
|
|
|
|
if (!urlSpec.y) {
|
2015-09-30 11:49:48 +03:00
|
|
|
urlSpec.y = 32;
|
2015-07-20 17:51:28 +03:00
|
|
|
}
|
|
|
|
urlSpec.x *= window.devicePixelRatio;
|
|
|
|
urlSpec.y *= window.devicePixelRatio;
|
2015-09-27 13:46:25 +03:00
|
|
|
urlSpec.x = Math.ceil(urlSpec.x);
|
|
|
|
urlSpec.y = Math.ceil(urlSpec.y);
|
2014-05-09 00:06:30 +04:00
|
|
|
urlSpec.t = $('#dirToken').val();
|
|
|
|
return OC.generateUrl('/apps/files_sharing/ajax/publicpreview.php?') + $.param(urlSpec);
|
2014-05-02 20:36:58 +04:00
|
|
|
};
|
2014-05-09 00:06:30 +04:00
|
|
|
|
2015-04-21 12:57:29 +03:00
|
|
|
this.fileList.updateEmptyContent = function() {
|
|
|
|
this.$el.find('#emptycontent .uploadmessage').text(
|
|
|
|
t('files_sharing', 'You can upload into this folder')
|
|
|
|
);
|
|
|
|
OCA.Files.FileList.prototype.updateEmptyContent.apply(this, arguments);
|
|
|
|
};
|
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
var file_upload_start = $('#file_upload_start');
|
2014-06-05 13:29:01 +04:00
|
|
|
file_upload_start.on('fileuploadadd', function (e, data) {
|
2014-05-09 00:06:30 +04:00
|
|
|
var fileDirectory = '';
|
2014-06-05 13:29:01 +04:00
|
|
|
if (typeof data.files[0].relativePath !== 'undefined') {
|
2014-05-09 00:06:30 +04:00
|
|
|
fileDirectory = data.files[0].relativePath;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add custom data to the upload handler
|
|
|
|
data.formData = {
|
|
|
|
requesttoken: $('#publicUploadRequestToken').val(),
|
|
|
|
dirToken: $('#dirToken').val(),
|
2014-06-18 22:38:51 +04:00
|
|
|
subdir: data.targetDir || self.fileList.getCurrentDirectory(),
|
2014-05-09 00:06:30 +04:00
|
|
|
file_directory: fileDirectory
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2014-05-20 18:01:34 +04:00
|
|
|
// do not allow sharing from the public page
|
|
|
|
delete this.fileList.fileActions.actions.all.Share;
|
2014-05-09 00:06:30 +04:00
|
|
|
|
2014-05-20 15:37:58 +04:00
|
|
|
this.fileList.changeDirectory(this.initialDir || '/', false, true);
|
2014-05-09 00:06:30 +04:00
|
|
|
|
|
|
|
// URL history handling
|
|
|
|
this.fileList.$el.on('changeDirectory', _.bind(this._onDirectoryChanged, this));
|
|
|
|
OC.Util.History.addOnPopStateHandler(_.bind(this._onUrlChanged, this));
|
2015-01-14 13:28:36 +03:00
|
|
|
|
|
|
|
$('#download').click(function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
OC.redirect(FileList.getDownloadUrl());
|
|
|
|
});
|
2014-05-09 00:06:30 +04:00
|
|
|
}
|
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
$(document).on('click', '#directLink', function () {
|
2014-05-09 00:06:30 +04:00
|
|
|
$(this).focus();
|
|
|
|
$(this).select();
|
2014-05-02 20:36:58 +04:00
|
|
|
});
|
2013-06-25 14:24:14 +04:00
|
|
|
|
2014-06-17 15:28:27 +04:00
|
|
|
$('.save-form').submit(function (event) {
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
var remote = $(this).find('input[type="text"]').val();
|
|
|
|
var token = $('#sharingToken').val();
|
|
|
|
var owner = $('#save').data('owner');
|
2015-12-14 18:04:05 +03:00
|
|
|
var ownerDisplayName = $('#save').data('owner-display-name');
|
2014-06-17 15:28:27 +04:00
|
|
|
var name = $('#save').data('name');
|
|
|
|
var isProtected = $('#save').data('protected') ? 1 : 0;
|
2015-12-14 18:04:05 +03:00
|
|
|
OCA.Sharing.PublicApp._saveToOwnCloud(remote, token, owner, ownerDisplayName, name, isProtected);
|
2014-06-17 15:28:27 +04:00
|
|
|
});
|
|
|
|
|
2015-09-30 16:28:28 +03:00
|
|
|
$('#remote_address').on("keyup paste", function() {
|
2015-09-28 21:44:33 +03:00
|
|
|
if ($(this).val() === '') {
|
|
|
|
$('#save-button-confirm').prop('disabled', true);
|
|
|
|
} else {
|
|
|
|
$('#save-button-confirm').prop('disabled', false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-07-04 02:07:24 +04:00
|
|
|
$('#save #save-button').click(function () {
|
2014-06-17 15:28:27 +04:00
|
|
|
$(this).hide();
|
|
|
|
$('.save-form').css('display', 'inline');
|
|
|
|
$('#remote_address').focus();
|
|
|
|
});
|
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
// legacy
|
|
|
|
window.FileList = this.fileList;
|
|
|
|
},
|
2013-10-18 19:40:41 +04:00
|
|
|
|
2015-04-20 18:44:41 +03:00
|
|
|
_showTextPreview: function (data, previewHeight) {
|
|
|
|
var textDiv = $('<div/>').addClass('text-preview');
|
|
|
|
textDiv.text(data);
|
|
|
|
textDiv.appendTo('#imgframe');
|
|
|
|
var divHeight = textDiv.height();
|
|
|
|
if (data.length > 999) {
|
2015-04-23 19:15:11 +03:00
|
|
|
var ellipsis = $('<div/>').addClass('ellipsis');
|
|
|
|
ellipsis.html('(…)');
|
|
|
|
ellipsis.appendTo('#imgframe');
|
2015-04-20 18:44:41 +03:00
|
|
|
}
|
|
|
|
if (divHeight > previewHeight) {
|
|
|
|
textDiv.height(previewHeight);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
_onDirectoryChanged: function (e) {
|
2014-05-09 00:06:30 +04:00
|
|
|
OC.Util.History.pushState({
|
|
|
|
// arghhhh, why is this not called "dir" !?
|
|
|
|
path: e.dir
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
_onUrlChanged: function (params) {
|
2014-05-09 00:06:30 +04:00
|
|
|
this.fileList.changeDirectory(params.path || params.dir, false, true);
|
2014-06-17 15:28:27 +04:00
|
|
|
},
|
|
|
|
|
2015-12-14 18:04:05 +03:00
|
|
|
_saveToOwnCloud: function (remote, token, owner, ownerDisplayName, name, isProtected) {
|
2016-03-21 17:44:12 +03:00
|
|
|
var toggleLoading = function() {
|
|
|
|
var iconClass = $('#save-button-confirm').attr('class');
|
|
|
|
var loading = iconClass.indexOf('icon-loading-small') !== -1;
|
|
|
|
if(loading) {
|
|
|
|
$('#save-button-confirm')
|
|
|
|
.removeClass("icon-loading-small")
|
|
|
|
.addClass("icon-confirm");
|
|
|
|
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$('#save-button-confirm')
|
|
|
|
.removeClass("icon-confirm")
|
|
|
|
.addClass("icon-loading-small");
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
toggleLoading();
|
2014-06-17 15:28:27 +04:00
|
|
|
var location = window.location.protocol + '//' + window.location.host + OC.webroot;
|
2015-11-19 00:48:35 +03:00
|
|
|
|
|
|
|
if(remote.substr(-1) !== '/') {
|
|
|
|
remote += '/'
|
|
|
|
};
|
2014-06-17 15:28:27 +04:00
|
|
|
|
2015-11-19 00:48:35 +03:00
|
|
|
var url = remote + 'index.php/apps/files#' + 'remote=' + encodeURIComponent(location) // our location is the remote for the other server
|
2015-12-14 18:04:05 +03:00
|
|
|
+ "&token=" + encodeURIComponent(token) + "&owner=" + encodeURIComponent(owner) +"&ownerDisplayName=" + encodeURIComponent(ownerDisplayName) + "&name=" + encodeURIComponent(name) + "&protected=" + isProtected;
|
2014-06-17 15:28:27 +04:00
|
|
|
|
|
|
|
|
|
|
|
if (remote.indexOf('://') > 0) {
|
|
|
|
OC.redirect(url);
|
|
|
|
} else {
|
|
|
|
// if no protocol is specified, we automatically detect it by testing https and http
|
|
|
|
// this check needs to happen on the server due to the Content Security Policy directive
|
|
|
|
$.get(OC.generateUrl('apps/files_sharing/testremote'), {remote: remote}).then(function (protocol) {
|
|
|
|
if (protocol !== 'http' && protocol !== 'https') {
|
2016-03-21 17:44:12 +03:00
|
|
|
toggleLoading();
|
2015-01-05 13:50:05 +03:00
|
|
|
OC.dialogs.alert(t('files_sharing', 'No ownCloud installation (7 or higher) found at {remote}', {remote: remote}),
|
2014-06-17 15:28:27 +04:00
|
|
|
t('files_sharing', 'Invalid ownCloud url'));
|
|
|
|
} else {
|
|
|
|
OC.redirect(protocol + '://' + url);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2014-05-09 00:06:30 +04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-06-05 13:29:01 +04:00
|
|
|
$(document).ready(function () {
|
2015-05-19 18:40:36 +03:00
|
|
|
// FIXME: replace with OC.Plugins.register()
|
|
|
|
if (window.TESTING) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-05-09 00:06:30 +04:00
|
|
|
var App = OCA.Sharing.PublicApp;
|
2014-05-21 14:54:34 +04:00
|
|
|
// defer app init, to give a chance to plugins to register file actions
|
2014-06-05 13:29:01 +04:00
|
|
|
_.defer(function () {
|
2014-05-21 14:54:34 +04:00
|
|
|
App.initialize($('#preview'));
|
|
|
|
});
|
2014-05-12 21:54:20 +04:00
|
|
|
|
2014-05-20 15:37:58 +04:00
|
|
|
if (window.Files) {
|
|
|
|
// HACK: for oc-dialogs previews that depends on Files:
|
2015-07-20 17:51:28 +03:00
|
|
|
Files.generatePreviewUrl = function (urlSpec) {
|
|
|
|
return App.fileList.generatePreviewUrl(urlSpec);
|
2014-05-20 15:37:58 +04:00
|
|
|
};
|
|
|
|
}
|
2013-06-25 14:24:14 +04:00
|
|
|
});
|
2014-05-09 00:06:30 +04:00
|
|
|
|