api_user_watch_list.go 1.4 KB

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