main.go 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. package main
  2. import (
  3. "strconv"
  4. "fmt"
  5. "github.com/boombuler/barcode"
  6. "github.com/boombuler/barcode/qr"
  7. "github.com/gorilla/mux"
  8. "gorm.io/driver/sqlite"
  9. "gorm.io/gorm"
  10. "html/template"
  11. "image"
  12. "image/png"
  13. "io/ioutil"
  14. "log"
  15. "math/rand"
  16. "net/http"
  17. "os"
  18. "strings"
  19. "time"
  20. )
  21. func init() {
  22. rand.Seed(time.Now().UnixNano())
  23. }
  24. var letterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890")
  25. func main() {
  26. port := os.Getenv("PORT")
  27. r := mux.NewRouter()
  28. r.HandleFunc("/", PrinterList)
  29. r.HandleFunc("/generate", GenerateQR)
  30. r.HandleFunc("/generateCompatible", generateCompatible)
  31. r.HandleFunc("/addprinter", AddPrinter)
  32. r.HandleFunc("/addcartridge", AddCartridge)
  33. r.HandleFunc("/cartridgeOfPrinter", AddCartridgeOfPrinter)
  34. r.HandleFunc("/compatible", FindCompatibleCartridges)
  35. r.HandleFunc("/printer/{printerName}", PrinterPage)
  36. r.HandleFunc("/cartridges", CartridgePage)
  37. r.HandleFunc("/updateCartridge", updateCartridges)
  38. fmt.Println("Server is listening...")
  39. http.Handle("/", r)
  40. http.ListenAndServe(":"+port, nil)
  41. }
  42. func updateCartridges(w http.ResponseWriter, r *http.Request){
  43. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  44. r.ParseForm()
  45. selectedCartridge := strings.Join(r.Form["cartridges"], "")
  46. var cartridge Cartridges
  47. db.Where("Name = ?", selectedCartridge).First(&cartridge)
  48. newQuantity := cartridge.Quantity + strconv.Atoi(r.Form["cartridgeQuantity"])
  49. db.Model(&cartridge).Update("Quantity", newQuantity)
  50. }
  51. func generateCompatible(w http.ResponseWriter, r *http.Request) {
  52. fmt.Println("New generating request from" + r.RemoteAddr)
  53. data, err := ioutil.ReadAll(r.Body)
  54. if err != nil {
  55. fmt.Println("Something went wrong during generating QR code")
  56. fmt.Fprintf(w, "Something went wrong during generating QR code")
  57. }
  58. filename := GenerateRandomString(10)
  59. fmt.Println("Generated name " + filename + " for " + r.RemoteAddr)
  60. generateFromText(string(data), filename)
  61. fmt.Println("Generated file " + filename + ".png for " + r.RemoteAddr)
  62. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", filename+".png"))
  63. http.ServeFile(w, r, filename)
  64. fmt.Println("Served file " + filename + ".png for " + r.RemoteAddr)
  65. os.Remove(filename + ".png")
  66. fmt.Println("Removed file " + filename + ".png")
  67. http.Redirect(w, r, "/", 301)
  68. }
  69. func CartridgePage(w http.ResponseWriter, r *http.Request) {
  70. db, err := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  71. if err != nil {
  72. fmt.Println("Error during opening DB")
  73. } else {
  74. var cartridges []Cartridges
  75. var names []string
  76. db.Find(&cartridges)
  77. for _, v := range cartridges {
  78. qua := fmt.Sprint(v.Quantity)
  79. name := v.Name + ": " + qua
  80. names = append(names, name)
  81. }
  82. data := CartridgesOutput{
  83. Name: names,
  84. }
  85. tmpl, err := template.ParseFiles("cartridges.gohtml")
  86. if err != nil{
  87. fmt.Println("Error parsing files")
  88. fmt.Println(err)
  89. }
  90. tmpl.Execute(w, data)
  91. }
  92. }
  93. func PrinterPage(w http.ResponseWriter, r *http.Request) {
  94. db, err := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  95. if err != nil {
  96. fmt.Println("Error during opening DB")
  97. } else {
  98. name := mux.Vars(r)["printerName"]
  99. var printer Printers
  100. db.Where("Name = ?", name).First(&printer)
  101. var printers []Printers
  102. db.Find(&printers)
  103. fmt.Println(printer)
  104. if printer.ID > 0 {
  105. var cartridges []string
  106. var cot []Cartridgeofprinter
  107. db.Find(&cot)
  108. db.Where("Printer_Id = ?", printer.ID).Find(&cot)
  109. for _, v := range cot {
  110. var cart Cartridges
  111. if v.Printer_Id == printer.ID {
  112. db.Where("ID = ?", v.Cartridge_Id).First(&cart)
  113. cartridges = append(cartridges, cart.Name)
  114. }
  115. }
  116. data := Output{
  117. PrinterName: name,
  118. Cartridges: cartridges,
  119. }
  120. tmpl, _ := template.ParseFiles("output.html")
  121. tmpl.Execute(w, data)
  122. } else {
  123. http.Redirect(w, r, "https://www.youtube.com/watch?v=dQw4w9WgXcQ", 301)
  124. }
  125. }
  126. // w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", name + ".png"))
  127. // var cartText = strings.Join(cartridgeName, "\n")
  128. // cartridgeQR(cartText, name)
  129. // http.ServeFile(w, r, name)
  130. }
  131. func FindCompatibleCartridges(w http.ResponseWriter, r *http.Request) {
  132. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  133. var PrinterList []Printers
  134. db.Find(&PrinterList)
  135. var PrinterName []string
  136. for _, pr := range PrinterList {
  137. PrinterName = append(PrinterName, pr.Name)
  138. }
  139. // var printer Printers
  140. r.ParseForm()
  141. selectedPrinter := strings.Join(r.Form["printer"], "")
  142. if selectedPrinter != "" {
  143. // db.Where("Name = ?", selectedPrinter).First(&printer)
  144. // var cops []uint
  145. // db.Table("CartridgeOfPrinters").Where("PrinterID = ?", printer.ID).Select("CartridgeID").Find(&cops)
  146. // var cartridgeName []string
  147. // for _, cop := range cops {
  148. // var cart Cartridges
  149. // db.Where("ID = ?", cop).First(&cart)
  150. // cartridgeName = append(cartridgeName, cart.Name)
  151. // }
  152. // // data := ViewData{
  153. // // Title: "Совместимость картриджей",
  154. // // PrinterNames: PrinterName,
  155. // // CartridgeNames: cartridgeName,
  156. // // }
  157. http.Redirect(w, r, "/printer/"+selectedPrinter, 301)
  158. return
  159. }
  160. data := ViewData{
  161. Title: "Совместимость картриджей",
  162. PrinterNames: PrinterName,
  163. }
  164. tmpl, _ := template.ParseFiles("compatible.html")
  165. tmpl.Execute(w, data)
  166. }
  167. func AddCartridgeOfPrinter(w http.ResponseWriter, r *http.Request) {
  168. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  169. r.ParseForm()
  170. cartridgeName := strings.Join(r.Form["cartridges"], "")
  171. printerName := strings.Join(r.Form["printers"], "")
  172. // printerName := strings.Join(r.Form["printers"], "")
  173. var cartridge Cartridges
  174. db.Where("Name = ?", cartridgeName).First(&cartridge)
  175. cartridgeID := cartridge.ID
  176. var printer Printers
  177. db.Where("Name = ?", printerName).First(&printer)
  178. printerID := printer.ID
  179. var cop Cartridgeofprinter
  180. cop.Cartridge_Id = cartridgeID
  181. cop.Printer_Id = printerID
  182. db.Create(&cop)
  183. http.Redirect(w, r, "/", 302)
  184. }
  185. func AddCartridge(w http.ResponseWriter, r *http.Request) {
  186. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  187. r.ParseForm()
  188. text := strings.Join(r.Form["cartridgeName"], "")
  189. var newCartridge Cartridges
  190. newCartridge.Name = text
  191. db.Create(&newCartridge)
  192. http.Redirect(w, r, "/", 302)
  193. }
  194. func AddPrinter(w http.ResponseWriter, r *http.Request) {
  195. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  196. r.ParseForm()
  197. text := strings.Join(r.Form["printerName"], "")
  198. var newPrinter Printers
  199. newPrinter.Name = text
  200. db.Create(&newPrinter)
  201. http.Redirect(w, r, "/", 302)
  202. }
  203. func GenerateQR(w http.ResponseWriter, r *http.Request) {
  204. r.ParseForm() // Получение имени принтера
  205. text := strings.Join(r.Form["printer"], "")
  206. GenerateFromWeb(w, r, text)
  207. }
  208. func GenerateFromWeb(w http.ResponseWriter, r *http.Request, printerName string) {
  209. qrtext := "https://printers-ttit.herokuapp.com/printer/" + printerName // Генерация URL
  210. fmt.Println("Generating QR code with text: " + qrtext + " for " + r.RemoteAddr)
  211. filename := GenerateRandomString(10) // Генерация имени файла
  212. fmt.Println("Generated filename " + filename + " for " + r.RemoteAddr)
  213. err := generateFromText(qrtext, filename) // qrtext - текст в QR, filename - имя файла
  214. if err != nil {
  215. fmt.Println(err)
  216. }
  217. fmt.Println("Setting header Content-Disposition for " + r.RemoteAddr)
  218. w.Header().Set("Content-Disposition", fmt.Sprintf("attachment; filename=\"%s\"", filename+".png"))
  219. fmt.Println("Starting serving file for " + r.RemoteAddr)
  220. http.ServeFile(w, r, filename+".png")
  221. }
  222. func generateFromText(text string, filename string) error {
  223. code, err := qr.Encode(text, qr.L, qr.Auto)
  224. if err != nil {
  225. return fmt.Errorf("Error during generating QR code")
  226. }
  227. if text != code.Content() {
  228. return fmt.Errorf("data differs")
  229. }
  230. code, err = barcode.Scale(code, 512, 512)
  231. if err != nil {
  232. return fmt.Errorf("Error during scaling QR code")
  233. }
  234. err = writePng(filename, code)
  235. if err != nil {
  236. return err
  237. }
  238. return nil
  239. }
  240. func writePng(filename string, img image.Image) error {
  241. file, err := os.Create(filename + ".png")
  242. if err != nil {
  243. return fmt.Errorf("Creating file error")
  244. }
  245. err = png.Encode(file, img)
  246. if err != nil {
  247. return fmt.Errorf("PNG file error")
  248. }
  249. file.Close()
  250. return nil
  251. }
  252. func GenerateRandomString(n int) string {
  253. b := make([]rune, n)
  254. for i := range b {
  255. b[i] = letterRunes[rand.Intn(len(letterRunes))]
  256. }
  257. return string(b)
  258. }
  259. func PrinterList(w http.ResponseWriter, r *http.Request) {
  260. db, _ := gorm.Open(sqlite.Open("printer.db"), &gorm.Config{})
  261. var PrinterList []Printers
  262. db.Find(&PrinterList)
  263. var PrinterName []string
  264. for _, pr := range PrinterList {
  265. PrinterName = append(PrinterName, pr.Name)
  266. }
  267. var CartridgeList []Cartridges
  268. db.Find(&CartridgeList)
  269. var CartridgeName []string
  270. for _, ca := range CartridgeList {
  271. CartridgeName = append(CartridgeName, ca.Name)
  272. }
  273. data := ViewData{
  274. Title: "Generate QR",
  275. PrinterNames: PrinterName,
  276. CartridgeNames: CartridgeName,
  277. }
  278. tmpl, _ := template.ParseFiles("generate.html")
  279. tmpl.Execute(w, data)
  280. }
  281. func cartridgeQR(text string, filename string) {
  282. code, err := qr.Encode(text, qr.L, qr.Auto)
  283. if err != nil {
  284. fmt.Println("Something went wrong...")
  285. }
  286. if text != code.Content() {
  287. log.Fatal("data differs")
  288. }
  289. code, err = barcode.Scale(code, 512, 512)
  290. if err != nil {
  291. log.Fatal(err)
  292. }
  293. writePng(filename, code)
  294. }