main.go 8.9 KB

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