Pereiti prie turinio

PAYSERA+PHP problema


Rekomenduojami pranešimai

Sveiki, susidūriau su tokia problema, jog Paysera sistemoje, meta klaidą, kad tipo nėra ar neaptinka privalomojo žodelio "OK", nors jis yra tik vienas nurodytas, paslaugos žmonėms užsideda, bet iškyla kita problema, jog kai Paysera pagalvoja, kad tai gali būti klaida, siunčia dar du, tris kartus pakartotinai ir taip pratęsia jiems ne 30d., bet 60 ar 90.

Skambino Paysera techninis personalas ir sakė, jog galima rankiniu būdu prikabinti "header status 200" ar kažką tokio, kad sistema mestų ne +300 klaidą, o +200.

Ką daryti tokiu atveju?

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Sveiki, susidūriau su tokia problema, jog Paysera sistemoje, meta klaidą, kad tipo nėra ar neaptinka privalomojo žodelio "OK", nors jis yra tik vienas nurodytas, paslaugos žmonėms užsideda, bet iškyla kita problema, jog kai Paysera pagalvoja, kad tai gali būti klaida, siunčia dar du, tris kartus pakartotinai ir taip pratęsia jiems ne 30d., bet 60 ar 90.

Skambino Paysera techninis personalas ir sakė, jog galima rankiniu būdu prikabinti "header status 200" ar kažką tokio, kad sistema mestų ne +300 klaidą, o +200.

Ką daryti tokiu atveju?

gali pasidaryti, kad galetų tik vieną kartą atlikti callback'ą pagal order id.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Failuose, prieš aktyvuojant paslaugą, turi būti patikrinama ar ji jau nebuvo aktyvuota.

Tai yra toks dalykas, kaip paslaugų pratęsimas, jeigu siunti daugiau kartų.

 

 

<?php
require_once('mokejimai_webtopay.php');
require_once('geoiploc.php');

include('../config/db_connect.php');
include('../admin/ajax/rcon_hl_net.php');

$get = removeQuotes($_POST);

