pouet.net/kebby_with_fire_api.php
2013-05-26 20:10:50 +01:00

360 lines
12 KiB
PHP

<?php
//
// kebby_with_fire api for pouet improvement
// as seen on tv: https://github.com/lra/pouet.net/issues/33
//
// gameplan:
// 1) go through all .php's and document use cases as function calls.
// 2) create a json_api.php with those php functions that take arguments and return the json.
// 3) refactor the current user.php and prod.php etc to use them, parsing the json result into the currently used php arrays.
// 4) test if all documented use cases are working ok locally. only then push it live.
// 5) write a json_rpc_api.php with functions that parse a json rpc input call, detect the right call and wrap it to the corresponding function in json_api.php (or port the calls to nodejs/whatever)
// 6) replace all user.php and prod.php again and have them call the json_rpc_api directly?
// 7) refactor v2 to use json_rpc_api calls. open them to authenticated external calls.
// lets take this wonderful opportunity to migrate from the deprecated mysql to mysqli
function connect_mysqli() {
if (!$mysqli) $mysqli = new mysqli($auth['localhost'],$auth['user'],$auth['pass'],$auth['db']);
}
$close_mysqli_automatically = true;
function close_mysqli() {
if ($close_mysqli_automatically && $mysqli) $mysqli->close();
}
//
// account.php
//
// uc_account_1
// get im types
function kbfire_api_get_imtypes() {
connect_mysqli();
$query = 'DESC users im_type';
unset($row);
unset($im_types);
if ($result = $mysqli->query($query)) {
while ($row = $result->fetch_row()) {
//printf ("%s (%s)\n", $row[0], $row[1]);
$reg = "/^enum\('(.*)'\)$/";
$tmp = preg_replace($reg,'\1',$row[1]);
$im_types = preg_split("/[']?,[']?/",$tmp);
}
$result->close();
}
//todo: verify, if db is not utf-8, need to iconv('latin1', 'UTF-8', $tmp); before calling json_encode
close_mysqli();
return json_encode($im_types);
}
//todo: test me
// uc_account_2
// update user
//todo: account.php needs a refactor to make errormessage check independent from query building
// uc_account_3
// select cdc
// SELECT cdc, timelock FROM users_cdcs WHERE user='".$_SESSION["SCENEID_ID"]."'
function kbfire_api_get_cdc_timelock($sceneid) {
connect_mysqli();
$query = 'SELECT cdc, timelock FROM users_cdcs WHERE user=\''.$sceneid.'\'';
unset($row);
unset($output);
if ($result = $mysqli->query($query)) {
while($row = $result->fetch_array(MYSQLI_ASSOC)) {
$output[] = array(
'cdc' => $row['cdc'],
'timelock' => $row['timelock']
);
}
}
$result->close();
return json_encode($output);
}
//todo: test me
// uc_account_4
// update users cdc
// delete from users_cdcs where user=".$_SESSION["SCENEID_ID"];
// insert into users_cdcs set cdc='".$v."', user='".$_SESSION["SCENEID_ID"]."', timelock=CURRENT_DATE";
// uc_account_5
// select banned
// select id from users where level='banned' and lastip='".$_SERVER["REMOTE_ADDR"]."'
// uc_account_6
// insert user
// INSERT users SET
// uc_account_7
// SELECT * FROM users WHERE id='".$_SESSION["SCENEID_ID"]."'"
// uc_account_8
// SELECT cdc, (CURRENT_DATE - timelock) as time, prods.name FROM users_cdcs LEFT JOIN prods ON prods.id = users_cdcs.cdc WHERE user='".$_SESSION["SCENEID_ID"]."'";
//
// add.php
//
// uc_add_1
// SELECT who FROM oneliner ORDER BY quand DESC LIMIT 1";
// uc_add_2
// $query="SELECT message FROM oneliner WHERE who = ".(int)$who." ORDER BY quand DESC LIMIT 1";
// dont forget lastmine output
// uc_add_3
// $query="INSERT INTO oneliner SET who=".$who.", quand=NOW(), message='".addslashes($message)."'";
// uc_add_4
// create_cache_module("onelines", "SELECT oneliner.who,oneliner.message,users.nickname,users.avatar FROM oneliner,users WHERE oneliner.who=users.id ORDER BY oneliner.quand DESC LIMIT 50",0);
// uc_add_5
// SELECT topic FROM bbs_topics ORDER BY lastpost DESC LIMIT 1";
// uc_add_6
// $query="INSERT bbs_topics SET topic='".mysql_real_escape_string($topic)."',category='".(int)$_POST["category"]."',lastpost=NOW(),firstpost=NOW(),userlastpost=".$_SESSION["SCENEID_ID"].",userfirstpost=".$_SESSION["SCENEID_ID"];
// uc_add_7
// $query="INSERT bbs_posts SET topic=".$lastid.",post='".addslashes($message)."',author=".$_SESSION["SCENEID_ID"].",added=NOW()";
// uc_add_8
// $query="SELECT author,topic,post FROM bbs_posts ORDER BY added DESC LIMIT 1";
// uc_add_9
// $query="SELECT id FROM bbs_topics where id=".$which;
// uc_add_10
// $query="SELECT count(0) FROM bbs_posts WHERE topic=".$which;
// uc_add_11
// $query="UPDATE bbs_topics SET lastpost=NOW(),count=".$count.",userlastpost=".$_SESSION["SCENEID_ID"]." WHERE id=".$which;
// uc_add_12
// $query="INSERT bbs_posts SET topic=".$which.",post='".addslashes($message)."',author=".$_SESSION["SCENEID_ID"].",added=NOW()";
// uc_add_13
// $query="SELECT who FROM comments where comment='".addslashes($comment)."' and who=".$_SESSION["SCENEID_ID"]." and which=".$which." ORDER BY quand DESC LIMIT 1";
// uc_add_14
// $query="SELECT count(0) FROM comments WHERE who=".$_SESSION["SCENEID_ID"]." AND which=".$which." AND rating!=0";
// uc_add_15
// $query="INSERT comments SET comment='".addslashes($comment)."',who=".$_SESSION["SCENEID_ID"].",which=".$which.",rating=".$rating.",quand=NOW()";
// uc_add_16
// $query = "SELECT comments.rating,comments.who FROM comments WHERE comments.which='".$which."'";
// uc_add_17
// $query="UPDATE prods SET voteup=".$rulez.", votepig=".$piggie.", votedown=".$sucks.", voteavg='".$avg."' where id=".$which;
// uc_add_18
// $sql = "SELECT prods.id,prods.name,prods.type,prods.group1,prods.group2,prods.group3,comments.who,users.nickname,users.avatar,".
// " g1.name as groupname1,g1.acronym as groupacron1, ".
// " g2.name as groupname2,g2.acronym as groupacron2, ".
// " g3.name as groupname3,g3.acronym as groupacron3, ".
// " GROUP_CONCAT(platforms.name) as platform ".
// " FROM prods ".
// " JOIN comments JOIN prods_platforms JOIN platforms ".
// " LEFT JOIN users ON users.id=comments.who ".
// " LEFT JOIN groups AS g1 ON prods.group1 = g1.id".
// " LEFT JOIN groups AS g2 ON prods.group2 = g2.id".
// " LEFT JOIN groups AS g3 ON prods.group3 = g3.id".
// " AND prods_platforms.prod=prods.id ".
// " AND prods_platforms.platform=platforms.id ".
// " WHERE comments.which=prods.id ".
// " GROUP BY comments.id ".
// " ORDER BY comments.quand DESC LIMIT 20";
// uc_add_19
// create_cache_module("latest_comments", "SELECT prods.id,prods.name,prods.type,prods.group1,prods.group2,prods.group3,comments.who,users.nickname,users.avatar FROM prods JOIN comments LEFT JOIN users ON users.id=comments.who WHERE comments.which=prods.id ORDER BY comments.quand DESC LIMIT 20",1);
// uc_add_20
// create_cache_module("top_demos", "SELECT prods.id, prods.name,prods.type,prods.group1,prods.group2,prods.group3 FROM prods WHERE prods.quand > DATE_SUB(sysdate(),INTERVAL '30' DAY) AND prods.quand < DATE_SUB(sysdate(),INTERVAL '0' DAY) ORDER BY (prods.views/((sysdate()-prods.quand)/100000)+prods.views)*prods.voteavg*prods.voteup desc LIMIT 50",1);
//
// affil.php
//
// uc_affil_1
// $sql = " SELECT *,".
// " p1.id as p1id, ".
// " p1.name as p1name, ".
// " p1.type as p1type, ".
// " p2.id as p2id, ".
// " p2.name as p2name, ".
// " p2.type as p2type, ".
// " affiliatedprods.type as type ".
// " from affiliatedprods ".
// " left join prods as p1 on p1.id = affiliatedprods.original ".
// " left join prods as p2 on p2.id = affiliatedprods.derivative ".
// "";
//
// api/*.php
//
// is this v2.0 stuff?!?
// are any of these beeing used for anything? should they be replaced?
//
// leave for later
// meanwhile poke gargaj for more info
//
//
// awardscandidates.php
//
// dont think this will be needed anymore, not worth porting
//
//
// bbs_del.php
//
// uc_bbs_del_1
// delete bbs
// should deletions also be wrapped in jsonp api?
//
// bbs.php
//
// uc_bbs_1
// $query="SELECT count(0) FROM bbs_topics";
// if ($_GET["categoryfilter"])
// $query.= sprintf(" where bbs_topics.category = %d",$_GET["categoryfilter"]);
//$result=mysql_query($query);
//$nb_topics=mysql_result($result,0);
// uc_bbs_2
//$query="SELECT bbs_topics.id, bbs_topics.topic, bbs_topics.firstpost, bbs_topics.lastpost, bbs_topics.userfirstpost, bbs_topics.userlastpost, bbs_topics.count, bbs_topics.category, users1.nickname as nickname_1, users1.avatar as avatar_1, users2.nickname as nickname_2, users2.avatar as avatar_2 FROM bbs_topics LEFT JOIN users as users2 on users2.id=bbs_topics.userfirstpost LEFT JOIN users as users1 on users1.id=bbs_topics.userlastpost";
//if ($_GET["categoryfilter"])
// $query.= sprintf(" where bbs_topics.category = %d",$_GET["categoryfilter"]);
//switch($order) {
// case "userfirstpost": $query.=" ORDER BY nickname_2, avatar_2, bbs_topics.lastpost //DESC"; break;
// case "firstpost": $query.=" ORDER BY firstpost DESC"; break;
// case "userlastpost": $query.=" ORDER BY nickname_1, avatar_1, bbs_topics.lastpost DESC"; break;
// case "lastpost": $query.=" ORDER BY bbs_topics.lastpost DESC"; break;
// case "count": $query.=" ORDER BY bbs_topics.count DESC"; break;
// case "topic": $query.=" ORDER BY bbs_topics.topic"; break;
// case "category": $query.=" ORDER BY bbs_topics.category"; break;
// default: $query.=" ORDER BY bbs_topics.lastpost DESC"; break;
//}
//$query.=" LIMIT ".(($page-1)*$topics_per_page).",".$topics_per_page;
//$result=mysql_query($query);
//while($tmp=mysql_fetch_assoc($result)) {
// $topics[]=$tmp;
//}
//$sortlink ="bbs.php?";
//if ($_GET["categoryfilter"])
// $sortlink ="categoryfilter=".$_GET["categoryfilter"]."&amp;";
//$sortlink.="order=";
//$pagelink = "bbs.php?order=".$order;
//if ($_GET["categoryfilter"])
// $pagelink .= "&categoryfilter=".$_GET["categoryfilter"]."";
//
// bbses.php
//
// uc_bbses_1
//
// this should probably get seperated into 2 use cases, first being which=id and the second the pattern lookup
//
// if($which) {
// $query = "SELECT bbs2 from bbsesaka WHERE bbs1=".$which;
// $result = mysql_query($query);
// while($tmp=mysql_fetch_array($result)) {
// $bbsesaka[]=$tmp;
// }
// $query="SELECT id,name,sysop,started,closed,phonenumber,telnetip,added,adder FROM bbses WHERE id=".$which;
// for($i=0;$i<count($bbsesaka);$i++) { $query.=" OR id=".$bbsesaka[$i]["bbs2"]; }
// } elseif($pattern) {
// if($pattern=="#") {
// $sqlwhere="(name LIKE '0%')||(name LIKE '1%')||(name LIKE '2%')||(name LIKE '3%')||(name LIKE '4%')||(name LIKE '5%')||(name LIKE '6%')||(name LIKE '7%')||(name LIKE '8%')||(name LIKE '9%')";
// } else {
// $sqlwhere="name LIKE '".$pattern."%'";
// }
// $query="SELECT id,name,phonenumber,telnetip FROM bbses WHERE (".$sqlwhere.") ORDER BY name";
// }
// $result = mysql_query($query);
// while($tmp = mysql_fetch_array($result)) {
// $bbses[]=$tmp;
// }
//
// if($which) {
// //get user who added this bbs
// $query="SELECT id,nickname,avatar FROM users WHERE id=".$bbses[0]["adder"];
// $result=mysql_query($query);
// $myuser=mysql_fetch_array($result);
//
// $query="SELECT prods.id, prods.name, prods.group1, groups.name as group1name from prods LEFT JOIN groups on prods.group1=groups.id WHERE prods.boardID=$which";
// $result = mysql_query($query);
// while($tmp = mysql_fetch_array($result)) {
// $bbstros[]=$tmp;
// }
//
// $query="SELECT affiliatedbbses.group,affiliatedbbses.type,groups.name from affiliatedbbses LEFT JOIN groups on affiliatedbbses.group=groups.id WHERE affiliatedbbses.bbs=$which ORDER BY affiliatedbbses.type, groups.name";
// $result = mysql_query($query);
// while($tmp = mysql_fetch_array($result)) {
// $bbsaffils[]=$tmp;
// }
//
// $query="SELECT * from othernfos WHERE type='bbs' and refid='$which'";
// $result = mysql_query($query);
// while($tmp = mysql_fetch_array($result)) {
// $bbsnfos[]=$tmp;
// }
//
// $query="select platforms.name,platforms.icon from bbses_platforms, platforms where bbses_platforms.bbs='".$which."' and platforms.id=bbses_platforms.platform";
// $result = mysql_query($query);
// while($tmp = mysql_fetch_array($result)) {
// $platforms[]=$tmp;
// }
// }
//
// buttons.php
//
// uc_buttons_1
// $query="SELECT type,img,url,alt FROM buttons WHERE dead = 0 ORDER BY type,RAND()";
// $result=mysql_query($query);
// while($tmp=mysql_fetch_array($result)) {
// $buttons[]=$tmp;
// }
//todo: document usecases of all remaining .php's
?>