api_user_watch_list.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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_user_watch_list(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, _ := strconv.Atoi(other_set["num"])
  16. num := 0
  17. if page*50 > 0 {
  18. num = page*50 - 50
  19. }
  20. ip := other_set["ip"]
  21. name := other_set["name"]
  22. if ip != name && tool.Get_user_auth(db, 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("select data from user_set where name = 'star_doc' and id = ? limit ?, 50"))
  29. } else {
  30. stmt, err = db.Prepare(tool.DB_change("select data from user_set where name = 'watchlist' and id = ? limit ?, 50"))
  31. }
  32. if err != nil {
  33. log.Fatal(err)
  34. }
  35. defer stmt.Close()
  36. rows, err := stmt.Query(name, num)
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. defer rows.Close()
  41. data_list := []string{}
  42. for rows.Next() {
  43. var title_data string
  44. err := rows.Scan(&title_data)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. data_list = append(data_list, title_data)
  49. }
  50. return_data := make(map[string]interface{})
  51. return_data["language"] = map[string]string{
  52. "watchlist": tool.Get_language(db, "watchlist", false),
  53. "star_doc": tool.Get_language(db, "star_doc", false),
  54. }
  55. return_data["data"] = data_list
  56. json_data, _ := json.Marshal(return_data)
  57. return string(json_data)
  58. }