main.go 7.0 KB

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