api_w_raw.go 1.8 KB

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