mirror of
https://github.com/imgproxy/imgproxy.git
synced 2025-10-10 12:12:40 +02:00
Replace imgagedata.ImageData.meta with format; Add imagedata.NewFromBytesWithFormat
This commit is contained in:
@@ -6,6 +6,7 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/imgproxy/imgproxy/v3/imagemeta"
|
"github.com/imgproxy/imgproxy/v3/imagemeta"
|
||||||
|
"github.com/imgproxy/imgproxy/v3/imagetype"
|
||||||
)
|
)
|
||||||
|
|
||||||
// NewFromBytes creates a new ImageData instance from the provided byte slice.
|
// NewFromBytes creates a new ImageData instance from the provided byte slice.
|
||||||
@@ -17,6 +18,11 @@ func NewFromBytes(b []byte, headers http.Header) (*ImageData, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return NewFromBytesWithFormat(meta.Format(), b, headers)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewFromBytesWithFormat creates a new ImageData instance from the provided format and byte slice.
|
||||||
|
func NewFromBytesWithFormat(format imagetype.Type, b []byte, headers http.Header) (*ImageData, error) {
|
||||||
// Temporary workaround for the old ImageData interface
|
// Temporary workaround for the old ImageData interface
|
||||||
h := make(map[string]string, len(headers))
|
h := make(map[string]string, len(headers))
|
||||||
for k, v := range headers {
|
for k, v := range headers {
|
||||||
@@ -25,7 +31,7 @@ func NewFromBytes(b []byte, headers http.Header) (*ImageData, error) {
|
|||||||
|
|
||||||
return &ImageData{
|
return &ImageData{
|
||||||
data: b,
|
data: b,
|
||||||
meta: meta,
|
format: format,
|
||||||
Headers: h,
|
Headers: h,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
@@ -12,7 +12,6 @@ import (
|
|||||||
|
|
||||||
"github.com/imgproxy/imgproxy/v3/config"
|
"github.com/imgproxy/imgproxy/v3/config"
|
||||||
"github.com/imgproxy/imgproxy/v3/ierrors"
|
"github.com/imgproxy/imgproxy/v3/ierrors"
|
||||||
"github.com/imgproxy/imgproxy/v3/imagemeta"
|
|
||||||
"github.com/imgproxy/imgproxy/v3/imagetype"
|
"github.com/imgproxy/imgproxy/v3/imagetype"
|
||||||
"github.com/imgproxy/imgproxy/v3/security"
|
"github.com/imgproxy/imgproxy/v3/security"
|
||||||
)
|
)
|
||||||
@@ -23,7 +22,7 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type ImageData struct {
|
type ImageData struct {
|
||||||
meta imagemeta.Meta
|
format imagetype.Type
|
||||||
data []byte
|
data []byte
|
||||||
Headers map[string]string
|
Headers map[string]string
|
||||||
|
|
||||||
@@ -41,14 +40,9 @@ func (d *ImageData) Close() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Meta returns the image metadata
|
|
||||||
func (d *ImageData) Meta() imagemeta.Meta {
|
|
||||||
return d.meta
|
|
||||||
}
|
|
||||||
|
|
||||||
// Format returns the image format based on the metadata
|
// Format returns the image format based on the metadata
|
||||||
func (d *ImageData) Format() imagetype.Type {
|
func (d *ImageData) Format() imagetype.Type {
|
||||||
return d.meta.Format()
|
return d.format
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reader returns an io.ReadSeeker for the image data
|
// Reader returns an io.ReadSeeker for the image data
|
||||||
|
@@ -51,7 +51,7 @@ func readAndCheckImage(r io.Reader, contentLength int, secopts security.Options)
|
|||||||
|
|
||||||
return &ImageData{
|
return &ImageData{
|
||||||
data: buf.Bytes(),
|
data: buf.Bytes(),
|
||||||
meta: meta,
|
format: meta.Format(),
|
||||||
cancel: cancel,
|
cancel: cancel,
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
@@ -9,6 +9,7 @@ import (
|
|||||||
"github.com/tdewolff/parse/v2/xml"
|
"github.com/tdewolff/parse/v2/xml"
|
||||||
|
|
||||||
"github.com/imgproxy/imgproxy/v3/imagedata"
|
"github.com/imgproxy/imgproxy/v3/imagedata"
|
||||||
|
"github.com/imgproxy/imgproxy/v3/imagetype"
|
||||||
)
|
)
|
||||||
|
|
||||||
func cloneHeaders(src map[string]string) http.Header {
|
func cloneHeaders(src map[string]string) http.Header {
|
||||||
@@ -54,7 +55,11 @@ func Sanitize(data *imagedata.ImageData) (*imagedata.ImageData, error) {
|
|||||||
return nil, l.Err()
|
return nil, l.Err()
|
||||||
}
|
}
|
||||||
|
|
||||||
newData, err := imagedata.NewFromBytes(buf.Bytes(), cloneHeaders(data.Headers))
|
newData, err := imagedata.NewFromBytesWithFormat(
|
||||||
|
imagetype.SVG,
|
||||||
|
buf.Bytes(),
|
||||||
|
cloneHeaders(data.Headers),
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@@ -470,7 +470,7 @@ func (img *Image) Save(imgtype imagetype.Type, quality int) (*imagedata.ImageDat
|
|||||||
|
|
||||||
b := ptrToBytes(ptr, int(imgsize))
|
b := ptrToBytes(ptr, int(imgsize))
|
||||||
|
|
||||||
imgdata, ierr := imagedata.NewFromBytes(b, make(http.Header))
|
imgdata, ierr := imagedata.NewFromBytesWithFormat(imgtype, b, make(http.Header))
|
||||||
if ierr != nil {
|
if ierr != nil {
|
||||||
cancel()
|
cancel()
|
||||||
return nil, ierr
|
return nil, ierr
|
||||||
|
Reference in New Issue
Block a user