api_user_watch_list.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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_user_watch_list(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. page, _ := strconv.Atoi(other_set["num"])
  16. num := 0
  17. if page*50 > 0 {
  18. num = page*50 - 50
  19. }
  20. db := tool.DB_connect(db_set)
  21. if db == nil {
  22. return
  23. }
  24. defer db.Close()
  25. ip := other_set["ip"]
  26. name := other_set["name"]
  27. if ip != name && tool.Get_user_auth(db, db_set, ip) == "" {
  28. fmt.Print("{}")
  29. return
  30. }
  31. var stmt *sql.Stmt
  32. var err error
  33. if other_set["do_type"] == "star_doc" {
  34. stmt, err = db.Prepare(tool.DB_change(db_set, "select data from user_set where name = 'star_doc' and id = ? limit ?, 50"))
  35. } else {
  36. stmt, err = db.Prepare(tool.DB_change(db_set, "select data from user_set where name = 'watchlist' and id = ? limit ?, 50"))
  37. }
  38. if err != nil {
  39. log.Fatal(err)
  40. }
  41. defer stmt.Close()
  42. rows, err := stmt.Query(name, num)
  43. if err != nil {
  44. log.Fatal(err)
  45. }
  46. defer rows.Close()
  47. var data_list []string
  48. for rows.Next() {
  49. var title_data string
  50. err := rows.Scan(&title_data)
  51. if err != nil {
  52. log.Fatal(err)
  53. }
  54. data_list = append(data_list, title_data)
  55. }
  56. if len(data_list) == 0 {
  57. fmt.Print("{}")
  58. } else {
  59. json_data, _ := json.Marshal(data_list)
  60. fmt.Print(string(json_data))
  61. }
  62. }