This repository has been archived on 2026-03-21. You can view files and clone it, but cannot push or open issues or pull requests.
payfrit-biz/api/beacons/delete.cfm

71 lines
2.4 KiB
Text

<cfsetting showdebugoutput="false">
<cfsetting enablecfoutputonly="true">
<cfcontent type="application/json; charset=utf-8" reset="true">
<cfheader name="Cache-Control" value="no-store">
<cfscript>
function apiAbort(obj) {
writeOutput(serializeJSON(obj));
abort;
}
function readJsonBody() {
raw = toString(getHttpRequestData().content);
if (isNull(raw) || len(trim(raw)) EQ 0) return {};
try {
parsed = deserializeJSON(raw);
} catch(any e) {
apiAbort({ OK=false, ERROR="bad_json", MESSAGE="Invalid JSON body" });
}
if (!isStruct(parsed)) return {};
return parsed;
}
data = readJsonBody();
httpHeaders = getHttpRequestData().headers;
// Get BusinessID from: session > body > X-Business-ID header
bizId = 0;
if (structKeyExists(request, "BusinessID") && isNumeric(request.BusinessID) && request.BusinessID GT 0) {
bizId = int(request.BusinessID);
}
if (bizId LTE 0 && structKeyExists(data, "BusinessID") && isNumeric(data.BusinessID) && data.BusinessID GT 0) {
bizId = int(data.BusinessID);
}
if (bizId LTE 0 && structKeyExists(httpHeaders, "X-Business-ID") && isNumeric(httpHeaders["X-Business-ID"]) && httpHeaders["X-Business-ID"] GT 0) {
bizId = int(httpHeaders["X-Business-ID"]);
}
if (bizId LTE 0) {
apiAbort({ OK=false, ERROR="no_business_selected" });
}
// Get ServicePointID (sharding beacons are service points with BeaconMinor)
servicePointId = structKeyExists(data, "ServicePointID") && isNumeric(data.ServicePointID) ? int(data.ServicePointID) : 0;
if (servicePointId LTE 0) {
apiAbort({ OK=false, ERROR="missing_service_point_id", MESSAGE="ServicePointID is required" });
}
</cfscript>
<!--- Clear BeaconMinor on service point to remove the beacon --->
<cfquery datasource="payfrit">
UPDATE ServicePoints
SET BeaconMinor = NULL
WHERE ID = <cfqueryparam cfsqltype="cf_sql_integer" value="#servicePointId#">
AND BusinessID = <cfqueryparam cfsqltype="cf_sql_integer" value="#bizId#">
</cfquery>
<cfquery name="qCheck" datasource="payfrit">
SELECT ID FROM ServicePoints
WHERE ID = <cfqueryparam cfsqltype="cf_sql_integer" value="#servicePointId#">
AND BusinessID = <cfqueryparam cfsqltype="cf_sql_integer" value="#bizId#">
LIMIT 1
</cfquery>
<cfif qCheck.recordCount EQ 0>
<cfoutput>#serializeJSON({ OK=false, ERROR="not_found", DEBUG_ServicePointID=servicePointId, DEBUG_BusinessID=bizId })#</cfoutput>
<cfabort>
</cfif>
<cfoutput>#serializeJSON({ OK=true, ERROR="", ServicePointID=servicePointId })#</cfoutput>