2019-09-25 19:19:42 +03:00
|
|
|
/**
|
2019-01-29 12:15:46 +03:00
|
|
|
* @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
|
|
*
|
2021-03-31 13:15:40 +03:00
|
|
|
* @author Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
|
|
* @author John Molakvoæ <skjnldsv@protonmail.com>
|
|
|
|
* @author Roeland Jago Douma <roeland@famdouma.nl>
|
2019-01-29 12:15:46 +03:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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
|
2021-03-31 13:15:40 +03:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
2019-01-29 12:15:46 +03:00
|
|
|
*/
|
|
|
|
|
2019-05-10 14:38:11 +03:00
|
|
|
import $ from 'jquery'
|
|
|
|
|
2019-01-29 12:15:46 +03:00
|
|
|
import './avatar'
|
|
|
|
import './contactsmenu'
|
|
|
|
import './exists'
|
|
|
|
import './filterattr'
|
|
|
|
import './ocdialog'
|
|
|
|
import './octemplate'
|
|
|
|
import './placeholder'
|
2019-05-10 15:18:08 +03:00
|
|
|
import './requesttoken'
|
2019-01-29 12:15:46 +03:00
|
|
|
import './selectrange'
|
|
|
|
import './showpassword'
|
|
|
|
import './ui-fixes'
|
2019-02-14 15:31:49 +03:00
|
|
|
|
|
|
|
import './css/jquery-ui-fixes.scss'
|
2019-02-14 15:34:20 +03:00
|
|
|
import './css/jquery.ocdialog.scss'
|
2019-05-10 14:38:11 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable automatic evaluation of responses for $.ajax() functions (and its
|
|
|
|
* higher-level alternatives like $.get() and $.post()).
|
|
|
|
*
|
|
|
|
* If a response to a $.ajax() request returns a content type of "application/javascript"
|
|
|
|
* JQuery would previously execute the response body. This is a pretty unexpected
|
|
|
|
* behaviour and can result in a bypass of our Content-Security-Policy as well as
|
|
|
|
* multiple unexpected XSS vectors.
|
|
|
|
*/
|
|
|
|
$.ajaxSetup({
|
|
|
|
contents: {
|
2019-11-13 15:05:10 +03:00
|
|
|
script: false,
|
|
|
|
},
|
2019-05-10 14:38:11 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable execution of eval in jQuery. We do require an allowed eval CSP
|
|
|
|
* configuration at the moment for handlebars et al. But for jQuery there is
|
|
|
|
* not much of a reason to execute JavaScript directly via eval.
|
|
|
|
*
|
|
|
|
* This thus mitigates some unexpected XSS vectors.
|
|
|
|
*/
|
2019-09-25 19:19:42 +03:00
|
|
|
$.globalEval = function() {
|
2019-05-10 14:38:11 +03:00
|
|
|
}
|