#!/usr/bin/php getValue('disable_payouts') == 1) { $log->logInfo(" payouts disabled via admin panel"); $monitoring->endCronjob($cron_name, 'E0009', 0, true, false); } $log->logInfo("Starting Payout..."); if ($bitcoin->can_connect() !== true) { $log->logFatal(" unable to connect to RPC server, exiting"); $monitoring->endCronjob($cron_name, 'E0006', 1, true); } if ($setting->getValue('disable_manual_payouts') != 1) { // Fetch outstanding payout requests if ($aPayouts = $oPayout->getUnprocessedPayouts()) { if (count($aPayouts) > 0) { $log->logInfo("\tStarting Manual Payments..."); $log->logInfo("\tAccount ID\tUsername\tBalance\t\tCoin Address"); foreach ($aPayouts as $aData) { $transaction_id = NULL; $rpc_txid = NULL; $aBalance = $transaction->getBalance($aData['account_id']); $dBalance = $aBalance['confirmed']; $aData['coin_address'] = $user->getCoinAddress($aData['account_id']); $aData['username'] = $user->getUserName($aData['account_id']); // Validate address against RPC try { $aStatus = $bitcoin->validateaddress($aData['coin_address']); if (!$aStatus['isvalid']) { $log->logError('User: ' . $aData['username'] . ' - Failed to verify this users coin address, skipping payout'); continue; } } catch (Exception $e) { $log->logError('User: ' . $aData['username'] . ' - Failed to verify this users coin address, skipping payout'); continue; } if ($dBalance > $config['txfee_manual']) { // To ensure we don't run this transaction again, lets mark it completed if (!$oPayout->setProcessed($aData['id'])) { $log->logFatal('unable to mark transactions ' . $aData['id'] . ' as processed. ERROR: ' . $oPayout->getCronError()); $monitoring->endCronjob($cron_name, 'E0010', 1, true); } $log->logInfo("\t" . $aData['account_id'] . "\t\t" . $aData['username'] . "\t" . $dBalance . "\t\t" . $aData['coin_address']); if ($transaction->addTransaction($aData['account_id'], $dBalance - $config['txfee_manual'], 'Debit_MP', NULL, $aData['coin_address'], NULL)) { // Store debit transaction ID for later update $transaction_id = $transaction->insert_id; if (!$transaction->addTransaction($aData['account_id'], $config['txfee_manual'], 'TXFee', NULL, $aData['coin_address'])) $log->logError('Failed to add TXFee record: ' . $transaction->getCronError()); // Mark all older transactions as archived if (!$transaction->setArchived($aData['account_id'], $transaction->insert_id)) $log->logError('Failed to mark transactions for #' . $aData['account_id'] . ' prior to #' . $transaction->insert_id . ' as archived. ERROR: ' . $transaction->getCronError()); // Run the payouts from RPC now that the user is fully debited try { $rpc_txid = $bitcoin->sendtoaddress($aData['coin_address'], $dBalance - $config['txfee_manual']); } catch (Exception $e) { $log->logError('E0078: RPC method did not return 200 OK: Address: ' . $aData['coin_address'] . ' ERROR: ' . $e->getMessage()); // Remove this line below if RPC calls are failing but transactions are still added to it // Don't blame MPOS if you run into issues after commenting this out! $monitoring->endCronjob($cron_name, 'E0078', 1, true); } // Update our transaction and add the RPC Transaction ID if (empty($rpc_txid) || !$transaction->setRPCTxId($transaction_id, $rpc_txid)) $log->logError('Unable to add RPC transaction ID ' . $rpc_txid . ' to transaction record ' . $tx_id . ': ' . $transaction->getCronError()); // Notify user via mail $aMailData['email'] = $user->getUserEmail($user->getUserName($aData['account_id'])); $aMailData['subject'] = 'Manual Payout Completed'; $aMailData['amount'] = $dBalance - $config['txfee_manual']; $aMailData['payout_id'] = $aData['id']; if (!$notification->sendNotification($aData['account_id'], 'manual_payout', $aMailData)) $log->logError('Failed to send notification email to users address: ' . $aMailData['email'] . 'ERROR: ' . $notification->getCronError()); // Recheck the users balance to make sure it is now 0 if (!$aBalance = $transaction->getBalance($aData['account_id'])) { $log->logFatal('Failed to fetch balance for account ' . $aData['account_id'] . '. ERROR: ' . $transaction->getCronError()); $monitoring->endCronjob($cron_name, 'E0065', 1, true); } if ($aBalance['confirmed'] > 0) { $log->logFatal('User has a remaining balance of ' . $aBalance['confirmed'] . ' after a successful payout!'); $monitoring->endCronjob($cron_name, 'E0065', 1, true); } } else { $log->logFatal('Failed to add new Debit_MP transaction in database for user ' . $user->getUserName($aData['account_id']) . ' ERROR: ' . $transaction->getCronError()); $monitoring->endCronjob($cron_name, 'E0064', 1, true); } } } } } else if (empty($aPayouts)) { $log->logInfo("\tStopping Payments. No Payout Requests Found."); } else { $log->logFatal("\tFailed Processing Manual Payment Queue...Aborting..."); $monitoring->endCronjob($cron_name, 'E0050', 1, true); } if (count($aPayouts > 0)) $log->logDebug(" found " . count($aPayouts) . " queued manual payout requests"); } else { $log->logDebug("Manual payouts are disabled via admin panel"); } if ($setting->getValue('disable_auto_payouts') != 1) { // Fetch all users balances if ($users = $transaction->getAPQueue()) { if (!empty($users)) { if (count($users) > 0) $log->logDebug(" found " . count($users) . " queued payout(s)"); // Go through users and run transactions $log->logInfo("Starting Payments..."); $log->logInfo("\tUserID\tUsername\tBalance\tThreshold\tAddress"); foreach ($users as $aUserData) { $transaction_id = NULL; $rpc_txid = NULL; $dBalance = $aUserData['confirmed']; // Validate address against RPC try { $aStatus = $bitcoin->validateaddress($aUserData['coin_address']); if (!$aStatus['isvalid']) { $log->logError('User: ' . $aUserData['username'] . ' - Failed to verify this users coin address, skipping payout'); continue; } } catch (Exception $e) { $log->logError('User: ' . $aUserData['username'] . ' - Failed to verify this users coin address, skipping payout'); continue; } $log->logInfo("\t" . $aUserData['id'] . "\t" . $aUserData['username'] . "\t" . $dBalance . "\t" . $aUserData['ap_threshold'] . "\t\t" . $aUserData['coin_address']); // Only run if balance meets threshold and can pay the potential transaction fee if ($dBalance > $aUserData['ap_threshold'] && $dBalance > $config['txfee_auto']) { // Create transaction record if ($transaction->addTransaction($aUserData['id'], $dBalance - $config['txfee_auto'], 'Debit_AP', NULL, $aUserData['coin_address'], NULL)) { // Store debit ID for later update $transaction_id = $transaction->insert_id; if (!$transaction->addTransaction($aUserData['id'], $config['txfee_auto'], 'TXFee', NULL, $aUserData['coin_address'])) $log->logError('Failed to add TXFee record: ' . $transaction->getCronError()); // Mark all older transactions as archived if (!$transaction->setArchived($aUserData['id'], $transaction->insert_id)) $log->logError('Failed to mark transactions for user #' . $aUserData['id'] . ' prior to #' . $transaction->insert_id . ' as archived. ERROR: ' . $transaction->getCronError()); // Run the payouts from RPC now that the user is fully debited try { $rpc_txid = $bitcoin->sendtoaddress($aUserData['coin_address'], $dBalance - $config['txfee_auto']); } catch (Exception $e) { $log->logError('E0078: RPC method did not return 200 OK: Address: ' . $aUserData['coin_address'] . ' ERROR: ' . $e->getMessage()); // Remove this line below if RPC calls are failing but transactions are still added to it // Don't blame MPOS if you run into issues after commenting this out! $monitoring->endCronjob($cron_name, 'E0078', 1, true); } // Update our transaction and add the RPC Transaction ID if (empty($rpc_txid) || !$transaction->setRPCTxId($transaction_id, $rpc_txid)) $log->logError('Unable to add RPC transaction ID ' . $rpc_txid . ' to transaction record ' . $tx_id . ': ' . $transaction->getCronError()); // Notify user via mail $aMailData['email'] = $user->getUserEmail($user->getUserName($aUserData['id'])); $aMailData['subject'] = 'Auto Payout Completed'; $aMailData['amount'] = $dBalance - $config['txfee_auto']; if (!$notification->sendNotification($aUserData['id'], 'auto_payout', $aMailData)) $log->logError('Failed to send notification email to users address: ' . $aMailData['email'] . ' ERROR: ' . $notification->getCronError()); // Recheck the users balance to make sure it is now 0 $aBalance = $transaction->getBalance($aUserData['id']); if ($aBalance['confirmed'] > 0) { $log->logFatal('User has a remaining balance of ' . $aBalance['confirmed'] . ' after a successful payout!'); $monitoring->endCronjob($cron_name, 'E0065', 1, true); } } else { $log->logFatal('Failed to add new Debit_AP transaction in database for user ' . $user->getUserName($aUserData['id']) . ' ERROR: ' . $transaction->getCronError()); $monitoring->endCronjob($cron_name, 'E0064', 1, true); } } } } } else if(empty($users)) { $log->logInfo("\tSkipping payments. No Auto Payments Eligible."); $log->logDebug("Users have not configured their AP > 0"); } else{ $log->logFatal("\tFailed Processing Auto Payment Payment Queue. ERROR: " . $transaction->getCronError()); $monitoring->endCronjob($cron_name, 'E0050', 1, true); } } else { $log->logDebug("Auto payouts disabled via admin panel"); } $log->logInfo("Completed Payouts"); // Cron cleanup and monitoring require_once('cron_end.inc.php'); ?>