Skip to content

Commit

Permalink
Add atomic locking
Browse files Browse the repository at this point in the history
  • Loading branch information
enjinabner committed Nov 29, 2023
1 parent 99ac3b0 commit eff2287
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
1 change: 1 addition & 0 deletions src/Enums/PlatformBeamCache.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ enum PlatformBeamCache: string implements PlatformCacheable
case CLAIM_PROBABILITIES = 'claimProbabilities';
case IDEMPOTENCY_KEY = 'idempotencyKey';
case BATCH_PROCESS = 'batchProcessKey';
case CLAIM_BEAM_JOB = 'claimBeamJob';

/**
* The key for the cache item.
Expand Down
15 changes: 12 additions & 3 deletions src/Jobs/ClaimBeam.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
use Enjin\Platform\Beam\Services\BeamService;
use Enjin\Platform\Services\Database\WalletService;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Cache\LockTimeoutException;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Foundation\Bus\Dispatchable;
Expand Down Expand Up @@ -41,7 +42,10 @@ public function __construct(protected ?array $data)
public function handle(BatchService $batch, WalletService $wallet): void
{
if ($data = $this->data) {
$lock = Cache::lock(PlatformBeamCache::CLAIM_BEAM_JOB->key($data['beam']['id']), 5);

try {
$lock->block(5);
$claim = BeamClaim::where('beam_id', $data['beam']['id'])
->claimable()
->when($data['code'], fn ($query) => $query->withSingleUseCode($data['code']))
Expand All @@ -58,17 +62,22 @@ public function handle(BatchService $batch, WalletService $wallet): void

DB::commit();

Log::info('Claim beam assigned.', $data);
Log::info('ClaimBeamJob: Claim assigned.', $claim->toArray());
} else {
Log::info('Claim beam cannot assign.', $data);
Log::info('ClaimBeamJob: No claim assigned.', $data);
$this->release(1);
}
} catch(LockTimeoutException) {
Log::info('ClaimBeamJob: Cannot obtain lock, retrying', $data);
$this->release(1);
} catch (Throwable $e) {
DB::rollBack();

Log::error('Claim beam error, message:' . $e->getMessage(), $data);
Log::error('ClaimBeamJob: Claim error, message:' . $e->getMessage(), $data);

throw $e;
} finally {
$lock?->release();
}
}
}
Expand Down

0 comments on commit eff2287

Please sign in to comment.