X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Flibs%2Fwernis_functions.php;h=4d86960d3ca9bd12bbc2030d05b6bb1c44c8548d;hb=26ea563a90454a2cde58f8cd134542a0d8f14780;hp=56302d59e66111f31ec5a272116ca2c2fa10f152;hpb=1355d2c0b29510dbd407f9cde9f41a5ac02d01fa;p=mailer.git
diff --git a/inc/libs/wernis_functions.php b/inc/libs/wernis_functions.php
index 56302d59e6..4d86960d3c 100644
--- a/inc/libs/wernis_functions.php
+++ b/inc/libs/wernis_functions.php
@@ -17,7 +17,7 @@
* Needs to be in all Files and every File needs "svn propset *
* svn:keywords Date Revision" (autoprobset!) at least!!!!!! *
* -------------------------------------------------------------------- *
- * Copyright (c) 2003 - 2008 by Roland Haeder *
+ * Copyright (c) 2003 - 2009 by Roland Haeder *
* For more information visit: http://www.mxchange.org *
* *
* This program is free software; you can redistribute it and/or modify *
@@ -38,14 +38,13 @@
// Some security stuff...
if (!defined('__SECURITY')) {
- $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), '/inc') + 4) . '/security.php';
- require($INC);
+ die();
}
// Sets a status message and code
-function WERNIS_STATUS_MESSAGE ($msg, $status) {
- $GLOBALS['wernis_data']['message'] = $msg;
- $GLOBALS['wernis_data']['status'] = $status;
+function WERNIS_STATUS_MESSAGE ($message, $status) {
+ $GLOBALS['wernis_data']['message'] = $message;
+ $GLOBALS['wernis_data']['status'] = $status;
}
// Get the status message
@@ -113,16 +112,29 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) {
} // END - if
// All (maybe) fine so remove the response header from server
- $response = $response[(count($response) - 1)];
+ $responseLine = '*INVALID*';
+ for ($idx = (count($response) - 1); $idx > 1; $idx--) {
+ $line = trim($response[$idx]);
+ if (!empty($line)) {
+ $responseLine = $line;
+ break;
+ } // END - if
+ } // END - for
- // Prepare the returning result for higher functions
- if (substr($response, 0, 1) == '&') {
- // Remove the leading & (which can be used in Flash)
- $response = substr($response, 1);
+ // Is the response leaded by a & symbol?
+ if (substr($responseLine, 0, 1) != '&') {
+ // Something badly happened on server-side
+ return array(
+ 'status' => 'request_problem',
+ 'message' => sprintf(getMessage('WERNIS_API_REQUEST_PROBLEM'), $response[0], htmlentities($responseLine))
+ );
} // END - if
+ // Remove the leading & (which can be used in Flash)
+ $responseLine = substr($responseLine, 1);
+
// Bring back the response
- $data = explode('=', $response);
+ $data = explode('=', $responseLine);
// Default return array (should not stay empty)
$return = array();
@@ -170,7 +182,7 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) {
break;
default: // Unknown error (maybe new?)
- DEBUG_LOG(__FUNCTION__, __LINE__, sprintf("Unknown error %s from WDS66 API received.", $data[1]));
+ logDebugMessage(__FUNCTION__, __LINE__, sprintf("Unknown error %s from WDS66 API received.", $data[1]));
$return = array(
'status' => 'request_failed',
'message' => sprintf(getMessage('WERNIS_API_REQUEST_FAILED'), $data[1])
@@ -181,7 +193,7 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) {
// All fine here
$return = array(
'status' => 'OK',
- 'response' => $response
+ 'response' => $responseLine
);
}
@@ -213,10 +225,10 @@ function WERNIS_TEST_API () {
function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) {
// Is the sponsor extension installed?
if (getConfig('wernis_withdraw_active') != 'Y') {
- if (!EXT_IS_ACTIVE('sponsor')) {
+ if (!isExtensionActive('sponsor')) {
// No, abort here
return false;
- } elseif (!IS_SPONSOR()) {
+ } elseif (!isSponsor()) {
// No sponsor, not allowed to withdraw!
return false;
}
@@ -226,17 +238,16 @@ function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) {
$result = false;
// Prepare the purpose
- $eval = "\$purpose = \"".COMPILE_CODE(sprintf(getMessage('WERNIS_API_PURPOSE_WITHDRAW'), getUserId()))."\";";
- eval($eval);
+ eval("\$purpose = \"".compileCode(sprintf(getMessage('WERNIS_API_PURPOSE_WITHDRAW'), getUserId()))."\";");
// Prepare the request data
$requestData = array(
- 'sub_request' => 'receive',
- 't_uid' => bigintval($wdsId),
- 't_md5' => $userMd5,
- 'r_uid' => getConfig('wernis_refid'),
- 'amount' => bigintval($amount),
- 'purpose' => encodeString($purpose, false)
+ 'sub_request' => 'receive',
+ 't_uid' => bigintval($wdsId),
+ 't_md5' => $userMd5,
+ 'r_uid' => getConfig('wernis_refid'),
+ 'amount' => bigintval($amount),
+ 'purpose' => encodeString($purpose, false)
);
// Return the result from the lower functions
@@ -267,17 +278,16 @@ function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) {
$result = false;
// Prepare the purpose
- $eval = "\$purpose = \"".COMPILE_CODE(sprintf(getMessage('WERNIS_API_PURPOSE_PAYOUT'), getUserId()))."\";";
- eval($eval);
+ eval("\$purpose = \"".compileCode(sprintf(getMessage('WERNIS_API_PURPOSE_PAYOUT'), getUserId()))."\";");
// Prepare the request data
$requestData = array(
- 'sub_request' => 'send',
- 't_uid' => getConfig('wernis_refid'),
- 't_md5' => getConfig('wernis_pass_md5'),
- 'r_uid' => bigintval($wdsId),
- 'amount' => bigintval($amount),
- 'purpose' => encodeString($purpose, false)
+ 'sub_request' => 'send',
+ 't_uid' => getConfig('wernis_refid'),
+ 't_md5' => getConfig('wernis_pass_md5'),
+ 'r_uid' => bigintval($wdsId),
+ 'amount' => bigintval($amount),
+ 'purpose' => encodeString($purpose, false)
);
// Return the result from the lower functions
@@ -326,17 +336,17 @@ function WERNIS_TRANSFER_STATUS ($status) {
// Log the transfer
function WERNIS_LOG_TRANSFER ($wdsId, $amount, $type = 'FAILED', $message = '', $status = '') {
// Register this wernis movement
- SQL_QUERY_ESC("INSERT INTO `{!_MYSQL_PREFIX!}_user_wernis` (`userid`,`wernis_account`,`wernis_amount`,`wernis_timestamp`,`wernis_type`,`wernis_api_message`,`wernis_api_status`) VALUES (%d, %d, %d, UNIX_TIMESTAMP(), '%s', '%s', '%s')",
+ SQL_QUERY_ESC("INSERT INTO `{?_MYSQL_PREFIX?}_user_wernis` (`userid`,`wernis_account`,`wernis_amount`,`wernis_timestamp`,`wernis_type`,`wernis_api_message`,`wernis_api_status`) VALUES (%d, %d, %d, UNIX_TIMESTAMP(), '%s', '%s', '%s')",
array(getUserId(), bigintval($wdsId), bigintval($amount), $type, $message, $status), __FUNCTION__, __LINE__);
}
// Take fees and factor
function WERNIS_TAKE_FEE ($points, $mode) {
// Payout or withdraw are allowed modes!
- //* DEBUG: */ echo "mode={$mode},points={$points}
\n";
+ //* DEBUG: */ outputHtml("mode={$mode},points={$points}
");
if (!in_array($mode, array('payout', 'withdraw'))) {
// Log error and abort
- DEBUG_LOG(__FUNCTION__, __LINE__, "uid={getUserId()},mode={$mode},points={$points}");
+ logDebugMessage(__FUNCTION__, __LINE__, "userid={getUserId()},mode={$mode},points={$points}");
return false;
} // END - if
@@ -359,7 +369,7 @@ function WERNIS_TAKE_FEE ($points, $mode) {
}
// Return value
- //* DEBUG: */ echo "mode={$mode},points={$points}
\n";
+ //* DEBUG: */ outputHtml("mode={$mode},points={$points}
");
return $points;
}
@@ -383,7 +393,7 @@ function WERNIS_ADD_FEES_TO_ARRAY (&$array) {
// Is the array an array? ;-)
if (!is_array($array)) {
// Log error and return
- DEBUG_LOG(__FUNCTION__, __LINE__, ' Type '.gettype($array).'!=array.');
+ logDebugMessage(__FUNCTION__, __LINE__, 'Type ' . gettype($array) . ' != array.');
return;
} // END - if