api_bbs_list.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package route
  2. import (
  3. "database/sql"
  4. "encoding/json"
  5. "log"
  6. "opennamu/route/tool"
  7. )
  8. func bbs_list(db *sql.DB, db_set map[string]string) map[string]string {
  9. rows, err := db.Query(tool.DB_change(db_set, "select set_data, set_id from bbs_set where set_name = 'bbs_name'"))
  10. if err != nil {
  11. log.Fatal(err)
  12. }
  13. defer rows.Close()
  14. data_list := map[string]string{}
  15. for rows.Next() {
  16. var name string
  17. var id string
  18. err := rows.Scan(&name, &id)
  19. if err != nil {
  20. log.Fatal(err)
  21. }
  22. data_list[name] = id
  23. }
  24. return data_list
  25. }
  26. func Api_bbs_list(call_arg []string) string {
  27. db_set := map[string]string{}
  28. json.Unmarshal([]byte(call_arg[0]), &db_set)
  29. db := tool.DB_connect(db_set)
  30. defer db.Close()
  31. data_list := bbs_list(db, db_set)
  32. data_list_sub := map[string][]string{}
  33. for k, v := range data_list {
  34. stmt, err := db.Prepare(tool.DB_change(db_set, "select set_data from bbs_set where set_name = 'bbs_type' and set_id = ?"))
  35. if err != nil {
  36. log.Fatal(err)
  37. }
  38. defer stmt.Close()
  39. var bbs_type string
  40. err = stmt.QueryRow(v).Scan(&bbs_type)
  41. if err != nil {
  42. if err == sql.ErrNoRows {
  43. bbs_type = ""
  44. } else {
  45. log.Fatal(err)
  46. }
  47. }
  48. stmt, err = db.Prepare(tool.DB_change(db_set, "select set_data from bbs_data where set_id = ? and set_name = 'date' order by set_code + 0 desc limit 1"))
  49. if err != nil {
  50. log.Fatal(err)
  51. }
  52. defer stmt.Close()
  53. var bbs_date string
  54. err = stmt.QueryRow(v).Scan(&bbs_date)
  55. if err != nil {
  56. if err == sql.ErrNoRows {
  57. bbs_date = ""
  58. } else {
  59. log.Fatal(err)
  60. }
  61. }
  62. data_list_sub[k] = []string{v, bbs_type, bbs_date}
  63. }
  64. return_data := make(map[string]interface{})
  65. return_data["language"] = map[string]string{
  66. "thread_base": tool.Get_language(db, db_set, "thread_base", false),
  67. "comment_base": tool.Get_language(db, db_set, "comment_base", false),
  68. }
  69. if len(data_list_sub) == 0 {
  70. return_data["data"] = map[string]string{}
  71. } else {
  72. return_data["data"] = data_list_sub
  73. }
  74. json_data, _ := json.Marshal(return_data)
  75. return string(json_data)
  76. }