#!/usr/bin/python ######################################################### # ____ ___ __ __ # /\ _`\ __/\_ \ /'__`\ /\ \ # \ \ \/\ \ __ __ __/\_\//\ \ ___ /\ \/\ \ \_\ \ __ ___ _ __ __ __ __ __ # \ \ \ \ \ /'__`\\ \/\ \/\ \\ \ \ /'___\ \ \ \ \ /'_` \ /'__`\ /'___\\`'__\'__`\\ \/\ \/\ \ # \ \ \_\ \\ __/ \ \_/ | \ \\_\ \_/\ \__/\ \ \_\ \\ \L\ \/\ __/ /\ \__/ \ \/\ __/ \ \_/ \_/ \ # \ \____/ \____\ \___/ \ \_\\____\ \____\\ \____/ \___,_\ \____\ \ \____\ \_\ \____\ \___x___/' # \/___/ \/____/\/__/ \/_//____/\/____/ \/___/ \/__,_ /\/____/ \/____/\/_/\/____/\/__//__/ # # Crew Members: bl3ck, stoke, Shellcoder_, n1md4, sys.x4sh, Ax3L, s1y, LostPassword, nex & overmind # # # Author: stoke # # # # # Jamb CMS CSRF Arbitrary add a post # # Jamb can be downloaded here: http://darkjoker.sytes.net/archives/jamb.zip # # Let's see the bugged code: # ---- snip from admin.php ----- """ if ($_GET ['act'] && is_logged () && intval ($_GET['id']) && preg_match ("|http://".$_SERVER['SERVER_NAME'].dirname($_SERVER['PHP_SELF'])."|",$_SERVER['HTTP_REFERER'])) { $id=intval ($_GET['id']); switch ($_GET['act']) { case 'del': $query = "DELETE FROM articles WHERE id = '{$id}'"; mysql_query ($query) or die ("Please edit functions.php!"); $query = "DELETE FROM comments WHERE pid = '{$id}'"; mysql_query ($query); header ("Location: index.php"); die (); break; case 'edit': $newtitle = htmlentities (mysql_real_escape_string ($_POST['newtitle'])); $newart = mysql_real_escape_string ($_POST['newart']); if (!$newtitle || !$newart) { $query = "SELECT * FROM articles WHERE id = '{$id}'"; $res=mysql_query ($query); $row=mysql_fetch_row ($res); if (!$row[0]) die ("Wrong ID"); $row[1]=stripslashes($row[1]); $row[2]=stripslashes ($row[2]); echo "
\n". "Title:
\n". "