main.go 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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. "io/ioutil"
  15. "os"
  16. "strings"
  17. "math/rand"
  18. "time"
  19. )
  20. func init() {
  21. rand.Seed(time.Now().UnixNano())
  22. }
  23. var letterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")
  24. func main() {
  25. r := mux.NewRouter()
  26. r.HandleFunc("/", PrinterList)
  27. r.HandleFunc("/generate", GenerateQR)
  28. r.HandleFunc("/generateCompatible", generateCompatible)
  29. r.HandleFunc("/addprinter", AddPrinter)
  30. r.HandleFunc("/addcartridge", AddCartridge)
  31. r.HandleFunc("/cartridgeOfPrinter", AddCartridgeOfPrinter)
  32. r.HandleFunc("/compatible", FindCompatibleCartridges)
  33. r.HandleFunc("/printer/{printerName}", PrinterPage)
  34. fmt.Println("Server is listening...")
  35. http.Handle("/", r)
  36. http.ListenAndServe(":8888", nil)
  37. }
  38. func generateCompatible(w http.ResponseWriter, r *http.Request){
  39. fmt.Println("New generating request from" + r.RemoteAddr)
  40. data, err := ioutil.ReadAll(r.Body)
  41. if err != nil{
  42. fmt.Println("Something went wrong during generating QR code")
  43. fmt.Fprintf(w, "Something went wrong during generating QR code")
  44. }
  45. filename := GenerateRandomString(10)
  46. fmt.Println("Generated name " + filename + " for " + r.RemoteAddr)
  47. generateFromText(string(data), filename)
  48. fmt.Println("Generated file " + filename + ".png for " + r.RemoteAddr)
  49. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", filename +".png"))
  50. http.ServeFile(w, r, filename)
  51. fmt.Println("Served file " + filename + ".png for " + r.RemoteAddr)
  52. os.Remove(filename + ".png")
  53. fmt.Println("Removed file " + filename + ".png")
  54. }
  55. func PrinterPage(w http.ResponseWriter, r *http.Request) {
  56. db, err := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  57. if err != nil {
  58. fmt.Println("Error during opening DB")
  59. } else {
  60. name := mux.Vars(r)["printerName"]
  61. var printer Printers
  62. db.Where("Name = ?", name).First(&printer)
  63. var printers []Printers
  64. db.Find(&printers)
  65. fmt.Println(printer)
  66. if printer.ID > 0 {
  67. var cartridges []string
  68. var cot []Cartridgeofprinter
  69. db.Find(&cot)
  70. db.Where("Printer_Id = ?", printer.ID).Find(&cot)
  71. for _, v := range cot {
  72. var cart Cartridges
  73. if v.Printer_Id == printer.ID{
  74. db.Where("ID = ?", v.Cartridge_Id).First(&cart)
  75. cartridges = append(cartridges, cart.Name)
  76. }
  77. }
  78. data := Output{
  79. PrinterName: name,
  80. Cartridges: cartridges,
  81. }
  82. tmpl, _ := template.ParseFiles("output.html")
  83. tmpl.Execute(w, data)
  84. // fmt.Fprintf(w, "Выбранный принтер: %v\n", name)
  85. // fmt.Fprintf(w, "Совместимые картриджи (" + string(len(cartridges)) + ")\n")
  86. // for _, cartridge := range cartridges{
  87. // fmt.Fprintf(w, cartridge)
  88. // }
  89. } else {
  90. http.Redirect(w, r, "https://www.youtube.com/watch?v=dQw4w9WgXcQ", 301)
  91. }
  92. }
  93. // w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", name + ".png"))
  94. // var cartText = strings.Join(cartridgeName, "\n")
  95. // cartridgeQR(cartText, name)
  96. // http.ServeFile(w, r, name)
  97. }
  98. func FindCompatibleCartridges(w http.ResponseWriter, r *http.Request) {
  99. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  100. var PrinterList []Printers
  101. db.Find(&PrinterList)
  102. var PrinterName []string
  103. for _, pr := range PrinterList {
  104. PrinterName = append(PrinterName, pr.Name)
  105. }
  106. // var printer Printers
  107. r.ParseForm()
  108. selectedPrinter := strings.Join(r.Form["printer"], "")
  109. if selectedPrinter != "" {
  110. // db.Where("Name = ?", selectedPrinter).First(&printer)
  111. // var cops []uint
  112. // db.Table("CartridgeOfPrinters").Where("PrinterID = ?", printer.ID).Select("CartridgeID").Find(&cops)
  113. // var cartridgeName []string
  114. // for _, cop := range cops {
  115. // var cart Cartridges
  116. // db.Where("ID = ?", cop).First(&cart)
  117. // cartridgeName = append(cartridgeName, cart.Name)
  118. // }
  119. // // data := ViewData{
  120. // // Title: "Совместимость картриджей",
  121. // // PrinterNames: PrinterName,
  122. // // CartridgeNames: cartridgeName,
  123. // // }
  124. http.Redirect(w, r, "/printer/"+selectedPrinter, 301)
  125. return
  126. }
  127. data := ViewData{
  128. Title: "Совместимость картриджей",
  129. PrinterNames: PrinterName,
  130. }
  131. tmpl, _ := template.ParseFiles("compatible.html")
  132. tmpl.Execute(w, data)
  133. }
  134. func AddCartridgeOfPrinter(w http.ResponseWriter, r *http.Request) {
  135. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  136. r.ParseForm()
  137. cartridgeName := strings.Join(r.Form["cartridges"], "")
  138. printerName := strings.Join(r.Form["printers"], "")
  139. // printerName := strings.Join(r.Form["printers"], "")
  140. var cartridge Cartridges
  141. db.Where("Name = ?", cartridgeName).First(&cartridge)
  142. cartridgeID := cartridge.ID
  143. var printer Printers
  144. db.Where("Name = ?", printerName).First(&printer)
  145. printerID := printer.ID
  146. var cop Cartridgeofprinter
  147. cop.Cartridge_Id = cartridgeID
  148. cop.Printer_Id = printerID
  149. db.Create(&cop)
  150. http.Redirect(w, r, "/", 302)
  151. }
  152. func AddCartridge(w http.ResponseWriter, r *http.Request) {
  153. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  154. r.ParseForm()
  155. text := strings.Join(r.Form["cartridgeName"], "")
  156. var newCartridge Cartridges
  157. newCartridge.Name = text
  158. db.Create(&newCartridge)
  159. http.Redirect(w, r, "/", 302)
  160. }
  161. func AddPrinter(w http.ResponseWriter, r *http.Request) {
  162. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  163. r.ParseForm()
  164. text := strings.Join(r.Form["printerName"], "")
  165. var newPrinter Printers
  166. newPrinter.Name = text
  167. db.Create(&newPrinter)
  168. http.Redirect(w, r, "/", 302)
  169. }
  170. func GenerateQR(w http.ResponseWriter, r *http.Request) {
  171. r.ParseForm()
  172. text := strings.Join(r.Form["printer"], "")
  173. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", text+".png"))
  174. generateFromText(text, text)
  175. http.ServeFile(w, r, text)
  176. }
  177. func PrinterList(w http.ResponseWriter, r *http.Request) {
  178. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  179. var PrinterList []Printers
  180. db.Find(&PrinterList)
  181. var PrinterName []string
  182. for _, pr := range PrinterList {
  183. PrinterName = append(PrinterName, pr.Name)
  184. }
  185. var CartridgeList []Cartridges
  186. db.Find(&CartridgeList)
  187. var CartridgeName []string
  188. for _, ca := range CartridgeList {
  189. CartridgeName = append(CartridgeName, ca.Name)
  190. }
  191. data := ViewData{
  192. Title: "Generate QR",
  193. PrinterNames: PrinterName,
  194. CartridgeNames: CartridgeName,
  195. }
  196. tmpl, _ := template.ParseFiles("generate.html")
  197. tmpl.Execute(w, data)
  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, filename 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(filename, code)
  226. }
  227. func writePng(filename string, img image.Image) {
  228. file, err := os.Create(filename + ".png")
  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. }
  238. func GenerateRandomString(n int) string {
  239. b := make([]rune, n)
  240. for i := range b {
  241. b[i] = letterRunes[rand.Intn(len(letterRunes))]
  242. }
  243. return string(b)
  244. }