api_list_old_page.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package route
  2. import (
  3. "database/sql"
  4. "encoding/json"
  5. "log"
  6. "opennamu/route/tool"
  7. "strconv"
  8. )
  9. func Api_list_old_page(call_arg []string) string {
  10. db_set := map[string]string{}
  11. json.Unmarshal([]byte(call_arg[0]), &db_set)
  12. other_set := map[string]string{}
  13. json.Unmarshal([]byte(call_arg[1]), &other_set)
  14. db := tool.DB_connect(db_set)
  15. defer db.Close()
  16. page_int, err := strconv.Atoi(other_set["num"])
  17. if err != nil {
  18. log.Fatal(err)
  19. }
  20. if page_int > 0 {
  21. page_int = (page_int * 50) - 50
  22. } else {
  23. page_int = 0
  24. }
  25. var stmt *sql.Stmt
  26. if other_set["set_type"] == "old" {
  27. stmt, err = db.Prepare(tool.DB_change(db_set, "select doc_name, set_data from data_set where set_name = 'last_edit' and doc_rev = '' and not (doc_name) in (select doc_name from data_set where set_name = 'doc_type' and set_data != '') order by set_data asc limit ?, 50"))
  28. } else {
  29. stmt, err = db.Prepare(tool.DB_change(db_set, "select doc_name, set_data from data_set where set_name = 'last_edit' and doc_rev = '' and not (doc_name) in (select doc_name from data_set where set_name = 'doc_type' and set_data != '') order by set_data desc limit ?, 50"))
  30. }
  31. if err != nil {
  32. log.Fatal(err)
  33. }
  34. defer stmt.Close()
  35. rows, err := stmt.Query(page_int)
  36. if err != nil {
  37. log.Fatal(err)
  38. }
  39. defer rows.Close()
  40. var data_list [][]string
  41. for rows.Next() {
  42. var doc_name string
  43. var date string
  44. err := rows.Scan(&doc_name, &date)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. stmt, err = db.Prepare(tool.DB_change(db_set, "select set_data from data_set where doc_name = ? and set_name = 'doc_type'"))
  49. if err != nil {
  50. log.Fatal(err)
  51. }
  52. defer stmt.Close()
  53. data_list = append(data_list, []string{doc_name, date})
  54. }
  55. return_data := make(map[string]interface{})
  56. if len(data_list) == 0 {
  57. return_data["data"] = map[string]string{}
  58. } else {
  59. return_data["data"] = data_list
  60. }
  61. json_data, _ := json.Marshal(return_data)
  62. return string(json_data)
  63. }