api_w_raw.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package route
  2. import (
  3. "database/sql"
  4. "encoding/json"
  5. "log"
  6. "opennamu/route/tool"
  7. )
  8. func Api_w_raw(call_arg []string) string {
  9. other_set := map[string]string{}
  10. json.Unmarshal([]byte(call_arg[0]), &other_set)
  11. db := tool.DB_connect()
  12. defer db.Close()
  13. if other_set["exist_check"] != "" {
  14. stmt, err := db.Prepare(tool.DB_change("select title from data where title = ?"))
  15. if err != nil {
  16. log.Fatal(err)
  17. }
  18. defer stmt.Close()
  19. new_data := map[string]string{}
  20. var title string
  21. err = stmt.QueryRow(other_set["name"]).Scan(&title)
  22. if err != nil {
  23. if err == sql.ErrNoRows {
  24. } else {
  25. log.Fatal(err)
  26. }
  27. } else {
  28. new_data["exist"] = "1"
  29. }
  30. json_data, _ := json.Marshal(new_data)
  31. return string(json_data)
  32. } else {
  33. new_data := map[string]string{}
  34. var data string
  35. if other_set["rev"] != "" {
  36. stmt, err := db.Prepare(tool.DB_change("select data from history where title = ? and id = ?"))
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. defer stmt.Close()
  41. err = stmt.QueryRow(other_set["name"], other_set["rev"]).Scan(&data)
  42. if err != nil {
  43. if err == sql.ErrNoRows {
  44. } else {
  45. log.Fatal(err)
  46. }
  47. } else {
  48. new_data["title"] = other_set["name"]
  49. new_data["data"] = data
  50. }
  51. json_data, _ := json.Marshal(new_data)
  52. return string(json_data)
  53. } else {
  54. stmt, err := db.Prepare(tool.DB_change("select data from data where title = ?"))
  55. if err != nil {
  56. log.Fatal(err)
  57. }
  58. defer stmt.Close()
  59. err = stmt.QueryRow(other_set["name"]).Scan(&data)
  60. if err != nil {
  61. if err == sql.ErrNoRows {
  62. } else {
  63. log.Fatal(err)
  64. }
  65. } else {
  66. new_data["title"] = other_set["name"]
  67. new_data["data"] = data
  68. }
  69. json_data, _ := json.Marshal(new_data)
  70. return string(json_data)
  71. }
  72. }
  73. }