api_w_watch_list.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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. other_set := map[string]string{}
  11. json.Unmarshal([]byte(call_arg[0]), &other_set)
  12. page, _ := strconv.Atoi(other_set["num"])
  13. num := 0
  14. if page*50 > 0 {
  15. num = page*50 - 50
  16. }
  17. db := tool.DB_connect()
  18. defer db.Close()
  19. if tool.Get_user_auth(db, other_set["ip"]) == "" {
  20. return "{}"
  21. }
  22. var stmt *sql.Stmt
  23. var err error
  24. if other_set["do_type"] == "star_doc" {
  25. stmt, err = db.Prepare(tool.DB_change("select id from user_set where name = 'star_doc' and data = ? limit ?, 50"))
  26. } else {
  27. stmt, err = db.Prepare(tool.DB_change("select id from user_set where name = 'watchlist' and data = ? limit ?, 50"))
  28. }
  29. if err != nil {
  30. log.Fatal(err)
  31. }
  32. defer stmt.Close()
  33. rows, err := stmt.Query(other_set["name"], num)
  34. if err != nil {
  35. log.Fatal(err)
  36. }
  37. defer rows.Close()
  38. data_list := [][]string{}
  39. ip_parser_temp := map[string][]string{}
  40. for rows.Next() {
  41. var user_name string
  42. err := rows.Scan(&user_name)
  43. if err != nil {
  44. log.Fatal(err)
  45. }
  46. var ip_pre string
  47. var ip_render string
  48. if _, ok := ip_parser_temp[user_name]; ok {
  49. ip_pre = ip_parser_temp[user_name][0]
  50. ip_render = ip_parser_temp[user_name][1]
  51. } else {
  52. ip_pre = tool.IP_preprocess(db, user_name, other_set["ip"])[0]
  53. ip_render = tool.IP_parser(db, user_name, other_set["ip"])
  54. ip_parser_temp[user_name] = []string{ip_pre, ip_render}
  55. }
  56. data_list = append(data_list, []string{ip_pre, ip_render})
  57. }
  58. return_data := make(map[string]interface{})
  59. return_data["language"] = map[string]string{
  60. "watchlist": tool.Get_language(db, "watchlist", false),
  61. "star_doc": tool.Get_language(db, "star_doc", false),
  62. }
  63. return_data["data"] = data_list
  64. json_data, _ := json.Marshal(return_data)
  65. return string(json_data)
  66. }