X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Flibs%2Fwernis_functions.php;h=d22f14cc417c3b93a5b6eb9b40d2eb58827e77c9;hb=07ec113b187228ba74b4b08966602c4a2c161d2c;hp=6a3725ac021a8ffcffd921aa32fdbe6de882be9a;hpb=50cec5fbac1b8b7427f016bf02c93cb1aa7bb9e1;p=mailer.git diff --git a/inc/libs/wernis_functions.php b/inc/libs/wernis_functions.php index 6a3725ac02..d22f14cc41 100644 --- a/inc/libs/wernis_functions.php +++ b/inc/libs/wernis_functions.php @@ -1,7 +1,7 @@ "failed_general", - 'message' => WERNIS_API_REQUEST_DATA_INVALID + 'status' => 'failed_general', + 'message' => '{--WERNIS_API_REQUEST_DATA_INVALID--}' ); } // END - if // Is the API id and MD5 hash there? - if ((empty($_CONFIG['wernis_api_id'])) || (empty($_CONFIG['wernis_api_md5']))) { + if ((getConfig('wernis_api_id') == '') || (getConfig('wernis_api_md5') == '')) { // Abort here... return array( - 'status' => "failed_general", - 'message' => WERNIS_API_REQUEST_DATA_MISSING + 'status' => 'failed_general', + 'message' => '{--WERNIS_API_REQUEST_DATA_MISSING--}' ); } // END - if // Add more request data - $requestData['api_id'] = bigintval($_CONFIG['wernis_api_id']); - $requestData['api_key'] = $_CONFIG['wernis_api_key']; + $requestData['api_id'] = getConfig('wernis_api_id'); + $requestData['api_key'] = getConfig('wernis_api_md5'); + + // 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 = $_CONFIG['wernis_api_url'] . $scriptName; + $requestString = getConfig('wernis_api_url') . $scriptName; // Get the raw response from the lower function - $response = POST_URL($requestString, $requestData); + $response = sendPostRequest($requestString, $requestData); // Check the response header if all is fine - if (strpos($response[0], "200") === false) { + if (strpos($response[0], '200') === false) { // Something bad happend... :( return array( - 'status' => "request_error", - 'message' => sprintf(WERNIS_API_REQUEST_ERROR, $response[0]) + 'status' => 'request_error', + 'message' => getMaskedMessage('WERNIS_API_REQUEST_ERROR', $response[0]) ); } // 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], 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(); // We use only the first two entries (which shall be fine) - if ($data[0] === "error") { + if ($data[0] === 'error') { // The request has failed... :( switch ($data[1]) { - case "404": // Invalid API ID - case "AUTH": // Authorization has failed + case '404': // Invalid API id + case 'AUTH': // Authorization has failed $return = array( - 'status' => "auth_failed", - 'message' => WERNIS_API_REQUEST_FAILED_AUTH + 'status' => 'auth_failed', + 'message' => '{--WERNIS_API_REQUEST_FAILED_AUTH--}' ); break; - case "LOCKED": // User account is locked! - case "PASS": // Bad passphrase entered - case "USER": // Missing account or invalid password + case 'LOCKED': // User account is locked! + case 'PASS': // Bad passphrase entered + case 'USER': // Missing account or invalid password $return = array( - 'status' => "user_failed", - 'message' => WERNIS_API_REQUEST_FAILED_USER + 'status' => 'user_failed', + 'message' => '{--WERNIS_API_REQUEST_FAILED_USER--}' ); break; - case "OWN": // Transfer to own account + case 'OWN': // Transfer to own account $return = array( - 'status' => "own_failed", - 'message' => WERNIS_API_REQUEST_FAILED_OWN + 'status' => 'own_failed', + 'message' => '{--WERNIS_API_REQUEST_FAILED_OWN--}' ); break; - case "AMOUNT": // Amount is depleted + case 'AMOUNT': // Amount is depleted $return = array( - 'status' => "amount_failed", - 'message' => WERNIS_API_REQUEST_FAILED_AMOUNT + 'status' => 'amount_failed', + 'message' => '{--WERNIS_API_REQUEST_FAILED_AMOUNT--}' ); break; - case "AMOUNT-SEND": // API amount is depleted + case 'AMOUNT-SEND': // API amount is depleted $return = array( - 'status' => "api_amount_failed", - 'message' => WERNIS_API_REQUEST_FAILED_API_AMOUNT + 'status' => 'api_amount_failed', + 'message' => '{--WERNIS_API_REQUEST_FAILED_API_AMOUNT--}' ); break; default: // Unknown error (maybe new?) + logDebugMessage(__FUNCTION__, __LINE__, sprintf("Unknown error %s from WDS66 API received.", $data[1])); $return = array( - 'status' => "request_failed", - 'message' => sprintf(WERNIS_API_REQUEST_FAILED, $data[1]) + 'status' => 'request_failed', + 'message' => getMaskedMessage('WERNIS_API_REQUEST_FAILED', $data[1]) ); break; } } else { // All fine here $return = array( - 'status' => "OK", - 'response' => $response + 'status' => 'OK', + 'response' => $responseLine ); } @@ -190,14 +213,14 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { // Tests the function by calling balance.php on the API function WERNIS_TEST_API () { - // Get config first - global $_CONFIG; + // Result is always failed $result = false; // Return the result from the lower functions - $return = WERNIS_SEND_REQUEST("balance.php"); + $return = WERNIS_SEND_REQUEST('balance.php'); - if ($return['status'] == "OK") { + // Did it went smoothly? + if ($return['status'] == 'OK') { // All fine! $result = true; } else { @@ -211,38 +234,34 @@ function WERNIS_TEST_API () { // Widthdraw this amount function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { - global $_CONFIG; - // Is the sponsor extension installed? - if (!EXT_IS_ACTIVE("sponsor")) { - // No, abort here - return false; - } elseif (!IS_SPONSOR()) { - // No sponsor, not allowed to withdraw! - return false; - } + if (getConfig('wernis_withdraw_active') != 'Y') { + if (!isExtensionActive('sponsor')) { + // No, abort here + return false; + } elseif (!isSponsor()) { + // No sponsor, not allowed to withdraw! + return false; + } + } // END - if // Default is failed attempt $result = false; - // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(sprintf(WERNIS_API_PURPOSE_WITHDRAW, $GLOBALS['userid']))."\";"; - eval($eval); - // Prepare the request data $requestData = array( - 'sub_request' => "receive", - 't_uid' => bigintval($wdsId), - 't_md5' => $userMd5, - 'r_uid' => $_CONFIG['wernis_refid'], - 'amount' => bigintval($amount), - 'purpose' => urlencode(base64_encode($purpose)) + 'sub_request' => 'receive', + 't_uid' => bigintval($wdsId), + 't_md5' => $userMd5, + 'r_uid' => getConfig('wernis_refid'), + 'amount' => bigintval($amount), + 'purpose' => getMaskedMessage('WERNIS_API_PURPOSE_WITHDRAW', getMemberId()) ); // Return the result from the lower functions - $return = WERNIS_SEND_REQUEST("book.php", $requestData); + $return = WERNIS_SEND_REQUEST('book.php', $requestData); - if ($return['status'] == "OK") { + if ($return['status'] == 'OK') { // All fine! $result = true; @@ -262,30 +281,24 @@ function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { // Payout this amount -function WERNIS_EXECUTE_PAYOUT ($wdsId, $userMd5, $amount) { - global $_CONFIG; - +function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) { // Default is failed attempt $result = false; - // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(sprintf(WERNIS_API_PURPOSE_PAYOUT, $GLOBALS['userid']))."\";"; - eval($eval); - // Prepare the request data $requestData = array( - 'sub_request' => "send", - 't_uid' => bigintval($wdsId), - 't_md5' => $userMd5, - 'r_uid' => $_CONFIG['wernis_refid'], - 'amount' => bigintval($amount), - 'purpose' => urlencode(base64_encode($purpose)) + 'sub_request' => 'send', + 't_uid' => getConfig('wernis_refid'), + 't_md5' => getConfig('wernis_pass_md5'), + 'r_uid' => bigintval($wdsId), + 'amount' => bigintval($amount), + 'purpose' => getMaskedMessage('WERNIS_API_PURPOSE_PAYOUT', getMemberId()) ); // Return the result from the lower functions - $return = WERNIS_SEND_REQUEST("book.php", $requestData); + $return = WERNIS_SEND_REQUEST('book.php', $requestData); - if ($return['status'] == "OK") { + if ($return['status'] == 'OK') { // All fine! $result = true; @@ -304,32 +317,83 @@ function WERNIS_EXECUTE_PAYOUT ($wdsId, $userMd5, $amount) { } // Translate the status IN/OUT -function WERNIS_TRANSFER_STATUS ($status) { +function translateWernisTransferStatus ($status) { // Default status - $return = sprintf(WERNIS_STATUS_UNKNWOWN, $status); + $return = getMaskedMessage('WERNIS_STATUS_UNKNWOWN', $status); + + // Which status? switch ($status) { - case "IN": // Withdraw - $return = WERNIS_STATUS_WITHDRAW; + case 'IN': // Withdraw + $return = '{--WERNIS_STATUS_WITHDRAW--}'; break; - case "OUT": // Payout - $return = WERNIS_STATUS_PAYOUT; + case 'OUT': // Payout + $return = '{--WERNIS_STATUS_PAYOUT--}'; break; - case "FAILED": // Payout - $return = WERNIS_STATUS_FAILED; + case 'FAILED': // Payout + $return = '{--WERNIS_STATUS_FAILED--}'; break; - } + } // END - switch // Return the status return $return; } -function WERNIS_LOG_TRANSFER ($wdsId, $amount, $type = 'FAILED', $message = null, $status = null) { +// Log the transfer +function WERNIS_LOG_TRANSFER ($wdsId, $amount, $type = 'FAILED', $message = '', $status = '') { // Register this wernis movement - $result = 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($GLOBALS['userid'], bigintval($wdsId), bigintval($amount), $type, $message, $status), __FILE__, __LINE__); + 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(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: */ debugOutput('mode='.$mode.',points='.$points); + if (!in_array($mode, array('payout', 'withdraw'))) { + // Log error and abort + logDebugMessage(__FUNCTION__, __LINE__, "userid={getMemberId()},mode={$mode},points={$points}"); + return false; + } // END - if + + // Is there a percentage or fixed fee? + if (getConfig('wernis_'.$mode.'_fee_percent') > 0) { + // Percentage fee + $points -= $points * getConfig('wernis_'.$mode.'_fee_percent') / 100; + } elseif (getConfig('wernis_'.$mode.'_fee_fix') > 0) { + // Fixed fee + $points -= getConfig('wernis_'.$mode.'_fee_fix'); + } + + // Divide/multiply the factor + if ($mode == 'payout') { + // Divide for payout + $points = $points / getConfig('wernis_payout_factor'); + } else { + // Multiply for withdraw + $points = $points * getConfig('wernis_withdraw_factor'); + } + + // Return value + //* 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) { + // Percentage fee + $points += $points * getConfig('wernis_withdraw_fee_percent') / 100; + } elseif (getConfig('wernis_withdraw_fee_fix') > 0) { + // Fixed fee + $points += getConfig('wernis_withdraw_fee_fix'); + } + + // Return value + return $points; } -// +// [EOF] ?>