Skip to content

Commit

Permalink
escape data in calendar popover (#2960)
Browse files Browse the repository at this point in the history
  • Loading branch information
kevinpapst committed Nov 19, 2021
1 parent 89bfa82 commit 9470699
Show file tree
Hide file tree
Showing 9 changed files with 51 additions and 16 deletions.
2 changes: 2 additions & 0 deletions assets/js/KimaiLoader.js
Expand Up @@ -36,6 +36,7 @@ import KimaiDatePicker from "./plugins/KimaiDatePicker";
import KimaiConfirmationLink from "./plugins/KimaiConfirmationLink";
import KimaiMultiUpdateTable from "./plugins/KimaiMultiUpdateTable";
import KimaiDateUtils from "./plugins/KimaiDateUtils";
import KimaiEscape from "./plugins/KimaiEscape";

export default class KimaiLoader {

Expand All @@ -48,6 +49,7 @@ export default class KimaiLoader {
new KimaiTranslation(translations)
);

kimai.registerPlugin(new KimaiEscape());
kimai.registerPlugin(new KimaiEvent());
kimai.registerPlugin(new KimaiAPI());
kimai.registerPlugin(new KimaiAlert());
Expand Down
10 changes: 1 addition & 9 deletions assets/js/KimaiPlugin.js
Expand Up @@ -71,14 +71,6 @@ export default class KimaiPlugin {
* @returns {string}
*/
escape(title) {
const tagsToReplace = {
'&': '&',
'<': '&lt;',
'>': '&gt;',
};

return title.replace(/[&<>]/g, function(tag) {
return tagsToReplace[tag] || tag;
});
return this.getPlugin('escape').escapeForHtml(title);
};
}
35 changes: 35 additions & 0 deletions assets/js/plugins/KimaiEscape.js
@@ -0,0 +1,35 @@
/*
* This file is part of the Kimai time-tracking app.
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

/*!
* [KIMAI] KimaiEscape: sanitize strings
*/

import KimaiPlugin from "../KimaiPlugin";

export default class KimaiEscape extends KimaiPlugin {

getId() {
return 'escape';
}

/**
* @param {string} title
* @returns {string}
*/
escapeForHtml(title) {
const tagsToReplace = {
'&': '&amp;',
'<': '&lt;',
'>': '&gt;',
};

return title.replace(/[&<>]/g, function(tag) {
return tagsToReplace[tag] || tag;
});
};
}
2 changes: 2 additions & 0 deletions public/build/app.920ba43e.js

Large diffs are not rendered by default.

Expand Up @@ -91,6 +91,10 @@
* [KIMAI] KimaiDateUtils: responsible for handling date specific tasks
*/

/*!
* [KIMAI] KimaiEscape: sanitize strings
*/

/*!
* [KIMAI] KimaiEvent: helper to trigger events
*/
Expand Down
2 changes: 0 additions & 2 deletions public/build/app.9e8f68cf.js

This file was deleted.

2 changes: 1 addition & 1 deletion public/build/entrypoints.json
Expand Up @@ -3,7 +3,7 @@
"app": {
"js": [
"build/runtime.b8e7bb04.js",
"build/app.9e8f68cf.js"
"build/app.920ba43e.js"
],
"css": [
"build/app.3bc2b4d9.css"
Expand Down
2 changes: 1 addition & 1 deletion public/build/manifest.json
@@ -1,6 +1,6 @@
{
"build/app.css": "build/app.3bc2b4d9.css",
"build/app.js": "build/app.9e8f68cf.js",
"build/app.js": "build/app.920ba43e.js",
"build/invoice.css": "build/invoice.ff32661a.css",
"build/invoice.js": "build/invoice.19f36eca.js",
"build/invoice-pdf.css": "build/invoice-pdf.9a7468ef.css",
Expand Down
8 changes: 5 additions & 3 deletions templates/calendar/user.html.twig
Expand Up @@ -120,11 +120,13 @@
function renderEventPopoverContent(eventObj)
{
const escaper = kimai.getPlugin('escape');
return '<div class="calendar-entry">' +
'<ul>' +
'<li>' + '{{ 'label.customer'|trans }}: ' + eventObj.customer + '</li>' +
'<li>' + '{{ 'label.project'|trans }}: ' + eventObj.project + '</li>' +
'<li>' + '{{ 'label.activity'|trans }}: ' + eventObj.activity + '</li>' +
'<li>' + '{{ 'label.customer'|trans }}: ' + escaper.escapeForHtml(eventObj.customer) + '</li>' +
'<li>' + '{{ 'label.project'|trans }}: ' + escaper.escapeForHtml(eventObj.project) + '</li>' +
'<li>' + '{{ 'label.activity'|trans }}: ' + escaper.escapeForHtml(eventObj.activity) + '</li>' +
'</ul>' +
(eventObj.description !== null || eventObj.tags.length > 0 ? '<hr>' : '') +
(eventObj.description ? '<p>' + eventObj.description + '</p>' : '') +
Expand Down

0 comments on commit 9470699

Please sign in to comment.