module.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450
  1. <?php
  2. class module_m extends Model
  3. {
  4. var $sql_ext;
  5. var $psize = 20;
  6. function __construct()
  7. {
  8. parent::Model();
  9. global $_SESSION;
  10. $this->psize = defined("SYS_PSIZE") ? SYS_PSIZE : 20;
  11. }
  12. function module_m()
  13. {
  14. $this->__construct();
  15. }
  16. function set_sql_ext()
  17. {
  18. $this->sql_ext = " FROM ".$this->db->prefix."module m LEFT JOIN ".$this->db->prefix."module_group mg ON(m.group_id=mg.id) WHERE 1=1 ";
  19. }
  20. //加载模块数
  21. //groupid:组ID
  22. //status:状态
  23. function top($groupid="",$status="0")
  24. {
  25. $sql = "SELECT * FROM ".$this->db->prefix."module_group WHERE 1=1 ";
  26. if($status)
  27. {
  28. $sql .= " AND status='1' ";
  29. }
  30. if($groupid)
  31. {
  32. $sql .= " AND id='".$groupid."' ";
  33. $rs = $this->db->get_one($sql);
  34. }
  35. else
  36. {
  37. $sql .= " ORDER BY taxis ASC,id DESC ";
  38. $rs = $this->db->get_all($sql);
  39. }
  40. //读取指定的语言包,以实现后台多语言功能
  41. //$rs = $this->merge_lang($rs,"module_group");
  42. return $rs;
  43. }
  44. //获取默认的左侧模块信息
  45. function left($groupid=0,$status=0)
  46. {
  47. if(!$groupid)
  48. {
  49. return false;
  50. }
  51. $sql = "SELECT * FROM ".$this->db->prefix."module WHERE (group_id='".$groupid."' OR group_id='0') ";
  52. //是否有状态限制
  53. if($status)
  54. {
  55. $sql .= " AND status='1' ";
  56. }
  57. $sql .= " ORDER BY taxis ASC,id DESC ";
  58. $rslist = $this->db->get_all($sql);
  59. if(!$rslist)
  60. {
  61. return false;
  62. }
  63. //$rslist = $this->sys_merge_lang($rslist,"module");
  64. return $rslist;
  65. }
  66. //取得所有的模块
  67. function all_module($status=0,$condition="")
  68. {
  69. $sql = "SELECT * FROM ".$this->db->prefix."module WHERE 1=1 ";
  70. if($status)
  71. {
  72. $sql .= " AND status='1' ";
  73. }
  74. if($condition)
  75. {
  76. $sql .= " AND ".$condition;
  77. }
  78. $sql.= " ORDER BY taxis ASC,id DESC ";
  79. $rslist = $this->db->get_all($sql);
  80. return $rslist;
  81. }
  82. //模块组
  83. function all_module_group()
  84. {
  85. $sql = "SELECT * FROM ".$this->db->prefix."module_group WHERE js_function='' ORDER BY taxis ASC,id DESC";
  86. $rslist = $this->db->get_all($sql);
  87. return $rslist;
  88. }
  89. //取得列表
  90. function get_list($pageid=0,$condition="")
  91. {
  92. $this->condition($condition);
  93. $sql = " SELECT m.*,mg.title g_title ";
  94. $sql.= $this->sql_ext;
  95. $sql.= " ORDER BY mg.taxis ASC,m.taxis ASC,m.id DESC ";
  96. if($pageid<1) $pageid = 1;
  97. $offset = ($pageid-1) * $this->psize;
  98. $sql.= " LIMIT ".$offset.",".$this->psize;
  99. $rslist = $this->db->get_all($sql);
  100. return $rslist;
  101. }
  102. //取得一个条件
  103. function condition($array)
  104. {
  105. $this->set_sql_ext();
  106. if(!$array || !is_array($array))
  107. {
  108. return false;
  109. }
  110. if($array["groupid"])
  111. {
  112. $this->sql_ext .= " AND m.group_id='".$array["groupid"]."' ";
  113. }
  114. foreach($array AS $key=>$value)
  115. {
  116. //如果是语言包,先跳过,等后续再来开发区分语言包的
  117. if($key == "langid")
  118. {
  119. continue;
  120. }
  121. if($key == "groupid")
  122. {
  123. $this->sql_ext .= " AND m.group_id='".$value."'";
  124. continue;
  125. }
  126. if(is_array($value))
  127. {
  128. $string_array = array();
  129. foreach($value AS $k=>$v)
  130. {
  131. $string_array[] = "m.".$k."='".$v."'";
  132. }
  133. $string = implode(" OR ",$string_array);
  134. $this->sql_ext .= " AND ( ".$string." )";
  135. continue;
  136. }
  137. $this->sql_ext .= " AND m.".$key."='".$value."'";
  138. }
  139. return true;
  140. }
  141. //取得总数
  142. function get_count()
  143. {
  144. $sql = "SELECT count(m.id) ".$this->sql_ext;
  145. $total = $this->db->count($sql);
  146. return $total;
  147. }
  148. //设置权限状态
  149. function status($id)
  150. {
  151. $sql = "SELECT status FROM ".$this->db->prefix."module WHERE id='".$id."'";
  152. $rs = $this->db->get_one($sql);
  153. $status = $rs["status"] ? 0 : 1;
  154. $sql = "UPDATE ".$this->db->prefix."module SET status='".$status."' WHERE id='".$id."'";
  155. $this->db->query($sql);
  156. return true;
  157. }
  158. //判断内容是否有内容,返回true表示有内容,false表示没有内容
  159. function if_list($id)
  160. {
  161. if(!$id)
  162. {
  163. return false;
  164. }
  165. $sql = "SELECT id FROM ".$this->db->prefix."list WHERE module_id='".$id."'";
  166. $rs = $this->db->get_one($sql);
  167. if($rs)
  168. {
  169. return true;
  170. }
  171. return false;
  172. }
  173. function if_system_module($id)
  174. {
  175. if(!$id)
  176. {
  177. return false;
  178. }
  179. $sql = "SELECT if_system FROM ".$this->db->prefix."module WHERE id='".$id."'";
  180. $rs = $this->db->get_one($sql);
  181. if($rs["if_system"])
  182. {
  183. return true;
  184. }
  185. else
  186. {
  187. return false;
  188. }
  189. }
  190. function module_id($name)
  191. {
  192. $sql = "SELECT id FROM ".$this->db->prefix."module WHERE identifier='".$name."'";
  193. $rs = $this->db->get_one($sql);
  194. if(!$rs)
  195. {
  196. return false;
  197. }
  198. return $rs["id"];
  199. }
  200. //删除模块操作
  201. function del($id)
  202. {
  203. //删除模块
  204. $sql = "DELETE FROM ".$this->db->prefix."module WHERE id='".$id."'";
  205. $this->db->query($sql);
  206. //删除模块字段
  207. $sql = "DELETE FROM ".$this->db->prefix."module_fields WHERE module_id='".$id."'";
  208. $this->db->query($sql);
  209. return true;
  210. }
  211. //取得一个模块的内容信息
  212. function get_one($id)
  213. {
  214. if(!$id)
  215. {
  216. return false;
  217. }
  218. $sql = "SELECT * FROM ".$this->db->prefix."module WHERE id='".$id."'";
  219. $rs = $this->db->get_one($sql);
  220. //分析模块中的权限
  221. $rs["popedom"] = $rs["popedom"] ? explode(",",$rs["popedom"]) : array();
  222. return $rs;
  223. }
  224. //判断标识符是否使用
  225. function chk_identifier($val)
  226. {
  227. $sql = "SELECT id FROM ".$this->db->prefix."module WHERE identifier='".$val."'";
  228. $rs = $this->db->get_one($sql);
  229. if($rs)
  230. {
  231. return true;
  232. }
  233. else
  234. {
  235. return false;
  236. }
  237. }
  238. //判断标识符是否使用
  239. function chk_identifier2($val,$module_id)
  240. {
  241. $forbidden = array("thumb","picture","ext","list","filename");
  242. //判断该字段是否和核心表中的字段重名,主表
  243. $sql = "SHOW FIELDS FROM ".$this->db->prefix."list";
  244. $rslist = $this->db->get_all($sql);
  245. $idlist = array();
  246. foreach($rslist AS $key=>$value)
  247. {
  248. $idlist[] = $value["Field"];
  249. }
  250. if(in_array($val,$idlist))
  251. {
  252. return true;
  253. }
  254. unset($rslist,$idlist);
  255. //判断模块中是否有相应的标识串,如有则禁止使用
  256. $sql = "SELECT id FROM ".$this->db->prefix."module_fields WHERE identifier='".$val."' AND module_id='".$module_id."'";
  257. $rs = $this->db->get_one($sql);
  258. if($rs)
  259. {
  260. return true;
  261. }
  262. else
  263. {
  264. return false;
  265. }
  266. }
  267. //存储信息
  268. function save($data,$id=0)
  269. {
  270. if($id)
  271. {
  272. $this->db->update_array($data,"module",array("id"=>$id));
  273. return true;
  274. }
  275. else
  276. {
  277. $insert_id = $this->db->insert_array($data,"module");
  278. return $insert_id;
  279. }
  280. }
  281. //读取字段列表,这里不使用分表
  282. function fields_index($module_id,$ifstatus=0)
  283. {
  284. if(!$module_id)
  285. {
  286. return false;
  287. }
  288. $sql = "SELECT * FROM ".$this->db->prefix."module_fields WHERE module_id='".$module_id."' ";
  289. if($ifstatus)
  290. {
  291. $sql .= " AND status='1' ";
  292. }
  293. $sql.= " ORDER BY taxis ASC,id DESC ";
  294. return $this->db->get_all($sql);
  295. }
  296. function fields_index_identifier($mid)
  297. {
  298. $sql = "SELECT identifier,title FROM ".$this->db->prefix."module_fields WHERE module_id='".$mid."'";
  299. return $this->db->get_all($sql,"identifier");
  300. }
  301. //读取某个字段内容
  302. function fields_one($id)
  303. {
  304. if(!$id)
  305. {
  306. return false;
  307. }
  308. $sql = "SELECT * FROM ".$this->db->prefix."module_fields WHERE id='".$id."'";
  309. $rs = $this->db->get_one($sql);
  310. return $rs;
  311. }
  312. //存储信息
  313. function fields_save($data,$id=0)
  314. {
  315. if($id)
  316. {
  317. $this->db->update_array($data,"module_fields",array("id"=>$id));
  318. return true;
  319. }
  320. else
  321. {
  322. $insert_id = $this->db->insert_array($data,"module_fields");
  323. return $insert_id;
  324. }
  325. }
  326. //设置权限状态
  327. function fields_status($id)
  328. {
  329. $sql = "SELECT status FROM ".$this->db->prefix."module_fields WHERE id='".$id."'";
  330. $rs = $this->db->get_one($sql);
  331. $status = $rs["status"] ? 0 : 1;
  332. $sql = "UPDATE ".$this->db->prefix."module_fields SET status='".$status."' WHERE id='".$id."'";
  333. $this->db->query($sql);
  334. return true;
  335. }
  336. //删除模块操作
  337. function fields_del($id)
  338. {
  339. //删除模块字段
  340. $sql = "DELETE FROM ".$this->db->prefix."module_fields WHERE id='".$id."'";
  341. $this->db->query($sql);
  342. return true;
  343. }
  344. //取得input类型
  345. function input_type($langid="zh",$ifuser=false)
  346. {
  347. $sql = "SELECT input,name FROM ".$this->db->prefix."input WHERE 1=1 ";
  348. if($ifuser)
  349. {
  350. $sql .= " AND ifuser='1' ";
  351. }
  352. $sql.= " ORDER BY taxis ASC";
  353. $rs = $this->db->get_all($sql);
  354. if(!$rs)
  355. {
  356. return false;
  357. }
  358. $rslist = array();
  359. foreach($rs AS $key=>$value)
  360. {
  361. $rslist[$value["input"]] = $value["name"];
  362. }
  363. return $rslist;
  364. }
  365. function min_max()
  366. {
  367. $sql = "SELECT min(id) min_id,max(id) max_id FROM ".$this->db->prefix."module WHERE ctrl_init='list' AND if_list='1'";
  368. return $this->db->get_one($sql);
  369. }
  370. function next_mid($mid)
  371. {
  372. $sql = "SELECT id FROM ".$this->db->prefix."module WHERE ctrl_init='list' AND if_list='1' AND id>'".$mid."' ORDER BY id ASC LIMIT 1";
  373. $rs = $this->db->get_one($sql);
  374. if($rs)
  375. {
  376. return $rs["id"];
  377. }
  378. else
  379. {
  380. return false;
  381. }
  382. }
  383. //取得组信息
  384. function group_one($id)
  385. {
  386. $sql = "SELECT * FROM ".$this->db->prefix."module_group WHERE id='".$id."'";
  387. return $this->db->get_one($sql);
  388. }
  389. function group_save($data,$id)
  390. {
  391. if($id)
  392. {
  393. $this->db->update_array($data,"module_group",array("id"=>$id));
  394. return true;
  395. }
  396. else
  397. {
  398. $insert_id = $this->db->insert_array($data,"module_group");
  399. return $insert_id;
  400. }
  401. }
  402. function group_del($id)
  403. {
  404. $sql = "DELETE FROM ".$this->db->prefix."module_group WHERE id='".$id."'";
  405. return $this->db->query($sql);
  406. }
  407. //取得有效的内容模块列表
  408. function module_list($ifcate=1,$condition="")
  409. {
  410. $sql = "SELECT * FROM ".$this->db->prefix."module WHERE ctrl_init='list' AND if_cate='".$ifcate."'";
  411. if($condition)
  412. {
  413. $sql .= " AND ".$condition;
  414. }
  415. $sql .= " ORDER BY taxis ASC,id DESC";
  416. return $this->db->get_all($sql);
  417. }
  418. }
  419. ?>