From aca87d534d3ac2ab88a8cfb6b1cafc9906c0fb86 Mon Sep 17 00:00:00 2001 From: plegall Date: Tue, 15 Dec 2009 22:53:51 +0000 Subject: merge r4492 from trunk to branch 2.0 Bug 1328 add function to check token git-svn-id: http://piwigo.org/svn/branches/2.0@4501 68402e56-0260-453c-a942-63ccdbb3a9ee --- admin/include/functions.php | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'admin') diff --git a/admin/include/functions.php b/admin/include/functions.php index 66d7b52ec..1538a98ae 100644 --- a/admin/include/functions.php +++ b/admin/include/functions.php @@ -23,6 +23,28 @@ include(PHPWG_ROOT_PATH.'admin/include/functions_metadata.php'); +/** + * check token comming from form posted or get params to prevent csrf attacks + * if pwg_token is empty action doesn't require token + * else pwg_token is compare to server token + * + * @return void access denied if token given is not equal to server token + */ +function check_token() +{ + global $conf; + + $token = hash_hmac('md5', session_id(), $conf['secret_key']); + + if (!empty($_POST['pwg_token']) && ($_POST['pwg_token'] != $token)) + { + access_denied(); + } + elseif (!empty($_GET['pwg_token']) && ($_GET['pwg_token'] != $token)) + { + access_denied(); + } +} // The function delete_site deletes a site and call the function // delete_categories for each primary category of the site -- cgit v1.2.3