try
{
$response = WebToPay::validateAndParseData($get, $paysera_projectid, $paysera_sign);
$kns = ($response['amount']);

$sms = strlen($response['key']);
$sms_ip = substr($response['sms'], $sms+1);

$sms = $mysqli->query("SELECT * FROM `unban_sms_config` WHERE `key` = '".$response['key']."' AND `price` = '".$kns."' AND `message_type` != 'unban'");
$sms_price = $sms->fetch_object();

if(strlen($sms_ip) < 3)
{
	echo "OK"; //zinutes IP turi buti ilgesnis nei 3 simboliai
}
else if($kns == $sms_price->price)
{
	$result = $mysqli_amx->query("SELECT * FROM `".$amxbans_prefix."_amxadmins` WHERE `username` = '".$sms_ip."' LIMIT 1");

	if($result->num_rows)
	{
		$assoc = $result->fetch_object();

		$rst = $mysqli->query("SELECT * FROM `unban_order_prvilegies` WHERE `name` = '".$sms_price->message_type."' LIMIT 1");
		$rst_v = $rst->fetch_object();

		if($rst->num_rows)
		{
			if($assoc->access == $rst_v->priv)
			{
				$timeleft = $assoc->expired + ($sms_price->priv_time * 24 * 60 * 60);

				$mysqli_amx->query("UPDATE `".$amxbans_prefix."_amxadmins` SET `expired` = '".$timeleft."', `created` = '".time()."', `nr` = '".$response['from']."' WHERE `username` = '".$sms_ip."'");

				if(getCountryFromIP($sms_ip, "code") != "LT")
					echo "OK";
				else
					echo "OK";
			}
			else
			{
				$timeleft = time() + ($sms_price->priv_time * 24 * 60 * 60);

				$mysqli_amx->query("UPDATE `".$amxbans_prefix."_amxadmins` SET `access` = '".$rst_v->priv."', `expired` = '".$timeleft."', `created` = '".time()."', `nr` = '".$response['from']."' WHERE `username` = '".$sms_ip."'");

				if(getCountryFromIP($sms_ip, "code") != "LT")
					echo "OK";
				else
					echo "OK";
			}
		}
		else
		{
			if(getCountryFromIP($sms_ip, "code") != "LT")
				echo "OK";
			else
				echo "OK";
		}
	}
	else
	{
		$rst = $mysqli->query("SELECT * FROM `unban_order_prvilegies` WHERE `name` = '".$sms_price->message_type."' LIMIT 1");

		if($rst->num_rows)
		{
			$rst_v = $rst->fetch_object();

			$timeleft = time() + ($sms_price->priv_time * 24 * 60 * 60);

			if(filter_var($sms_ip, FILTER_VALIDATE_IP))
			{
				$mysqli_amx->query("INSERT INTO ".$amxbans_prefix."_amxadmins (`username`, `access`, `flags`, `nickname`, `ashow`, `created`, `expired`, `nr`, `days`, `steamid`) VALUES ('".$sms_ip."', '".$rst_v->priv."', 'de', '".$sms_ip."', '0', '".time()."', '".$timeleft."', '".$response['from']."', '".$sms_price->priv_time."', '".$sms_ip."') ");
			}
			else
			{
				$password_set = randomPassword(6);
				$mysqli_amx->query("INSERT INTO ".$amxbans_prefix."_amxadmins (`username`, `password`, `access`, `flags`, `nickname`, `ashow`, `created`, `expired`, `nr`, `days`, `steamid`) VALUES ('".$sms_ip."', '".$password_set."', '".$rst_v->priv."', 'a', '".$sms_ip."', '0', '".time()."', '".$timeleft."', '".$response['from']."', '".$sms_price->priv_time."', '".$sms_ip."') ");
			}

			if($mysqli_amx->query("SELECT * FROM `".$amxbans_prefix."_admins_servers`"))
			{
				sleep(1);

				while($row = $servers_lst->fetch_object())
				{						
					$local_ips = gethostbyname($row->ip).":".$row->port;

					$result2 = $mysqli_amx->query("SELECT * FROM `amx_serverinfo` WHERE `address` = '".$local_ips."' LIMIT 1");

					if($result2->num_rows)
					{
						$result = $mysqli_amx->query("SELECT * FROM `".$amxbans_prefix."_amxadmins` WHERE `username` = '".$sms_ip."' LIMIT 1");
						$ft = $result->fetch_object();
						$ft2 = $result2->fetch_object();

						$mysqli_amx->query("INSERT INTO `".$amxbans_prefix."_admins_servers` (`admin_id`, `server_id`, `use_static_bantime`) VALUES ('".$ft->id."', '".$ft2->id."', 'no')");
					}
				}
			}

			if(filter_var($sms_ip, FILTER_VALIDATE_IP)) {
				echo "OK";
			}
			else {
				echo "OK".$password_set;
			}
		}
		else
		{
			if(getCountryFromIP($sms_ip, "code") != "LT")
				echo "OK";
			else
				echo "OK";
		}
	}
	reload_admins($mysqli_amx);
}
else
{
	if(getCountryFromIP($sms_ip, "code") == "LT")
		echo "OK";
	else
		echo "OK";
}
}
catch (Exception $e) {
   echo get_class($e).': '.$e->getMessage();
}

function removeQuotes($post) {
   if (get_magic_quotes_gpc()) {
       foreach ($post as &$var) {
           if (is_array($var)) {
               $var = removeQuotes($var);
           } else {
               $var = stripslashes($var);
           }
       }
   }
   return $post;
}
?>

Redagavo venom
Nuoroda į pranešimą
Dalintis kituose puslapiuose

if(getCountryFromIP($sms_ip, "code") != "LT")
   echo "OK";
else
   echo "OK";

 

Kam tuos if'us rašai, jei vistiek abu OK išveda?

 

Prieš tai buvo skirtingi atsakymai, bet paysera darbuotojai pasakė, kad tiesiog pakeisčiau į žodelį OK,

kaip reikia prikabinti prie headerio tą +200, sakė jog tai būtų pats paprasčiausias būdas.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...