main.go 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. package main
  2. import (
  3. "fmt"
  4. "github.com/boombuler/barcode"
  5. "github.com/boombuler/barcode/qr"
  6. "github.com/gorilla/mux"
  7. "gorm.io/driver/sqlite"
  8. "gorm.io/gorm"
  9. "html/template"
  10. "image"
  11. "image/png"
  12. "log"
  13. "net/http"
  14. "os"
  15. "strings"
  16. )
  17. func main() {
  18. r := mux.NewRouter()
  19. r.HandleFunc("/", PrinterList)
  20. r.HandleFunc("/generate", GenerateQR)
  21. r.HandleFunc("/addprinter", AddPrinter)
  22. r.HandleFunc("/addcartridge", AddCartridge)
  23. r.HandleFunc("/cartridgeOfPrinter", AddCartridgeOfPrinter)
  24. r.HandleFunc("/compatible", FindCompatibleCartridges)
  25. r.HandleFunc("/printer/{printerName}", PrinterPage)
  26. fmt.Println("Server is listening...")
  27. http.Handle("/", r)
  28. http.ListenAndServe(":8888", nil)
  29. }
  30. func PrinterPage(w http.ResponseWriter, r *http.Request) {
  31. db, err := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  32. if err != nil {
  33. fmt.Println("Error during opening DB")
  34. } else {
  35. name := mux.Vars(r)["printerName"]
  36. fmt.Println("Selected printer: " + name)
  37. var printer Printers
  38. db.Where("Name LIKE ?", name).First(&printer)
  39. var printers []Printers
  40. db.Find(&printers)
  41. fmt.Println(printers)
  42. fmt.Println(printer)
  43. if printer.Id > 0 {
  44. var cartridges []string
  45. var cot []Cartridgeofprinter
  46. db.Where("PrinterID = ?", printer.Id).Find(&cot)
  47. fmt.Println(cot)
  48. fmt.Println("Printer ID = ")
  49. fmt.Println(printer.Id)
  50. for _, v := range cot {
  51. var cart Cartridges
  52. if v.Cartridgeid != 0{
  53. fmt.Println(v.Cartridgeid)
  54. db.Where("ID = ?", v.Cartridgeid).First(&cart)
  55. cartridges = append(cartridges, cart.Name)
  56. }
  57. }
  58. data := Output{
  59. PrinterName: name,
  60. Cartridges: cartridges,
  61. }
  62. tmpl, _ := template.ParseFiles("output.html")
  63. tmpl.Execute(w, data)
  64. // fmt.Fprintf(w, "Выбранный принтер: %v\n", name)
  65. // fmt.Fprintf(w, "Совместимые картриджи (" + string(len(cartridges)) + ")\n")
  66. // for _, cartridge := range cartridges{
  67. // fmt.Fprintf(w, cartridge)
  68. // }
  69. } else {
  70. http.Redirect(w, r, "https://www.youtube.com/watch?v=dQw4w9WgXcQ", 301)
  71. }
  72. }
  73. // w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", name + ".png"))
  74. // var cartText = strings.Join(cartridgeName, "\n")
  75. // cartridgeQR(cartText, name)
  76. // http.ServeFile(w, r, name)
  77. }
  78. func FindCompatibleCartridges(w http.ResponseWriter, r *http.Request) {
  79. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  80. var PrinterList []Printers
  81. db.Find(&PrinterList)
  82. var PrinterName []string
  83. for _, pr := range PrinterList {
  84. PrinterName = append(PrinterName, pr.Name)
  85. }
  86. var printer Printers
  87. r.ParseForm()
  88. selectedPrinter := strings.Join(r.Form["printer"], "")
  89. fmt.Println("Selected: " + selectedPrinter)
  90. if selectedPrinter != "" {
  91. db.Where("Name = ?", selectedPrinter).First(&printer)
  92. var cops []uint
  93. db.Table("CartridgeOfPrinters").Where("PrinterID = ?", printer.Id).Select("CartridgeID").Find(&cops)
  94. var cartridgeName []string
  95. for _, cop := range cops {
  96. var cart Cartridges
  97. db.Where("ID = ?", cop).First(&cart)
  98. cartridgeName = append(cartridgeName, cart.Name)
  99. }
  100. // data := ViewData{
  101. // Title: "Совместимость картриджей",
  102. // PrinterNames: PrinterName,
  103. // CartridgeNames: cartridgeName,
  104. // }
  105. http.Redirect(w, r, "/printer/"+selectedPrinter, 301)
  106. return
  107. }
  108. data := ViewData{
  109. Title: "Совместимость картриджей",
  110. PrinterNames: PrinterName,
  111. }
  112. tmpl, _ := template.ParseFiles("compatible.html")
  113. tmpl.Execute(w, data)
  114. }
  115. func AddCartridgeOfPrinter(w http.ResponseWriter, r *http.Request) {
  116. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  117. r.ParseForm()
  118. cartridgeName := strings.Join(r.Form["cartridges"], "")
  119. printerName := strings.Join(r.Form["printers"], "")
  120. // printerName := strings.Join(r.Form["printers"], "")
  121. var cartridge Cartridges
  122. db.Where("Name = ?", cartridgeName).First(&cartridge)
  123. cartridgeID := cartridge.Id
  124. var printer Printers
  125. db.Where("Name = ?", printerName).First(&printer)
  126. printerID := printer.Id
  127. var cop Cartridgeofprinter
  128. cop.Cartridgeid = cartridgeID
  129. cop.Printerid = printerID
  130. db.Create(&cop)
  131. http.Redirect(w, r, "/", 302)
  132. }
  133. func AddCartridge(w http.ResponseWriter, r *http.Request) {
  134. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  135. r.ParseForm()
  136. text := strings.Join(r.Form["cartridgeName"], "")
  137. var newCartridge Cartridges
  138. newCartridge.Name = text
  139. db.Create(&newCartridge)
  140. http.Redirect(w, r, "/", 302)
  141. }
  142. func AddPrinter(w http.ResponseWriter, r *http.Request) {
  143. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  144. r.ParseForm()
  145. text := strings.Join(r.Form["printerName"], "")
  146. var newPrinter Printers
  147. newPrinter.Name = text
  148. db.Create(&newPrinter)
  149. http.Redirect(w, r, "/", 302)
  150. }
  151. func GenerateQR(w http.ResponseWriter, r *http.Request) {
  152. r.ParseForm()
  153. text := strings.Join(r.Form["printer"], "")
  154. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", text+".png"))
  155. generateFromText(text)
  156. http.ServeFile(w, r, text)
  157. }
  158. func PrinterList(w http.ResponseWriter, r *http.Request) {
  159. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  160. var PrinterList []Printers
  161. db.Find(&PrinterList)
  162. var PrinterName []string
  163. for _, pr := range PrinterList {
  164. PrinterName = append(PrinterName, pr.Name)
  165. }
  166. var CartridgeList []Cartridges
  167. db.Find(&CartridgeList)
  168. var CartridgeName []string
  169. for _, ca := range CartridgeList {
  170. CartridgeName = append(CartridgeName, ca.Name)
  171. }
  172. data := ViewData{
  173. Title: "Generate QR",
  174. PrinterNames: PrinterName,
  175. CartridgeNames: CartridgeName,
  176. }
  177. tmpl, _ := template.ParseFiles("generate.html")
  178. tmpl.Execute(w, data)
  179. }
  180. func generateCompatibleCartridges(printer Printers) {
  181. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  182. var cops []Cartridgeofprinter
  183. var cartridges []Cartridges
  184. db.Where("Printerid = ?", printer.Id).Find(&cops)
  185. for _, cop := range cops {
  186. var cartridge Cartridges
  187. fmt.Println(cop.Cartridgeid)
  188. db.Where("ID = ?", cop.Cartridgeid).First(&cartridge)
  189. cartridges = append(cartridges, cartridge)
  190. }
  191. }
  192. func cartridgeQR(text string, filename string) {
  193. code, err := qr.Encode(text, qr.L, qr.Auto)
  194. if err != nil {
  195. fmt.Println("Something went wrong...")
  196. }
  197. if text != code.Content() {
  198. log.Fatal("data differs")
  199. }
  200. code, err = barcode.Scale(code, 512, 512)
  201. if err != nil {
  202. log.Fatal(err)
  203. }
  204. writePng(filename, code)
  205. }
  206. func generateFromText(text string) {
  207. code, err := qr.Encode(text, qr.L, qr.Auto)
  208. if err != nil {
  209. fmt.Println("Something went wrong...")
  210. }
  211. if text != code.Content() {
  212. log.Fatal("data differs")
  213. }
  214. code, err = barcode.Scale(code, 512, 512)
  215. if err != nil {
  216. log.Fatal(err)
  217. }
  218. writePng(text, code)
  219. }
  220. func writePng(filename string, img image.Image) {
  221. file, err := os.Create(filename)
  222. if err != nil {
  223. log.Fatal(err)
  224. }
  225. err = png.Encode(file, img)
  226. if err != nil {
  227. log.Fatal(err)
  228. }
  229. file.Close()
  230. }