X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Flibs%2Fwernis_functions.php;h=48f3677c9c2a4c0e3efd7061f5c07f39b0dc0bd1;hp=7c89782e871897aa927df8c0a76b2e2b19457299;hb=936a7baf6967cd03d65a84acef3b9b4de8fcec6a;hpb=b8aa17b98b99c27eafbdca0fa090bae63527da9a diff --git a/inc/libs/wernis_functions.php b/inc/libs/wernis_functions.php index 7c89782e87..48f3677c9c 100644 --- a/inc/libs/wernis_functions.php +++ b/inc/libs/wernis_functions.php @@ -1,7 +1,7 @@ 'failed_general', - 'message' => getMessage('WERNIS_API_REQUEST_DATA_INVALID') + 'message' => '{--WERNIS_API_REQUEST_DATA_INVALID--}' ); } // END - if // Is the API id and MD5 hash there? - if ((getConfig('wernis_api_id') == '') || (getConfig('wernis_api_md5') == '')) { + if ((getWernisApiId() == '') || (getWernisApiMd5() == '')) { // Abort here... return array( 'status' => 'failed_general', - 'message' => getMessage('WERNIS_API_REQUEST_DATA_MISSING') + 'message' => '{--WERNIS_API_REQUEST_DATA_MISSING--}' ); } // END - if // Add more request data - $requestData['api_id'] = getConfig('wernis_api_id'); - $requestData['api_key'] = getConfig('wernis_api_md5'); + $requestData['api_id'] = getWernisApiId(); + $requestData['api_key'] = getWernisApiMd5(); + + // Is a purpose there? + if (isset($requestData['purpose'])) { + // Eval the purpose + eval('$purpose = "' . doFinalCompilation($requestData['purpose'], FALSE) . '";'); + + // Prepare the purpose, it needs encoding + $requestData['purpose'] = encodeString($purpose); + } // END - if // Construct the request string - $requestString = getConfig('wernis_api_url') . $scriptName; + $requestString = getWernisApiUrl() . $scriptName; // Get the raw response from the lower function - $response = sendPostRequest($requestString, $requestData); + $response = sendHttpPostRequest($requestString, $requestData); // Check the response header if all is fine - if (strpos($response[0], '200') === false) { + if (!isHttpStatusOkay($response[0])) { // Something bad happend... :( return array( 'status' => 'request_error', - 'message' => sprintf(getMessage('WERNIS_API_REQUEST_ERROR'), $response[0]) + 'message' => '{%message,WERNIS_API_REQUEST_ERROR=' . $response[0] . '%}' ); } // END - if // All (maybe) fine so remove the response header from server + $responseLine = '*INVALID*'; for ($idx = (count($response) - 1); $idx > 1; $idx--) { $line = trim($response[$idx]); if (!empty($line)) { - $response = $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], secureString($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(); @@ -137,11 +151,11 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { if ($data[0] === 'error') { // The request has failed... :( switch ($data[1]) { - case '404': // Invalid API ID + case '404': // Invalid API id case 'AUTH': // Authorization has failed $return = array( 'status' => 'auth_failed', - 'message' => getMessage('WERNIS_API_REQUEST_FAILED_AUTH') + 'message' => '{--WERNIS_API_REQUEST_FAILED_AUTH--}' ); break; @@ -150,36 +164,36 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { case 'USER': // Missing account or invalid password $return = array( 'status' => 'user_failed', - 'message' => getMessage('WERNIS_API_REQUEST_FAILED_USER') + 'message' => '{--WERNIS_API_REQUEST_FAILED_USER--}' ); break; case 'OWN': // Transfer to own account $return = array( 'status' => 'own_failed', - 'message' => getMessage('WERNIS_API_REQUEST_FAILED_OWN') + 'message' => '{--WERNIS_API_REQUEST_FAILED_OWN--}' ); break; case 'AMOUNT': // Amount is depleted $return = array( 'status' => 'amount_failed', - 'message' => getMessage('WERNIS_API_REQUEST_FAILED_AMOUNT') + 'message' => '{--WERNIS_API_REQUEST_FAILED_AMOUNT--}' ); break; case 'AMOUNT-SEND': // API amount is depleted $return = array( 'status' => 'api_amount_failed', - 'message' => getMessage('WERNIS_API_REQUEST_FAILED_API_AMOUNT') + 'message' => '{--WERNIS_API_REQUEST_FAILED_API_AMOUNT--}' ); 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]) + 'message' => '{%message,WERNIS_API_REQUEST_FAILED=' . $data[1] . '%}' ); break; } @@ -187,7 +201,7 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { // All fine here $return = array( 'status' => 'OK', - 'response' => $response + 'response' => $responseLine ); } @@ -197,17 +211,27 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { // Tests the function by calling balance.php on the API function WERNIS_TEST_API () { + // Only as admin + assert(isAdmin()); + // Result is always failed - $result = false; + $result = FALSE; + + // Prepare the request data + $requestData = array( + 't_uid' => getWernisRefid(), + 't_md5' => getWernisPassMd5() + ); // Return the result from the lower functions - $return = WERNIS_SEND_REQUEST('balance.php'); + $return = WERNIS_SEND_REQUEST('balance.php', $requestData); + // Did it went smoothly? if ($return['status'] == 'OK') { // All fine! - $result = true; + $result = TRUE; } else { - // Status failture text + // Status failure text WERNIS_STATUS_MESSAGE($return['message'], $return['status']); } @@ -218,31 +242,27 @@ function WERNIS_TEST_API () { // Widthdraw this amount function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { // Is the sponsor extension installed? - if (getConfig('wernis_withdraw_active') != 'Y') { - if (!EXT_IS_ACTIVE('sponsor')) { + if (!isWernisWithdrawActive()) { + if (!isExtensionActive('sponsor')) { // No, abort here - return false; - } elseif (!IS_SPONSOR()) { + return FALSE; + } elseif (!isSponsor()) { // No sponsor, not allowed to withdraw! - return false; + return FALSE; } } // END - if // Default is failed attempt - $result = false; - - // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(sprintf(getMessage('WERNIS_API_PURPOSE_WITHDRAW'), getUserId()))."\";"; - eval($eval); + $result = FALSE; // 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' => getWernisRefid(), + 'amount' => bigintval($amount), + 'purpose' => getMaskedMessage('WERNIS_API_PURPOSE_WITHDRAW', getMemberId()) ); // Return the result from the lower functions @@ -250,12 +270,12 @@ function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { if ($return['status'] == 'OK') { // All fine! - $result = true; + $result = TRUE; // Log the transfer - WERNIS_LOG_TRANSFER($wdsId, $amount, 'IN'); + WERNIS_LOG_TRANSFER($wdsId, $amount, 'WITHDRAW'); } else { - // Status failture text + // Status failure text WERNIS_STATUS_MESSAGE($return['message'], $return['status']); // Log the transfer @@ -270,20 +290,16 @@ function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { // Payout this amount function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) { // Default is failed attempt - $result = false; - - // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(sprintf(getMessage('WERNIS_API_PURPOSE_PAYOUT'), getUserId()))."\";"; - eval($eval); + $result = FALSE; // 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' => getWernisRefid(), + 't_md5' => getWernisPassMd5(), + 'r_uid' => bigintval($wdsId), + 'amount' => bigintval($amount), + 'purpose' => getMaskedMessage('WERNIS_API_PURPOSE_PAYOUT', getMemberId()) ); // Return the result from the lower functions @@ -291,12 +307,12 @@ function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) { if ($return['status'] == 'OK') { // All fine! - $result = true; + $result = TRUE; // Log the transfer - WERNIS_LOG_TRANSFER($wdsId, $amount, 'OUT'); + WERNIS_LOG_TRANSFER($wdsId, $amount, 'PAYOUT'); } else { - // Status failture text + // Status failure text WERNIS_STATUS_MESSAGE($return['message'], $return['status']); // Log the transfer @@ -308,22 +324,18 @@ function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) { } // Translate the status IN/OUT -function WERNIS_TRANSFER_STATUS ($status) { - // Default status - $return = sprintf(getMessage('WERNIS_STATUS_UNKNWOWN'), $status); - switch ($status) { - case 'IN': // Withdraw - $return = getMessage('WERNIS_STATUS_WITHDRAW'); - break; +function translateWernisTransferStatus ($status) { + // Default status is unknown + $return = '{%message,WERNIS_STATUS_UNKNWOWN=' . $status . '%}'; - case 'OUT': // Payout - $return = getMessage('WERNIS_STATUS_PAYOUT'); - break; + // Construct message id + $messageId = 'WERNIS_STATUS_' . $status; - case 'FAILED': // Payout - $return = getMessage('WERNIS_STATUS_FAILED'); - break; - } + // Is it there? + if (isMessageIdValid($messageId)) { + // Then use it as message string + $return = '{--' . $messageId . '--}'; + } // END - if // Return the status return $return; @@ -332,77 +344,272 @@ 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')", - array(getUserId(), bigintval($wdsId), bigintval($amount), $type, $message, $status), __FUNCTION__, __LINE__); + sqlQueryEscaped("INSERT INTO `{?_MYSQL_PREFIX?}_user_wernis` (`userid`, `wernis_account`, `wernis_amount`, `wernis_timestamp`, `wernis_type`, `wernis_api_message`, `wernis_api_status`) VALUES (%s, %s, %s, UNIX_TIMESTAMP(), '%s', '%s', '%s')", + array( + getMemberId(), + 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: */ debugOutput('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}"); - return false; + logDebugMessage(__FUNCTION__, __LINE__, 'userid=' . getMemberId() . ',mode=' . $mode . ',points=' . $points . ' - unknown mode detected.'); + return FALSE; } // END - if // Is there a percentage or fixed fee? - if (getConfig('wernis_'.$mode.'_fee_percent') > 0) { + if (getConfig('wernis_' . $mode . '_fee_percent') > 0) { // Percentage fee $points -= $points * getConfig('wernis_'.$mode.'_fee_percent') / 100; - } elseif (getConfig('wernis_'.$mode.'_fee_fix') > 0) { + } elseif (getConfig('wernis_' . $mode . '_fee_fix') > 0) { // Fixed fee - $points -= getConfig('wernis_'.$mode.'_fee_fix'); + $points -= getConfig('wernis_' . $mode . '_fee_fix'); } // Divide/multiply the factor if ($mode == 'payout') { // Divide for payout - $points = $points / getConfig('wernis_payout_factor'); + $points = $points / getWernisPayoutFactor(); } else { // Multiply for withdraw - $points = $points * getConfig('wernis_withdraw_factor'); + $points = $points * getWernisWithdrawFactor(); } // Return value - //* DEBUG: */ echo "mode={$mode},points={$points}
\n"; + //* DEBUG: */ debugOutput('mode=' . $mode . ',points=' . $points); return $points; } // Add withdraw fees and factor function WERNIS_ADD_WITHDRAW_FEE ($points) { // Is there a percentage or fixed fee? - if (getConfig('wernis_withdraw_fee_percent') > 0) { + if (getWernisWithdrawFeePercent() > 0) { // Percentage fee - $points += $points * getConfig('wernis_withdraw_fee_percent') / 100; - } elseif (getConfig('wernis_withdraw_fee_fix') > 0) { + $points += $points * getWernisWithdrawFeePercent() / 100; + } elseif (getWernisWithdrawFeeFix() > 0) { // Fixed fee - $points += getConfig('wernis_withdraw_fee_fix'); + $points += getWernisWithdrawFeeFix(); } // Return value return $points; } -// Add all fees to the array -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.'); - return; +//----------------------------------------------------------------------------- +// Wrapper functions +//----------------------------------------------------------------------------- + +// Wrapper function for 'wernis_refid' +function getWernisRefid () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_refid'); } // END - if - // Add both factors - $array['payout_factor'] = translateComma(getConfig('wernis_payout_factor')); - $array['withdraw_factor'] = translateComma(getConfig('wernis_withdraw_factor')); + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_pass_md5' +function getWernisPassMd5 () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_pass_md5'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_api_id' +function getWernisApiId () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_api_id'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_api_md5' +function getWernisApiMd5 () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_api_md5'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_api_url' +function getWernisApiUrl () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_api_url'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_withdraw_active' +function getWernisWithdrawActive () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_withdraw_active'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_payout_active' +function getWernisPayoutActive () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_payout_active'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_withdraw_active' +function isWernisWithdrawActive () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = (getConfig('wernis_withdraw_active') == 'Y'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_payout_active' +function isWernisPayoutActive () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = (getConfig('wernis_payout_active') == 'Y'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_withdraw_factor' +function getWernisWithdrawFactor () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_withdraw_factor'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_payout_factor' +function getWernisPayoutFactor () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_payout_factor'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_withdraw_fee_percent' +function getWernisWithdrawFeePercent () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_withdraw_fee_percent'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_withdraw_fee_fix' +function getWernisWithdrawFeeFix () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_withdraw_fee_fix'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_payout_fee_percent' +function getWernisPayoutFeePercent () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_payout_fee_percent'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_payout_fee_fix' +function getWernisPayoutFeeFix () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_payout_fee_fix'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_min_payout' +function getWernisMinPayout () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_min_payout'); + } // END - if + + // Return cache + return $GLOBALS[__FUNCTION__]; +} + +// Wrapper function for 'wernis_min_withdraw' +function getWernisMinWithdraw () { + // Is there cache? + if (!isset($GLOBALS[__FUNCTION__])) { + // Get config entry + $GLOBALS[__FUNCTION__] = getConfig('wernis_min_withdraw'); + } // END - if - // Add all fees - $array['payout_fee_percent'] = translateComma(getConfig('wernis_payout_fee_percent')); - $array['withdraw_fee_percent'] = translateComma(getConfig('wernis_withdraw_fee_percent')); - $array['payout_fee_fix'] = translateComma(getConfig('wernis_payout_fee_fix')); - $array['withdraw_fee_fix'] = translateComma(getConfig('wernis_withdraw_fee_fix')); + // Return cache + return $GLOBALS[__FUNCTION__]; } -// +// [EOF] ?>