X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Flibs%2Fwernis_functions.php;h=61d12747ef551df73c0d7b7512896ebf4b7cef94;hb=46f2e389417a40f1029612b58cb285416ccae7a5;hp=812fbf20ec0a60dd94ebe5cc12c0f183ae81514d;hpb=60494e212a67fe360bfbb481eb4928480a6f379b;p=mailer.git diff --git a/inc/libs/wernis_functions.php b/inc/libs/wernis_functions.php index 812fbf20ec..61d12747ef 100644 --- a/inc/libs/wernis_functions.php +++ b/inc/libs/wernis_functions.php @@ -10,7 +10,12 @@ * -------------------------------------------------------------------- * * Kurzbeschreibung : Alle Ihrer gesammelten Punkte * * -------------------------------------------------------------------- * - * * + * $Revision:: $ * + * $Date:: $ * + * $Tag:: 0.2.1-FINAL $ * + * $Author:: $ * + * 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 * * For more information visit: http://www.mxchange.org * @@ -32,27 +37,25 @@ ************************************************************************/ // Some security stuff... -if (ereg(basename(__FILE__), $_SERVER['PHP_SELF'])) { +if (!defined('__SECURITY')) { $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php"; require($INC); } // Sets a status message and code function WERNIS_STATUS_MESSAGE ($msg, $status) { - global $WERNIS; - $WERNIS['message'] = $msg; - $WERNIS['status'] = $status; + $GLOBALS['wernis_data']['message'] = $msg; + $GLOBALS['wernis_data']['status'] = $status; } // Get the status message function GET_WERNIS_ERROR_MESSAGE () { - global $WERNIS; - if (isset($WERNIS['message'])) { + if (isset($GLOBALS['wernis_data']['message'])) { // Use raw message - return $WERNIS['message']; - } elseif (isset($WERNIS['status'])) { + return $GLOBALS['wernis_data']['message']; + } elseif (isset($GLOBALS['wernis_data']['status'])) { // Fall-back to status - return sprintf(WERNIS_ERROR_STATUS, $WERNIS['status']); + return sprintf(WERNIS_ERROR_STATUS, $GLOBALS['wernis_data']['status']); } else { // Something bad happend return WERNIS_UNKNOWN_ERROR; @@ -61,13 +64,9 @@ function GET_WERNIS_ERROR_MESSAGE () { // Get the status code function GET_WERNIS_ERROR_CODE () { - global $WERNIS; - if (isset($WERNIS['status'])) { + if (isset($GLOBALS['wernis_data']['status'])) { // Use raw message - return $WERNIS['status']; - } elseif (isset($WERNIS['status'])) { - // Fall-back to status - return sprintf(WERNIS_ERROR_STATUS, $WERNIS['status']); + return $GLOBALS['wernis_data']['status']; } else { // Something bad happend return WERNIS_UNKNOWN_ERROR; @@ -76,8 +75,6 @@ function GET_WERNIS_ERROR_CODE () { // Sends out a request to the API and returns it's result function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { - global $_CONFIG; - // Is the requestData an array? if (!is_array($requestData)) { // Then abort here! @@ -85,34 +82,35 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { '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 ); - } + } // END - if + + // Add more request data + $requestData['api_id'] = getConfig(('wernis_api_id')); + $requestData['api_key'] = getConfig('wernis_api_md5'); // Construct the request string - $requestString = $_CONFIG['wernis_api_url'] . $scriptName."?api_id=".$_CONFIG['wernis_api_id']."&api_key=".$_CONFIG['wernis_api_md5']; - foreach ($requestData as $key=>$value) { - $requestString .= "&".$key."=".$value; - } + $requestString = getConfig('wernis_api_url') . $scriptName; // Get the raw response from the lower function - $response = MXCHANGE_OPEN($requestString); + $response = POST_URL($requestString, $requestData); // Check the response header if all is fine if (strpos($response[0], "200") === false) { // Something bad happend... :( return array( - 'status' => "request_eror", + 'status' => "request_error", 'message' => sprintf(WERNIS_API_REQUEST_ERROR, $response[0]) ); - } + } // END - if // All (maybe) fine so remove the response header from server $response = $response[(count($response) - 1)]; @@ -121,7 +119,7 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { if (substr($response, 0, 1) == "&") { // Remove the leading & (which can be used in Flash) $response = substr($response, 1); - } + } // END - if // Bring back the response $data = explode("=", $response); @@ -130,9 +128,10 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { $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 $return = array( 'status' => "auth_failed", @@ -140,6 +139,8 @@ function WERNIS_SEND_REQUEST ($scriptName, $requestData = array()) { ); break; + case "LOCKED": // User account is locked! + case "PASS": // Bad passphrase entered case "USER": // Missing account or invalid password $return = array( 'status' => "user_failed", @@ -169,6 +170,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])); $return = array( 'status' => "request_failed", 'message' => sprintf(WERNIS_API_REQUEST_FAILED, $data[1]) @@ -189,8 +191,7 @@ 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 @@ -209,22 +210,33 @@ function WERNIS_TEST_API () { } // Widthdraw this amount -function WERNIS_EXECUTE_WITHDRAW($userId, $userMd5, $amount) { - global $_CONFIG; +function WERNIS_EXECUTE_WITHDRAW ($wdsId, $userMd5, $amount) { + // Is the sponsor extension installed? + if (getConfig('wernis_withdraw_active') != "Y") { + if (!EXT_IS_ACTIVE("sponsor")) { + // No, abort here + return false; + } elseif (!IS_SPONSOR()) { + // No sponsor, not allowed to withdraw! + return false; + } + } // END - if + + // Default is failed attempt $result = false; // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(WERNIS_API_PURPOSE_WITHDRAW)."\";"; + $eval = "\$purpose = \"".COMPILE_CODE(sprintf(WERNIS_API_PURPOSE_WITHDRAW, getUserId()))."\";"; eval($eval); // Prepare the request data $requestData = array( 'sub_request' => "receive", - 't_uid' => bigintval($userId), + 't_uid' => bigintval($wdsId), 't_md5' => $userMd5, - 'r_uid' => $_CONFIG['wernis_refid'], + 'r_uid' => getConfig('wernis_refid'), 'amount' => bigintval($amount), - 'purpose' => urlencode(base64_encode($purpose)) + 'purpose' => encodeString($purpose, false) ); // Return the result from the lower functions @@ -233,9 +245,15 @@ function WERNIS_EXECUTE_WITHDRAW($userId, $userMd5, $amount) { if ($return['status'] == "OK") { // All fine! $result = true; + + // Log the transfer + WERNIS_LOG_TRANSFER($wdsId, $amount, 'IN'); } else { // Status failture text WERNIS_STATUS_MESSAGE($return['message'], $return['status']); + + // Log the transfer + WERNIS_LOG_TRANSFER($wdsId, $amount, 'FAILED', $return['message'], $return['status']); } // Return result @@ -244,22 +262,22 @@ function WERNIS_EXECUTE_WITHDRAW($userId, $userMd5, $amount) { // Payout this amount -function WERNIS_EXECUTE_PAYOUT($userId, $userMd5, $amount) { - global $_CONFIG; +function WERNIS_EXECUTE_PAYOUT ($wdsId, $amount) { + // Default is failed attempt $result = false; // Prepare the purpose - $eval = "\$purpose = \"".COMPILE_CODE(WERNIS_API_PURPOSE_PAYOUT)."\";"; + $eval = "\$purpose = \"".COMPILE_CODE(sprintf(getMessage('WERNIS_API_PURPOSE_PAYOUT'), getUserId()))."\";"; eval($eval); // Prepare the request data $requestData = array( 'sub_request' => "send", - 't_uid' => bigintval($userId), - 't_md5' => $userMd5, - 'r_uid' => $_CONFIG['wernis_refid'], + 't_uid' => getConfig('wernis_refid'), + 't_md5' => getConfig('wernis_pass_md5'), + 'r_uid' => bigintval($wdsId), 'amount' => bigintval($amount), - 'purpose' => urlencode(base64_encode($purpose)) + 'purpose' => encodeString($purpose, false) ); // Return the result from the lower functions @@ -268,9 +286,15 @@ function WERNIS_EXECUTE_PAYOUT($userId, $userMd5, $amount) { if ($return['status'] == "OK") { // All fine! $result = true; + + // Log the transfer + WERNIS_LOG_TRANSFER($wdsId, $amount, 'OUT'); } else { // Status failture text WERNIS_STATUS_MESSAGE($return['message'], $return['status']); + + // Log the transfer + WERNIS_LOG_TRANSFER($wdsId, $amount, 'FAILED', $return['message'], $return['status']); } // Return result @@ -278,7 +302,7 @@ function WERNIS_EXECUTE_PAYOUT($userId, $userMd5, $amount) { } // Translate the status IN/OUT -function WERNIS_TRANSFER_STATUS($status) { +function WERNIS_TRANSFER_STATUS ($status) { // Default status $return = sprintf(WERNIS_STATUS_UNKNWOWN, $status); switch ($status) { @@ -289,11 +313,90 @@ function WERNIS_TRANSFER_STATUS($status) { case "OUT": // Payout $return = WERNIS_STATUS_PAYOUT; break; + + case "FAILED": // Payout + $return = WERNIS_STATUS_FAILED; + break; } // Return the status return $return; } +// 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__); +} + +// Take fees and factor +function WERNIS_TAKE_FEE ($points, $mode) { + // Payout or withdraw are allowed modes! + //* DEBUG: */ echo "mode={$mode},points={$points}
\n"; + if (!in_array($mode, array('payout', 'withdraw'))) { + // Log error and abort + DEBUG_LOG(__FUNCTION__, __LINE__, "uid={getUserId()},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: */ echo "mode={$mode},points={$points}
\n"; + 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; +} + +// 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; + } // END - if + + // Add both factors + $array['payout_factor'] = TRANSLATE_COMMA(getConfig('wernis_payout_factor')); + $array['withdraw_factor'] = TRANSLATE_COMMA(getConfig('wernis_withdraw_factor')); + + // Add all fees + $array['payout_fee_percent'] = TRANSLATE_COMMA(getConfig('wernis_payout_fee_percent')); + $array['withdraw_fee_percent'] = TRANSLATE_COMMA(getConfig('wernis_withdraw_fee_percent')); + $array['payout_fee_fix'] = TRANSLATE_COMMA(getConfig('wernis_payout_fee_fix')); + $array['withdraw_fee_fix'] = TRANSLATE_COMMA(getConfig('wernis_withdraw_fee_fix')); +} + // ?>