mirror of
https://github.com/inverse-inc/sogo.git
synced 2026-05-09 13:35:26 +00:00
@@ -10,6 +10,8 @@ Bug fixes
|
||||
- [sogo-tool] fixed "manage-acl unsubscribe" command (#4591)
|
||||
- [web] fixed handling of collapsed/expanded mail accounts (#4541)
|
||||
- [web] fixed handling of duplicate recipients (#4597)
|
||||
- [web] fixed folder export when XSRF validation is enabled (#4502)
|
||||
- [web] don't encode filename extension when exporting folders
|
||||
|
||||
4.0.4 (2018-10-23)
|
||||
------------------
|
||||
|
||||
@@ -94,12 +94,11 @@ static NSArray *photoTags = nil;
|
||||
}
|
||||
|
||||
response = [context response];
|
||||
[response setHeader: @"application/octet-stream; charset=utf-8"
|
||||
[response setHeader: @"application/directory; charset=utf-8"
|
||||
forKey: @"content-type"];
|
||||
filename = [NSString stringWithFormat: @"%@.ldif",
|
||||
[sourceFolder displayName]];
|
||||
disposition = [NSString stringWithFormat: @"attachment; filename=\"%@\"",
|
||||
[filename asQPSubjectString: @"utf-8"]];
|
||||
[[sourceFolder displayName] asQPSubjectString: @"utf-8"]];
|
||||
disposition = [NSString stringWithFormat: @"attachment; filename=\"%@\"", filename];
|
||||
[response setHeader: disposition forKey: @"Content-Disposition"];
|
||||
[response setContent: [content dataUsingEncoding: NSUTF8StringEncoding]];
|
||||
|
||||
|
||||
@@ -253,8 +253,12 @@ static SoProduct *commonProduct = nil;
|
||||
![auth isKindOfClass: [SOGoWebAuthenticator class]])
|
||||
return [super performActionNamed: _actionName];
|
||||
|
||||
// We grab the X-XSRF-TOKEN header
|
||||
// We grab the X-XSRF-TOKEN from the header or the URL
|
||||
token = [[context request] headerForKey: @"X-XSRF-TOKEN"];
|
||||
if (![token length])
|
||||
{
|
||||
token = [[context request] formValueForKey: @"X-XSRF-TOKEN"];
|
||||
}
|
||||
|
||||
// We compare it with our session key
|
||||
value = [[context request]
|
||||
|
||||
@@ -796,8 +796,12 @@ static SoProduct *commonProduct = nil;
|
||||
return [super performActionNamed: _actionName];
|
||||
}
|
||||
|
||||
// We grab the X-XSRF-TOKEN header
|
||||
// We grab the X-XSRF-TOKEN from the header or the URL
|
||||
token = [[context request] headerForKey: @"X-XSRF-TOKEN"];
|
||||
if (![token length])
|
||||
{
|
||||
token = [[context request] formValueForKey: @"X-XSRF-TOKEN"];
|
||||
}
|
||||
|
||||
// We compare it with our session key
|
||||
value = [[context request]
|
||||
|
||||
@@ -54,7 +54,7 @@
|
||||
[response setHeader: @"text/calendar; charset=utf-8"
|
||||
forKey: @"content-type"];
|
||||
disposition = [NSString stringWithFormat: @"attachment; filename=\"%@.ics\"",
|
||||
[folderICS displayName]];
|
||||
[[folderICS displayName] asQPSubjectString: @"utf-8"]];
|
||||
[response setHeader: disposition forKey: @"Content-Disposition"];
|
||||
|
||||
return response;
|
||||
|
||||
@@ -18,7 +18,7 @@ module.exports = function(grunt) {
|
||||
};
|
||||
var custom_vendor_files = {
|
||||
'js/vendor/angular-file-upload.min.js': ['bower_components/angular-file-upload/dist/angular-file-upload.js', 'js/Common/angular-file-upload.trump.js'],
|
||||
'js/vendor/FileSaver.min.js': ['bower_components/file-saver.js/FileSaver.js']
|
||||
'js/vendor/FileSaver.min.js': ['bower_components/FileSaver/dist/FileSaver.js']
|
||||
};
|
||||
|
||||
require('time-grunt')(grunt);
|
||||
|
||||
@@ -11,7 +11,7 @@
|
||||
"angular-ui-router": "1.0.20",
|
||||
"angular-file-upload": "latest",
|
||||
"angular-material": "1.1.10",
|
||||
"file-saver.js": "latest",
|
||||
"FileSaver": "latest",
|
||||
"lodash": "latest",
|
||||
"ng-sortable": "1.3.7",
|
||||
"breakpoint-sass": ">=2.4.2"
|
||||
|
||||
@@ -11,11 +11,12 @@
|
||||
* @param {String} path - the base path of the external resource
|
||||
* @param {Object} options - extra attributes to be associated to the object
|
||||
*/
|
||||
function Resource($http, $q, $window, path, activeUser, options) {
|
||||
function Resource($http, $q, $window, $cookies, path, activeUser, options) {
|
||||
angular.extend(this, {
|
||||
_http: $http,
|
||||
_q: $q,
|
||||
_window: $window,
|
||||
_cookies: $cookies,
|
||||
_path: path,
|
||||
_activeUser: activeUser
|
||||
});
|
||||
@@ -29,9 +30,9 @@
|
||||
* @desc The factory we'll use to register with Angular.
|
||||
* @return a new Resource object
|
||||
*/
|
||||
Resource.$factory = ['$http', '$q', '$window', function($http, $q, $window) {
|
||||
Resource.$factory = ['$http', '$q', '$window', '$cookies', function($http, $q, $window, $cookies) {
|
||||
return function(path, activeUser, options) {
|
||||
return new Resource($http, $q, $window, path, activeUser, options);
|
||||
return new Resource($http, $q, $window, $cookies, path, activeUser, options);
|
||||
};
|
||||
}];
|
||||
|
||||
@@ -54,7 +55,7 @@
|
||||
if (uid)
|
||||
path.splice(path.length - 1, 1, escape(uid));
|
||||
|
||||
return new Resource(this._http, this._q, this._window, '/' + path.join('/'), this._activeUser);
|
||||
return new Resource(this._http, this._q, this._window, this._cookies, '/' + path.join('/'), this._activeUser);
|
||||
};
|
||||
|
||||
/**
|
||||
@@ -234,10 +235,14 @@
|
||||
};
|
||||
|
||||
Resource.prototype.open = function(id, action) {
|
||||
var path = [this._path];
|
||||
var path = [this._path], xsrfToken;
|
||||
xsrfToken = this._cookies.get('XSRF-TOKEN');
|
||||
if (id) path.push(id);
|
||||
if (action) path.push(action);
|
||||
path = _.compact(_.flatten(path)).join('/');
|
||||
if (xsrfToken) {
|
||||
path += '?X-XSRF-TOKEN=' + xsrfToken;
|
||||
}
|
||||
|
||||
this._window.location.href = path;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user