api_w_raw.go 1.9 KB

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