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 > URL 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 && structKeyExists(url, "BusinessID") && isNumeric(url.BusinessID) && url.BusinessID GT 0) { bizId = int(url.BusinessID); } if (bizId LTE 0) { apiAbort({ OK=false, ERROR="missing_business_id", MESSAGE="BusinessID is required" }); } SELECT ID, BeaconShardID, BeaconMajor FROM Businesses WHERE ID = LIMIT 1 SELECT UUID FROM BeaconShards WHERE ID = #serializeJSON({ OK = true, BusinessID = bizId, BeaconShardUUID = qShard.UUID, BeaconMajor = qBiz.BeaconMajor, ShardID = qBiz.BeaconShardID, AlreadyAllocated = true })# SELECT ID, UUID, BusinessCount FROM BeaconShards WHERE IsActive = 1 AND BusinessCount < MaxBusinesses ORDER BY BusinessCount ASC LIMIT 1 FOR UPDATE SELECT COALESCE(MAX(BeaconMajor), 0) AS MaxMajor FROM Businesses WHERE BeaconShardID = UPDATE Businesses SET BeaconShardID = , BeaconMajor = WHERE ID = AND (BeaconShardID IS NULL OR BeaconMajor IS NULL) UPDATE BeaconShards SET BusinessCount = BusinessCount + 1 WHERE ID = #serializeJSON({ OK = true, BusinessID = bizId, BeaconShardUUID = shardUUID, BeaconMajor = nextMajor, ShardID = shardId, AlreadyAllocated = false })# #serializeJSON({ OK=false, ERROR="server_error", MESSAGE=cfcatch.message, DETAIL=cfcatch.detail })#