api_topic_list.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package route
  2. import (
  3. "encoding/json"
  4. "log"
  5. "opennamu/route/tool"
  6. "strconv"
  7. )
  8. func Api_topic_list(call_arg []string) string {
  9. db_set := map[string]string{}
  10. json.Unmarshal([]byte(call_arg[0]), &db_set)
  11. other_set := map[string]string{}
  12. json.Unmarshal([]byte(call_arg[1]), &other_set)
  13. db := tool.DB_connect(db_set)
  14. defer db.Close()
  15. page_int, err := strconv.Atoi(other_set["num"])
  16. if err != nil {
  17. log.Fatal(err)
  18. }
  19. if page_int > 0 {
  20. page_int = (page_int * 50) - 50
  21. } else {
  22. page_int = 0
  23. }
  24. stmt, err := db.Prepare(tool.DB_change(db_set, "select code, sub, stop, agree from rd where title = ? order by sub asc limit ?, 50"))
  25. if err != nil {
  26. log.Fatal(err)
  27. }
  28. defer stmt.Close()
  29. rows, err := stmt.Query(other_set["name"], page_int)
  30. if err != nil {
  31. log.Fatal(err)
  32. }
  33. defer rows.Close()
  34. var data_list [][]string
  35. for rows.Next() {
  36. var code string
  37. var sub string
  38. var stop string
  39. var agree string
  40. err := rows.Scan(&code, &sub, &stop, &agree)
  41. if err != nil {
  42. log.Fatal(err)
  43. }
  44. data_list = append(data_list, []string{code, sub, stop, agree})
  45. }
  46. return_data := make(map[string]interface{})
  47. return_data["language"] = map[string]string{}
  48. if len(data_list) == 0 {
  49. return_data["data"] = map[string]string{}
  50. } else {
  51. return_data["data"] = data_list
  52. }
  53. json_data, _ := json.Marshal(return_data)
  54. return string(json_data)
  55. }