* Added 3rd party logger library KLogger * Adjusted all cronjobs from verbose output to logging * Added new logs folder for crons to write to * Added new .gitignore for logs folder data * Updated blocks class to only fetch blocks with no share_id * Adjusted findblocks to use no blocks class method
87 lines
3.1 KiB
PHP
Executable File
87 lines
3.1 KiB
PHP
Executable File
#!/usr/bin/php
|
|
<?php
|
|
|
|
/*
|
|
|
|
Copyright:: 2013, Sebastian Grewe
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
// Include all settings and classes
|
|
require_once('shared.inc.php');
|
|
|
|
if ($bitcoin->can_connect() !== true) {
|
|
$log->logFatal(" unable to connect to RPC server, exiting\n");
|
|
exit(1);
|
|
}
|
|
|
|
// Mark this job as active
|
|
$setting->setValue('auto_payout_active', 1);
|
|
|
|
// Fetch all users with setup AP
|
|
$users = $user->getAllAutoPayout();
|
|
|
|
// Quick summary
|
|
$log->logInfo(" found " . count($users) . " queued payout(s)\n");
|
|
|
|
// Go through users and run transactions
|
|
if (! empty($users)) {
|
|
$log->logInfo("\tUserID\tUsername\tBalance\tThreshold\tAddress");
|
|
|
|
foreach ($users as $aUserData) {
|
|
$aBalance = $transaction->getBalance($aUserData['id']);
|
|
$dBalance = $aBalance['confirmed'];
|
|
$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']) {
|
|
// Validate address against RPC
|
|
try {
|
|
$bitcoin->validateaddress($aUserData['coin_address']);
|
|
} catch (BitcoinClientException $e) {
|
|
$log->logError('Failed to verifu this users coin address, skipping payout');
|
|
continue;
|
|
}
|
|
|
|
// Send balance, fees are reduced later by RPC Server
|
|
try {
|
|
$bitcoin->sendtoaddress($aUserData['coin_address'], $dBalance);
|
|
} catch (BitcoinClientException $e) {
|
|
$log->logError('Failed to send requested balance to coin address, please check payout process');
|
|
continue;
|
|
}
|
|
|
|
// Create transaction record
|
|
if ($transaction->addTransaction($aUserData['id'], $dBalance - $config['txfee'], 'Debit_AP', NULL, $aUserData['coin_address']) && $transaction->addTransaction($aUserData['id'], $config['txfee'], 'TXFee', NULL, $aUserData['coin_address'])) {
|
|
// Notify user via mail
|
|
$aMailData['email'] = $user->getUserEmail($user->getUserName($aUserData['id']));
|
|
$aMailData['subject'] = 'Auto Payout Completed';
|
|
$aMailData['amount'] = $dBalance;
|
|
if (!$notification->sendNotification($aUserData['id'], 'auto_payout', $aMailData))
|
|
$log->logError('Failed to send notification email to users address: ' . $aMailData['email']);
|
|
} else {
|
|
$log->logError('Failed to add new Debit_AP transaction in database for user ' . $user->getUserName($aUserData['id']));
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
$log->logDebug(" no user has configured their AP > 0\n");
|
|
}
|
|
|
|
// Mark this job as inactive
|
|
$setting->setValue('auto_payout_active', 0);
|
|
|
|
?>
|