From: Mischa POSLAWSKY Date: Thu, 28 Aug 2014 18:18:09 +0000 (+0200) Subject: edit: encode page url in path X-Git-Tag: v1.1~1 X-Git-Url: http://git.shiar.net/minimedit.git/commitdiff_plain/643c4d7625a1b1db94edef4eb633fa67c3b53ae0 edit: encode page url in path Included in access logs. --- diff --git a/edit.js b/edit.js index 573f3cd..2e96176 100644 --- a/edit.js +++ b/edit.js @@ -2,10 +2,10 @@ CKEDITOR.plugins.add('inlinesave', { init: function(editor) { editor.addCommand( 'inlinesave', { exec: function (editor) { - var pagename = window.location.pathname.replace(/^\/(?:\.html)?/, '') || 'index'; - var data = 'page='+encodeURIComponent(pagename)+'&body='+encodeURIComponent(editor.getData()); + var pagename = window.location.pathname.replace(/\.html$/, '').replace(/\/$/, '/index'); + var data = 'body='+encodeURIComponent(editor.getData()); ajaxpost = new XMLHttpRequest(); - ajaxpost.open('POST', '/edit.php', true); + ajaxpost.open('POST', '/edit.php'+pagename, true); ajaxpost.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); ajaxpost.onreadystatechange = function () { if (ajaxpost.readyState != 4) diff --git a/edit.php b/edit.php index 657c279..719c2f0 100644 --- a/edit.php +++ b/edit.php @@ -7,10 +7,10 @@ function abort($status, $body) { if (!$_POST) abort('405 post error', "niets te doen"); -if (!isset($_POST['page'])) +if (!isset($_SERVER['PATH_INFO']) or strlen($_SERVER['PATH_INFO']) <= 1) abort('409 input error', "geen bestand aangeleverd"); -$filename = preg_replace('/(?:\.html)?$/', '.html', ltrim($_POST['page'], '/'), 1); +$filename = preg_replace('/(?:\.html)?$/', '.html', ltrim($_SERVER['PATH_INFO'], '/'), 1); if (file_exists($filename) and !is_writable($filename)) abort('403 input error', "ongeldige bestandsnaam: $filename");