Files
Jonathan Miller 1799401db5
Branch Policy Check / Verify merge target (pull_request) Successful in 1s
feat: add standard file headers to all 57 files missing them
- Add Copyright + FILE INFORMATION headers to 11 PHP enterprise classes
- Add FILE INFORMATION blocks to 9 PHP files with incomplete headers
- Add headers to 2 test files
- Add markdown comment headers to 27 index/README files
- Add headers to 5 root markdown files
- Add FILE INFORMATION to 4 files with existing but incomplete headers

All files now conform to moko-platform file header standard.

Authored-by: Moko Consulting

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-05-11 17:10:19 -05:00

66 lines
1.9 KiB
PHP

<?php
declare(strict_types=1);
/**
* Error Recovery Framework - Backward compatibility file
*
* This file now serves as a backward compatibility layer.
* Classes have been split into separate files following PSR-4 standards:
* - RecoveryError.php
* - CheckpointManager.php
* - RetryHelper.php
* - RecoveryManager.php
*
* Copyright (C) 2026 Moko Consulting <hello@mokoconsulting.tech>
*
* SPDX-License-Identifier: GPL-3.0-or-later
*
* FILE INFORMATION
* DEFGROUP: MokoStandards.Enterprise.Recovery
* INGROUP: MokoStandards.Enterprise
* REPO: https://git.mokoconsulting.tech/MokoConsulting/moko-platform
* PATH: /lib/Enterprise/ErrorRecovery.php
* BRIEF: Error recovery framework
*
* @package MokoStandards\Enterprise
* @version 04.00.04
* @author MokoStandards Team
* @license GPL-3.0-or-later
* @deprecated Individual class files should be used instead
*/
namespace MokoEnterprise;
use Throwable;
// For backward compatibility, ensure classes are loaded
require_once __DIR__ . '/RecoveryError.php';
require_once __DIR__ . '/CheckpointManager.php';
require_once __DIR__ . '/RetryHelper.php';
require_once __DIR__ . '/RecoveryManager.php';
/**
* Execute a callable with automatic rollback on failure.
*
* @param callable $operation Operation to execute
* @param callable $rollback Rollback function to call on failure
* @return mixed Result of operation
* @throws Throwable Re-throws the original exception after rollback
*/
function withRollback(callable $operation, callable $rollback): mixed
{
try {
return $operation();
} catch (Throwable $e) {
error_log("Operation failed, executing rollback: {$e->getMessage()}");
try {
$rollback();
error_log("Rollback completed successfully");
} catch (Throwable $rollbackError) {
error_log("Rollback failed: {$rollbackError->getMessage()}");
}
throw $e;
}
}