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/admin/_scripts/resetTestData.cfm
John Mizerek 89ec86c9d2 Move 70 one-off admin scripts to api/admin/_scripts/ (gitignored)
Only quickTasks/ and scheduledTasks/ subdirectories remain tracked
since those are actively used by the portal.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-31 20:38:49 -08:00

57 lines
1.9 KiB
Text

<cfsetting showdebugoutput="false">
<cfsetting enablecfoutputonly="true">
<cffunction name="apiAbort" access="public" returntype="void" output="true">
<cfargument name="payload" type="struct" required="true">
<cfcontent type="application/json; charset=utf-8">
<cfoutput>#serializeJSON(arguments.payload)#</cfoutput>
<cfabort>
</cffunction>
<cftry>
<!--- Disable foreign key checks temporarily --->
<cfset queryExecute("SET FOREIGN_KEY_CHECKS = 0", [], { datasource = "payfrit" })>
<!--- Clear Tasks --->
<cfset queryExecute("DELETE FROM Tasks", [], { datasource = "payfrit" })>
<!--- Clear Payments --->
<cftry>
<cfset queryExecute("DELETE FROM Payments", [], { datasource = "payfrit" })>
<cfcatch></cfcatch>
</cftry>
<!--- Clear OrderLineItemModifiers if exists --->
<cftry>
<cfset queryExecute("DELETE FROM OrderLineItemModifiers", [], { datasource = "payfrit" })>
<cfcatch></cfcatch>
</cftry>
<!--- Clear OrderLineItems --->
<cfset queryExecute("DELETE FROM OrderLineItems", [], { datasource = "payfrit" })>
<!--- Clear Orders --->
<cfset queryExecute("DELETE FROM Orders", [], { datasource = "payfrit" })>
<!--- Re-enable foreign key checks --->
<cfset queryExecute("SET FOREIGN_KEY_CHECKS = 1", [], { datasource = "payfrit" })>
<!--- Reset auto-increment counters --->
<cfset queryExecute("ALTER TABLE Tasks AUTO_INCREMENT = 1", [], { datasource = "payfrit" })>
<cfset queryExecute("ALTER TABLE Orders AUTO_INCREMENT = 1", [], { datasource = "payfrit" })>
<cfset queryExecute("ALTER TABLE OrderLineItems AUTO_INCREMENT = 1", [], { datasource = "payfrit" })>
<cfset apiAbort({
"OK": true,
"MESSAGE": "All test data cleared successfully. Orders, OrderLineItems, and Tasks tables have been reset."
})>
<cfcatch>
<cfset apiAbort({
"OK": false,
"ERROR": "reset_failed",
"MESSAGE": cfcatch.message,
"DETAIL": cfcatch.detail
})>
</cfcatch>
</cftry>