api_w_xref.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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_w_xref(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["page"])
  16. num := 0
  17. if page*50 > 0 {
  18. num = page*50 - 50
  19. }
  20. var link_case_insensitive string
  21. err := db.QueryRow(tool.DB_change("select data from other where name = 'link_case_insensitive'")).Scan(&link_case_insensitive)
  22. if err != nil {
  23. if err == sql.ErrNoRows {
  24. link_case_insensitive = ""
  25. } else {
  26. log.Fatal(err)
  27. }
  28. }
  29. if link_case_insensitive != "" {
  30. link_case_insensitive = " collate nocase"
  31. }
  32. var stmt *sql.Stmt
  33. if other_set["do_type"] == "1" {
  34. stmt, err = db.Prepare(tool.DB_change("select distinct link, type from back where title" + link_case_insensitive + " = ? and not type = 'no' and not type = 'nothing' order by type asc, link asc limit ?, 50"))
  35. } else {
  36. stmt, err = db.Prepare(tool.DB_change("select distinct title, type from back where link" + link_case_insensitive + " = ? and not type = 'no' and not type = 'nothing' order by type asc, title asc limit ?, 50"))
  37. }
  38. if err != nil {
  39. log.Fatal(err)
  40. }
  41. defer stmt.Close()
  42. rows, err := stmt.Query(other_set["name"], num)
  43. if err != nil {
  44. log.Fatal(err)
  45. }
  46. defer rows.Close()
  47. data_list := [][]string{}
  48. for rows.Next() {
  49. var name string
  50. var type_data string
  51. err := rows.Scan(&name, &type_data)
  52. if err != nil {
  53. log.Fatal(err)
  54. }
  55. data_list = append(data_list, []string{name, type_data})
  56. }
  57. json_data, _ := json.Marshal(data_list)
  58. return string(json_data)
  59. }