259 lines
9.8 KiB
PHP
259 lines
9.8 KiB
PHP
<?php
|
|
/* vim: set noexpandtab tabstop=2 softtabstop=2 shiftwidth=2: */
|
|
|
|
/**
|
|
* Donation plugin (TMUF).
|
|
* Processes copper donations to and payments from the server.
|
|
* Created by Xymph
|
|
*
|
|
* Dependencies: used by plugin.panels.php
|
|
*
|
|
* Important: you must make an initial donation from a TMUF player
|
|
* login to your server login via the in-game message system, so that
|
|
* there are sufficient coppers in the account to pay the Nadeo tax on
|
|
* the first /donate transaction.
|
|
*/
|
|
|
|
Aseco::registerEvent('onBillUpdated', 'bill_updated');
|
|
Aseco::addChatCommand('donate', 'Donates coppers to server');
|
|
Aseco::addChatCommand('topdons', 'Displays top 100 highest donators');
|
|
|
|
global $bills, $payments;
|
|
$bills = array();
|
|
$payments = array();
|
|
|
|
global $mindonation, $publicappr;
|
|
$mindonation = 10; // minimum donation amount (because of Nadeo tax)
|
|
$publicappr = 100; // public appreciation threshold (show Thank You to all)
|
|
|
|
global $donation_values; // default copper values for donate panel
|
|
$donation_values = array(20, 50, 100, 200, 500, 1000, 2000);
|
|
|
|
function chat_donate($aseco, $command) {
|
|
global $bills, $mindonation;
|
|
|
|
$player = $command['author'];
|
|
$login = $player->login;
|
|
$coppers = $command['params'];
|
|
|
|
if ($aseco->server->getGame() == 'TMF') {
|
|
// check for TMUF server
|
|
if ($aseco->server->rights) {
|
|
// check for TMUF player
|
|
if ($player->rights) {
|
|
// check for valid amount
|
|
if ($coppers != '' && is_numeric($coppers)) {
|
|
$coppers = (int) $coppers;
|
|
// check for minimum donation
|
|
if ($coppers >= $mindonation) {
|
|
// start the transaction
|
|
$message = formatText($aseco->getChatMessage('DONATION'),
|
|
$coppers, $aseco->server->name);
|
|
$aseco->client->query('SendBill', $login, $coppers,
|
|
$aseco->formatColors($message), '');
|
|
$billid = $aseco->client->getResponse();
|
|
$bills[$billid] = array($player->login, $player->nickname, $coppers);
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('DONATE_MINIMUM'),
|
|
$mindonation);
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = $aseco->getChatMessage('DONATE_HELP');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('UNITED_ONLY'), 'account');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('UNITED_ONLY'), 'server');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = $aseco->getChatMessage('FOREVER_ONLY');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} // chat_donate
|
|
|
|
function admin_payment($aseco, $login, $target, $amount) {
|
|
global $payments;
|
|
|
|
// check parameters
|
|
if ($target != '' && $amount != '' && is_numeric($amount) && $amount > 0) {
|
|
// check for this server
|
|
if ($target != $aseco->server->serverlogin) {
|
|
// get current server coppers
|
|
$aseco->client->query('GetServerCoppers');
|
|
$coppers = $aseco->client->getResponse();
|
|
|
|
// check for sufficient balance, including Nadeo tax (2 + 5%)
|
|
if ($amount <= $coppers - 2 - floor($amount * 0.05)) {
|
|
// remember payment to be made
|
|
$label = formatText($aseco->getChatMessage('PAYMENT'), $amount, $target);
|
|
$payments[$login] = array($target, (int) $amount, $label);
|
|
display_payment($aseco, $login, $aseco->server->nickname,
|
|
$aseco->formatColors($label));
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('PAY_INSUFF'), $coppers);
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = $aseco->getChatMessage('PAY_SERVER');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = $aseco->getChatMessage('PAY_HELP');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} // admin_payment
|
|
|
|
function admin_pay($aseco, $login, $answer) {
|
|
global $bills, $payments;
|
|
|
|
// check for confirmation
|
|
if ($answer) {
|
|
// send server coppers to login
|
|
$aseco->client->query('Pay', $payments[$login][0], $payments[$login][1],
|
|
$aseco->formatColors($payments[$login][2]));
|
|
$billid = $aseco->client->getResponse();
|
|
// store negative bill
|
|
$bills[$billid] = array($login, $payments[$login][0], -$payments[$login][1]);
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('PAY_CANCEL'),
|
|
$payments[$login][0]);
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} // admin_pay
|
|
|
|
// called @ onBillUpdated
|
|
// [0]=BillId, [1]=State, [2]=StateName, [3]=TransactionId
|
|
function bill_updated($aseco, $bill) {
|
|
global $bills, $publicappr;
|
|
|
|
$billid = $bill[0];
|
|
$txid = $bill[3];
|
|
// check for known bill ID
|
|
if (array_key_exists($billid, $bills)) {
|
|
// get bill info
|
|
$login = $bills[$billid][0];
|
|
$nickname = $bills[$billid][1];
|
|
$coppers = $bills[$billid][2];
|
|
|
|
// check bill state
|
|
switch ($bill[1]) {
|
|
case 4: // Payed (Paid)
|
|
// check for donation or payment
|
|
if ($coppers > 0) {
|
|
// check for public appreciation threshold
|
|
if ($coppers >= $publicappr) {
|
|
$message = formatText($aseco->getChatMessage('THANKS_ALL'),
|
|
$aseco->server->name, $coppers, $nickname);
|
|
$aseco->client->query('ChatSendServerMessage', $aseco->formatColors($message));
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('THANKS_YOU'),
|
|
$coppers);
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
$aseco->console('Player {1} donated {2} coppers to this server (TxId {3})', $login, $coppers, $txid);
|
|
ldb_updateDonations($aseco, $login, $coppers);
|
|
|
|
// throw 'donation' event
|
|
$aseco->releaseEvent('onDonation', array($login, $coppers));
|
|
} else { // $coppers < 0
|
|
// get new server coppers
|
|
$aseco->client->query('GetServerCoppers');
|
|
$newcoppers = $aseco->client->getResponse();
|
|
|
|
$message = formatText($aseco->getChatMessage('PAY_CONFIRM'),
|
|
abs($coppers), $nickname, $newcoppers);
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
$aseco->console('Server paid {1} coppers to login "{2}" (TxId {3})', abs($coppers), $login, $txid);
|
|
}
|
|
unset($bills[$billid]);
|
|
break;
|
|
case 5: // Refused
|
|
$message = '{#server}> {#error}Transaction refused!';
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
$aseco->console('Refused transaction of {1} to login "{2}" (TxId {3})', $coppers, $login, $txid);
|
|
unset($bills[$billid]);
|
|
break;
|
|
case 6: // Error
|
|
$message = '{#server}> {#error}Transaction failed: {#highlite}$i ' . $bill[2];
|
|
if ($login != '')
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
else
|
|
$aseco->client->query('ChatSendServerMessage', $aseco->formatColors($message));
|
|
$aseco->console('Failed transaction of {1} to login "{2}" (TxId {3})', $coppers, $login, $txid);
|
|
unset($bills[$billid]);
|
|
break;
|
|
default: // CreatingTransaction/Issued/ValidatingPay(e)ment
|
|
break;
|
|
}
|
|
} else {
|
|
$aseco->console('BillUpdated for unknown BillId {1} {2} (TxId {3})', $billid, $bill[2], $txid);
|
|
}
|
|
} // bill_updated
|
|
|
|
|
|
function chat_topdons($aseco, $command) {
|
|
|
|
$player = $command['author'];
|
|
$login = $player->login;
|
|
|
|
if ($aseco->server->getGame() == 'TMF') {
|
|
// check for TMUF server
|
|
if ($aseco->server->rights) {
|
|
$head = 'Current TOP 100 Donators:';
|
|
$top = 100;
|
|
$bgn = '{#black}'; // nickname begin
|
|
|
|
$query = 'SELECT p.NickName, x.donations FROM players p
|
|
LEFT JOIN players_extra x ON (p.Id=x.PlayerId)
|
|
WHERE x.donations!=0 ORDER BY x.donations DESC LIMIT ' . $top;
|
|
$res = mysql_query($query);
|
|
|
|
if (mysql_num_rows($res) > 0) {
|
|
$dons = array();
|
|
$lines = 0;
|
|
$player->msgs = array();
|
|
// reserve extra width for $w tags
|
|
$extra = ($aseco->settings['lists_colornicks'] ? 0.2 : 0);
|
|
$player->msgs[0] = array(1, $head, array(0.7+$extra, 0.1, 0.45+$extra, 0.15), array('Icons128x128_1', 'Coppers', -0.01));
|
|
$i = 1;
|
|
while ($row = mysql_fetch_object($res)) {
|
|
$nick = $row->NickName;
|
|
if (!$aseco->settings['lists_colornicks'])
|
|
$nick = stripColors($nick);
|
|
$dons[] = array(str_pad($i, 2, '0', STR_PAD_LEFT) . '.',
|
|
$bgn . $nick, $row->donations);
|
|
$i++;
|
|
if (++$lines > 14) {
|
|
$player->msgs[] = $dons;
|
|
$lines = 0;
|
|
$dons = array();
|
|
}
|
|
}
|
|
// add if last batch exists
|
|
if (!empty($dons))
|
|
$player->msgs[] = $dons;
|
|
|
|
// display ManiaLink message
|
|
display_manialink_multi($player);
|
|
} else {
|
|
$message = '{#server}> {#error}No donator(s) found!';
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
|
|
mysql_free_result($res);
|
|
} else {
|
|
$message = formatText($aseco->getChatMessage('UNITED_ONLY'), 'server');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} else {
|
|
$message = $aseco->getChatMessage('FOREVER_ONLY');
|
|
$aseco->client->query('ChatSendServerMessageToLogin', $aseco->formatColors($message), $login);
|
|
}
|
|
} // chat_topdons
|
|
?>
|