| 1 |
<? |
<?php |
| 2 |
require_once "../lib/db_open.inc.php"; |
require_once "../lib/db_open.inc.php"; |
| 3 |
|
require_once "./section_list.inc.php"; |
| 4 |
require_once "./session_init.inc.php"; |
require_once "./session_init.inc.php"; |
| 5 |
require_once "./theme.inc.php"; |
require_once "./theme.inc.php"; |
| 6 |
|
|
| 25 |
exit(json_encode($result_set)); |
exit(json_encode($result_set)); |
| 26 |
} |
} |
| 27 |
|
|
| 28 |
|
// Load section setting |
| 29 |
$sql = "SELECT * FROM section_config WHERE SID = $sid AND enable"; |
$sql = "SELECT * FROM section_config WHERE SID = $sid AND enable"; |
| 30 |
|
|
| 31 |
$rs = mysqli_query($db_conn, $sql); |
$rs = mysqli_query($db_conn, $sql); |
| 38 |
exit(json_encode($result_set)); |
exit(json_encode($result_set)); |
| 39 |
} |
} |
| 40 |
|
|
| 41 |
if($row = mysqli_fetch_array($rs)) |
if ($row = mysqli_fetch_array($rs)) |
| 42 |
{ |
{ |
| 43 |
$result_set["return"]["data"] = array( |
$result_set["data"] = array( |
| 44 |
"sid" => $sid, |
"sid" => $sid, |
| 45 |
|
"cid" => $row["CID"], |
| 46 |
"sname" => $row["sname"], |
"sname" => $row["sname"], |
| 47 |
"s_title" => $row["title"], |
"title" => $row["title"], |
| 48 |
|
"exp_get" => $row["exp_get"], |
| 49 |
|
"recommend" => $row["recommend"], |
| 50 |
|
"read_user_level" => $row["read_user_level"], |
| 51 |
|
"write_user_level" => $row["write_user_level"], |
| 52 |
"announcement" => $row["announcement"], |
"announcement" => $row["announcement"], |
| 53 |
"comment" => $row["comment"], |
"comment" => $row["comment"], |
| 54 |
"ex_update" => $row["ex_update"], |
"ex_update" => $row["ex_update"], |
| 55 |
"ex_dir" => array(), |
"sort_order" => $row["sort_order"], |
| 56 |
|
"class_sections" => array(), |
| 57 |
|
"section_hierachy" => array(), |
| 58 |
|
"masters" => array(), |
| 59 |
); |
); |
| 60 |
} |
} |
| 61 |
else |
else |
| 69 |
|
|
| 70 |
mysqli_free_result($rs); |
mysqli_free_result($rs); |
| 71 |
|
|
| 72 |
$sql = "SELECT * FROM ex_dir WHERE SID = $sid AND enable ORDER BY dir"; |
// Load section master |
| 73 |
|
$sql = "SELECT section_master.UID, username, major, begin_dt, end_dt FROM section_master |
| 74 |
|
INNER JOIN user_list ON section_master.UID = user_list.UID |
| 75 |
|
WHERE SID = $sid AND section_master.enable AND (NOW() BETWEEN begin_dt AND end_dt) |
| 76 |
|
ORDER BY major DESC, begin_dt ASC, end_dt ASC"; |
| 77 |
|
|
| 78 |
$rs = mysqli_query($db_conn, $sql); |
$rs = mysqli_query($db_conn, $sql); |
| 79 |
if ($rs == false) |
if ($rs == false) |
| 80 |
{ |
{ |
| 81 |
$result_set["return"]["code"] = -2; |
$result_set["return"]["code"] = -2; |
| 82 |
$result_set["return"]["message"] = "Query ex_dir error: " . mysqli_error($db_conn); |
$result_set["return"]["message"] = "Query section master error: " . mysqli_error($db_conn); |
| 83 |
|
|
| 84 |
mysqli_close($db_conn); |
mysqli_close($db_conn); |
| 85 |
exit(json_encode($result_set)); |
exit(json_encode($result_set)); |
| 86 |
} |
} |
| 87 |
|
|
| 88 |
array_push($result_set["return"]["data"]["ex_dir"], array( |
while ($row = mysqli_fetch_array($rs)) |
| 89 |
"dir" => "", |
{ |
| 90 |
"name" => "根目录", |
array_push($result_set["data"]["masters"], array( |
| 91 |
)); |
"uid" => $row["UID"], |
| 92 |
|
"username" => $row["username"], |
| 93 |
|
"major" => $row["major"], |
| 94 |
|
"begin_dt" => $row["begin_dt"], |
| 95 |
|
"end_dt" => $row["end_dt"], |
| 96 |
|
)); |
| 97 |
|
} |
| 98 |
|
mysqli_free_result($rs); |
| 99 |
|
|
| 100 |
|
// Load sections in current class |
| 101 |
|
$sql = "SELECT SID, title, sort_order FROM section_config WHERE CID = " . |
| 102 |
|
$result_set["data"]["cid"] . " AND enable ORDER BY sort_order"; |
| 103 |
|
|
| 104 |
|
$rs = mysqli_query($db_conn, $sql); |
| 105 |
|
if ($rs == false) |
| 106 |
|
{ |
| 107 |
|
$result_set["return"]["code"] = -2; |
| 108 |
|
$result_set["return"]["message"] = "Query section list error: " . mysqli_error($db_conn); |
| 109 |
|
|
| 110 |
|
mysqli_close($db_conn); |
| 111 |
|
exit(json_encode($result_set)); |
| 112 |
|
} |
| 113 |
|
|
| 114 |
while($row = mysqli_fetch_array($rs)) |
while ($row = mysqli_fetch_array($rs)) |
| 115 |
{ |
{ |
| 116 |
array_push($result_set["return"]["data"]["ex_dir"], array( |
array_push($result_set["data"]["class_sections"], array( |
| 117 |
"dir" => $row["dir"], |
"sid" => $row["SID"], |
| 118 |
"name" => $row["name"], |
"title" => $row["title"], |
| 119 |
|
"sort_order" => $row["sort_order"], |
| 120 |
)); |
)); |
| 121 |
} |
} |
| 122 |
mysqli_free_result($rs); |
mysqli_free_result($rs); |
| 123 |
|
|
| 124 |
|
// Load section list |
| 125 |
|
$ret = load_section_list($result_set["data"]["section_hierachy"], |
| 126 |
|
function (array $section, array $filter_param) : bool |
| 127 |
|
{ |
| 128 |
|
return $_SESSION["BBS_priv"]->checkpriv($section["SID"], S_POST | S_MAN_S); |
| 129 |
|
}, |
| 130 |
|
function (array $section, array $filter_param) : mixed |
| 131 |
|
{ |
| 132 |
|
return null; |
| 133 |
|
}, |
| 134 |
|
$db_conn); |
| 135 |
|
|
| 136 |
|
if ($ret == false) |
| 137 |
|
{ |
| 138 |
|
$result_set["return"]["code"] = -2; |
| 139 |
|
$result_set["return"]["message"] = "Query section error: " . mysqli_error($db_conn); |
| 140 |
|
|
| 141 |
|
mysqli_close($db_conn); |
| 142 |
|
exit(json_encode($result_set)); |
| 143 |
|
} |
| 144 |
|
|
| 145 |
mysqli_close($db_conn); |
mysqli_close($db_conn); |
| 146 |
|
|
| 147 |
// Output with theme view |
// Output with theme view |