* Compatible with the situation where the mask is empty in CreateEditImage. * Fix the test for the unnecessary removal of the mask.png file. * add image variation implementation
This commit is contained in:
60
image.go
60
image.go
@@ -86,14 +86,16 @@ func (c *Client) CreateEditImage(ctx context.Context, request ImageEditRequest)
|
||||
return
|
||||
}
|
||||
|
||||
// mask
|
||||
mask, err := writer.CreateFormFile("mask", request.Mask.Name())
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
_, err = io.Copy(mask, request.Mask)
|
||||
if err != nil {
|
||||
return
|
||||
// mask, it is optional
|
||||
if request.Mask != nil {
|
||||
mask, err2 := writer.CreateFormFile("mask", request.Mask.Name())
|
||||
if err2 != nil {
|
||||
return
|
||||
}
|
||||
_, err = io.Copy(mask, request.Mask)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
err = writer.WriteField("prompt", request.Prompt)
|
||||
@@ -119,3 +121,45 @@ func (c *Client) CreateEditImage(ctx context.Context, request ImageEditRequest)
|
||||
err = c.sendRequest(req, &response)
|
||||
return
|
||||
}
|
||||
|
||||
// ImageVariationRequest represents the request structure for the image API.
|
||||
type ImageVariationRequest struct {
|
||||
Image *os.File `json:"image,omitempty"`
|
||||
N int `json:"n,omitempty"`
|
||||
Size string `json:"size,omitempty"`
|
||||
}
|
||||
|
||||
// ImageVariationRequest - API call to create an image variation. This is the main endpoint of the DALL-E API.
|
||||
func (c *Client) CreateVariateImage(ctx context.Context, request ImageVariationRequest) (response ImageResponse, err error) {
|
||||
body := &bytes.Buffer{}
|
||||
writer := multipart.NewWriter(body)
|
||||
|
||||
// image
|
||||
image, err := writer.CreateFormFile("image", request.Image.Name())
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
_, err = io.Copy(image, request.Image)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
err = writer.WriteField("n", strconv.Itoa(request.N))
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
err = writer.WriteField("size", request.Size)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
writer.Close()
|
||||
urlSuffix := "/images/edits"
|
||||
req, err := http.NewRequestWithContext(ctx, http.MethodPost, c.fullURL(urlSuffix), body)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
req.Header.Set("Content-Type", writer.FormDataContentType())
|
||||
err = c.sendRequest(req, &response)
|
||||
return
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user