api_list_old_page.go 2.1 KB

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