- Add HEIC/HEIF support for iPhone camera photos - Make frontend file type validation more permissive for mobile browsers - Add 'capture' attribute to prefer rear camera on mobile - Include actual file extension in error messages for debugging Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
69 lines
2.5 KiB
Text
69 lines
2.5 KiB
Text
<cfsetting showdebugoutput="false">
|
|
<cfsetting enablecfoutputonly="true">
|
|
<cfcontent type="application/json; charset=utf-8" reset="true">
|
|
<cfheader name="Cache-Control" value="no-store">
|
|
|
|
<cftry>
|
|
<cfset itemsDir = expandPath("/uploads/items")>
|
|
<cfscript>
|
|
// Get ItemID from form
|
|
itemId = 0;
|
|
if (structKeyExists(form, "ItemID") && isNumeric(form.ItemID) && form.ItemID GT 0) {
|
|
itemId = int(form.ItemID);
|
|
}
|
|
|
|
if (itemId LTE 0) {
|
|
apiAbort({ "OK": false, "ERROR": "missing_itemid", "MESSAGE": "ItemID is required" });
|
|
}
|
|
</cfscript>
|
|
|
|
<!--- Check if file was uploaded --->
|
|
<cfif NOT structKeyExists(form, "photo") OR form.photo EQ "">
|
|
<cfoutput>#serializeJSON({ "OK": false, "ERROR": "no_file", "MESSAGE": "No file was uploaded" })#</cfoutput>
|
|
<cfabort>
|
|
</cfif>
|
|
|
|
<!--- Upload the file to temp location first --->
|
|
<cffile action="UPLOAD" filefield="photo" destination="#itemsDir#/" nameconflict="MAKEUNIQUE" mode="755" result="uploadResult">
|
|
|
|
<!--- Validate file type (include HEIC/HEIF for iPhone) --->
|
|
<cfset allowedExtensions = "jpg,jpeg,gif,png,webp,heic,heif">
|
|
<cfset actualExt = lCase(uploadResult.ClientFileExt)>
|
|
<cfif NOT listFindNoCase(allowedExtensions, actualExt)>
|
|
<cffile action="DELETE" file="#itemsDir#/#uploadResult.ServerFile#">
|
|
<cfoutput>#serializeJSON({ "OK": false, "ERROR": "invalid_type", "MESSAGE": "Only image files are accepted (jpg, jpeg, gif, png, webp, heic). Got: #actualExt#" })#</cfoutput>
|
|
<cfabort>
|
|
</cfif>
|
|
|
|
<!--- Convert HEIC/HEIF to jpg for broader compatibility --->
|
|
<cfif actualExt EQ "heic" OR actualExt EQ "heif">
|
|
<cfset actualExt = "jpg">
|
|
</cfif>
|
|
|
|
<!--- Delete old photo if exists (any extension) --->
|
|
<cfscript>
|
|
for (ext in listToArray("jpg,jpeg,gif,png,webp,heic,heif")) {
|
|
oldFile = "#itemsDir#/#itemId#.#ext#";
|
|
if (fileExists(oldFile)) {
|
|
try { fileDelete(oldFile); } catch (any e) {}
|
|
}
|
|
}
|
|
</cfscript>
|
|
|
|
<!--- Rename to ItemID.ext (use actualExt which may be converted from heic) --->
|
|
<cffile action="RENAME" source="#itemsDir#/#uploadResult.ServerFile#" destination="#itemsDir#/#itemId#.#actualExt#" mode="755">
|
|
|
|
<!--- Return success with image URL --->
|
|
<cfoutput>#serializeJSON({
|
|
"OK": true,
|
|
"ERROR": "",
|
|
"MESSAGE": "Photo uploaded successfully",
|
|
"IMAGEURL": "/uploads/items/#itemId#.#actualExt#"
|
|
})#</cfoutput>
|
|
|
|
<cfcatch type="any">
|
|
<cfheader statuscode="200" statustext="OK">
|
|
<cfcontent type="application/json; charset=utf-8" reset="true">
|
|
<cfoutput>#serializeJSON({ "OK": false, "ERROR": "server_error", "MESSAGE": cfcatch.message, "DETAIL": cfcatch.detail })#</cfoutput>
|
|
</cfcatch>
|
|
</cftry>
|