api_w_watch_list.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package route
  2. import (
  3. "database/sql"
  4. "encoding/json"
  5. "log"
  6. "opennamu/route/tool"
  7. "strconv"
  8. )
  9. func Api_w_watch_list(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. page, _ := strconv.Atoi(other_set["num"])
  15. num := 0
  16. if page*50 > 0 {
  17. num = page*50 - 50
  18. }
  19. db := tool.DB_connect(db_set)
  20. defer db.Close()
  21. ip := other_set["ip"]
  22. if tool.Get_user_auth(db, db_set, ip) == "" {
  23. return "{}"
  24. }
  25. var stmt *sql.Stmt
  26. var err error
  27. if other_set["do_type"] == "star_doc" {
  28. stmt, err = db.Prepare(tool.DB_change(db_set, "select id from user_set where name = 'star_doc' and data = ? limit ?, 50"))
  29. } else {
  30. stmt, err = db.Prepare(tool.DB_change(db_set, "select id from user_set where name = 'watchlist' and data = ? limit ?, 50"))
  31. }
  32. if err != nil {
  33. log.Fatal(err)
  34. }
  35. defer stmt.Close()
  36. rows, err := stmt.Query(other_set["name"], num)
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. defer rows.Close()
  41. var data_list []string
  42. for rows.Next() {
  43. var user_name string
  44. err := rows.Scan(&user_name)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. data_list = append(data_list, user_name)
  49. }
  50. if len(data_list) == 0 {
  51. return "{}"
  52. } else {
  53. json_data, _ := json.Marshal(data_list)
  54. return string(json_data)
  55. }
  56. }