123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- package workers
- import (
- "context"
- "fmt"
- "image"
- "image/color"
- "io/ioutil"
- "os"
- "path/filepath"
- "strings"
- "time"
- "golang-fave/engine/config"
- "golang-fave/engine/utils"
- "github.com/disintegration/imaging"
- "github.com/vladimirok5959/golang-worker/worker"
- )
- func ImageGenerator(www_dir string) *worker.Worker {
- return worker.New(func(ctx context.Context, w *worker.Worker, o *[]worker.Iface) {
- if www_dir, ok := (*o)[0].(string); ok {
- image_loop(ctx, www_dir)
- }
- select {
- case <-ctx.Done():
- case <-time.After(1 * time.Second):
- return
- }
- }, &[]worker.Iface{
- www_dir,
- })
- }
- func image_loop(ctx context.Context, www_dir string) {
- if dirs, err := ioutil.ReadDir(www_dir); err == nil {
- for _, dir := range dirs {
- trigger := strings.Join([]string{www_dir, dir.Name(), "tmp", "trigger.img.run"}, string(os.PathSeparator))
- if utils.IsFileExists(trigger) {
- processed := false
- conf := config.ConfigNew()
- if err := conf.ConfigRead(strings.Join([]string{www_dir, dir.Name(), "config", "config.json"}, string(os.PathSeparator))); err == nil {
- target_dir := strings.Join([]string{www_dir, dir.Name(), "htdocs", "products", "images"}, string(os.PathSeparator))
- if utils.IsDirExists(target_dir) {
- pattern := target_dir + string(os.PathSeparator) + "*" + string(os.PathSeparator) + "*.*"
- if files, err := filepath.Glob(pattern); err == nil {
- for _, file := range files {
- select {
- case <-ctx.Done():
- return
- default:
- if image_detect(ctx, www_dir, file, conf) {
- if !processed {
- processed = true
- }
- }
- }
- }
- }
- }
- }
- if !processed {
- os.Remove(trigger)
- }
- }
- }
- }
- }
- func image_detect(ctx context.Context, www, file string, conf *config.Config) bool {
- result := false
- index := strings.LastIndex(file, string(os.PathSeparator))
- if index != -1 {
- file_name := file[index+1:]
- if !strings.HasPrefix(file_name, "thumb-") {
- file_thumb_0 := file[:index+1] + "thumb-0-" + file_name
- file_thumb_1 := file[:index+1] + "thumb-1-" + file_name
- file_thumb_2 := file[:index+1] + "thumb-2-" + file_name
- file_thumb_3 := file[:index+1] + "thumb-3-" + file_name
- file_thumb_full := file[:index+1] + "thumb-full-" + file_name
- if !utils.IsFileExists(file_thumb_0) {
- image_create(ctx, www, file, file_thumb_0, "thumb-0", conf)
- result = true
- }
- if !utils.IsFileExists(file_thumb_1) {
- image_create(ctx, www, file, file_thumb_1, "thumb-1", conf)
- result = true
- }
- if !utils.IsFileExists(file_thumb_2) {
- image_create(ctx, www, file, file_thumb_2, "thumb-2", conf)
- result = true
- }
- if !utils.IsFileExists(file_thumb_3) {
- image_create(ctx, www, file, file_thumb_3, "thumb-3", conf)
- result = true
- }
- if !utils.IsFileExists(file_thumb_full) {
- image_create(ctx, www, file, file_thumb_full, "thumb-full", conf)
- result = true
- }
- }
- }
- return result
- }
- func image_create(ctx context.Context, www, src, dst, typ string, conf *config.Config) {
- width := (*conf).Shop.Thumbnails.Thumbnail0[0]
- height := (*conf).Shop.Thumbnails.Thumbnail0[1]
- resize := 0
- if typ == "thumb-1" {
- width = (*conf).Shop.Thumbnails.Thumbnail1[0]
- height = (*conf).Shop.Thumbnails.Thumbnail1[1]
- resize = (*conf).Shop.Thumbnails.Thumbnail1[2]
- } else if typ == "thumb-2" {
- width = (*conf).Shop.Thumbnails.Thumbnail2[0]
- height = (*conf).Shop.Thumbnails.Thumbnail2[1]
- resize = (*conf).Shop.Thumbnails.Thumbnail2[2]
- } else if typ == "thumb-3" {
- width = (*conf).Shop.Thumbnails.Thumbnail3[0]
- height = (*conf).Shop.Thumbnails.Thumbnail3[1]
- resize = (*conf).Shop.Thumbnails.Thumbnail3[2]
- } else if typ == "thumb-full" {
- width = (*conf).Shop.Thumbnails.ThumbnailFull[0]
- height = (*conf).Shop.Thumbnails.ThumbnailFull[1]
- resize = (*conf).Shop.Thumbnails.ThumbnailFull[2]
- }
- image_generate(ctx, width, height, resize, src, dst)
- }
- func image_generate(ctx context.Context, width, height int, resize int, fsrc, fdst string) {
- src, err := imaging.Open(fsrc)
- if err == nil {
- if resize == 0 {
- src = imaging.Fill(src, width, height, imaging.Center, imaging.Lanczos)
- if err := imaging.Save(src, fdst); err != nil {
- fmt.Printf("Image generation error (1): %v\n", err)
- }
- } else if resize == 1 {
- src = imaging.Fit(src, width, height, imaging.Lanczos)
- if err := imaging.Save(src, fdst); err != nil {
- fmt.Printf("Image generation error (2): %v\n", err)
- }
- } else {
- src = imaging.Fit(src, width, height, imaging.Lanczos)
- dst := imaging.New(width, height, color.NRGBA{255, 255, 255, 255})
- x := 0
- y := 0
- if src.Bounds().Dx() < width {
- x = int((width - src.Bounds().Dx()) / 2)
- }
- if src.Bounds().Dy() < height {
- y = int((height - src.Bounds().Dy()) / 2)
- }
- dst = imaging.Paste(dst, src, image.Pt(x, y))
- if err := imaging.Save(dst, fdst); err != nil {
- fmt.Printf("Image generation error (3): %v\n", err)
- }
- return
- }
- }
- }
|