api_list_old_page.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package route
  2. import (
  3. "database/sql"
  4. "log"
  5. "opennamu/route/tool"
  6. "strconv"
  7. jsoniter "github.com/json-iterator/go"
  8. )
  9. func Api_list_old_page(call_arg []string) string {
  10. var json = jsoniter.ConfigCompatibleWithStandardLibrary
  11. other_set := map[string]string{}
  12. json.Unmarshal([]byte(call_arg[0]), &other_set)
  13. db := tool.DB_connect()
  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. var stmt *sql.Stmt
  25. if other_set["set_type"] == "old" {
  26. stmt, err = db.Prepare(tool.DB_change("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"))
  27. } else {
  28. stmt, err = db.Prepare(tool.DB_change("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"))
  29. }
  30. if err != nil {
  31. log.Fatal(err)
  32. }
  33. defer stmt.Close()
  34. rows, err := stmt.Query(page_int)
  35. if err != nil {
  36. log.Fatal(err)
  37. }
  38. defer rows.Close()
  39. data_list := [][]string{}
  40. for rows.Next() {
  41. var doc_name string
  42. var date string
  43. err := rows.Scan(&doc_name, &date)
  44. if err != nil {
  45. log.Fatal(err)
  46. }
  47. stmt, err = db.Prepare(tool.DB_change("select set_data from data_set where doc_name = ? and set_name = 'doc_type'"))
  48. if err != nil {
  49. log.Fatal(err)
  50. }
  51. defer stmt.Close()
  52. data_list = append(data_list, []string{doc_name, date})
  53. }
  54. return_data := make(map[string]interface{})
  55. return_data["data"] = data_list
  56. json_data, _ := json.Marshal(return_data)
  57. return string(json_data)
  58. }