PHP Query (show your server on your website)
#21

Quote:
Originally Posted by Programie
How can I query the amount of NPCs on the server?
You could send an rcon command to the server and get the output of it..
Reply
#22

Quote:
Originally Posted by !MaVe
Quote:
Originally Posted by Programie
How can I query the amount of NPCs on the server?
You could send an rcon command to the server and get the output of it..
Oh? Do explain!
Reply
#23

Quote:
Originally Posted by /^We(stie|z+[e|a
r)$/ ]
Quote:
Originally Posted by !MaVe
Quote:
Originally Posted by Programie
How can I query the amount of NPCs on the server?
You could send an rcon command to the server and get the output of it..
Oh? Do explain!
There isn't much to explain there..
You can send an rcon command to the server via this sdk, this is the function:

PHP Code:
function RCON($rcon$command)
  {
      echo 
'Password '.$rcon.' with '.$command;
      if (
$this->SendPacket('x '.$rcon.' '.$command) === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }

      
// Pop the first 11 bytes from the response;
      
$aReturnArray fread$this->rSocketID11 );

      echo 
fread$this->rSocketID11 );

      return 
$aReturnArray;
  } 
In a script, you can check if some rcon command was sent (OnRconCommand) and send something back to the sdk
Reply
#24

Oh. Well, what you said was pretty ambiguous. I know how RCON works, in fact I know pretty much how all the public query system works. You made it sound like there's a command for returning the amount of NPCs on a server, but you meant actually creating a command. Hmm.

(off topic: Can you get the SDK right now?)
Reply
#25

I don't know what's wrong, but it keeps showing Server is offline ...
Reply
#26

I was just testing this and it sorta fucked up,

With servers from 0 - 100 players it will display the "online players", but for servers with 101 + online players, it won't list the players.

Anyway to fix this?
Reply
#27

Quote:
Originally Posted by Takumi_
I don't know what's wrong, but it keeps showing Server is offline ...
Same here, I'm using PHP 5.

PS: I've chmodded both files to give permission for information retrieval from the server however it still says "Server is offline"
Reply
#28

Thanks it's very helped me..
Reply
#29

Quote:
Originally Posted by Takumi_
I don't know what's wrong, but it keeps showing Server is offline ...
Quote:
Originally Posted by [XSZ
FrostBytez ]
Quote:
Originally Posted by Takumi_
I don't know what's wrong, but it keeps showing Server is offline ...
Same here, I'm using PHP 5.

PS: I've chmodded both files to give permission for information retrieval from the server however it still says "Server is offline"
Your webhosting most likely probably has firewalls blocking anything but port 80.
Also note that you need sockets for this to work.

Quote:
Originally Posted by DeathGod
I was just testing this and it sorta fucked up,

With servers from 0 - 100 players it will display the "online players", but for servers with 101 + online players, it won't list the players.

Anyway to fix this?
No, this is a limit in SA-MP itself to prevent DoS (listing 500 players is a lot of data, so you could flood the server with very small query requests)
Reply
#30

Quote:
Originally Posted by Woet
...
And? You can also flood the server with requests for rules...?
Reply
#31

Is there any function here that can return 0(server is offline) or 1(server is online) ?
Or can it be modified to make this?

function ServerOnline()
Reply
#32

You could use my PHP query API (shameless advertising here) which has it built in, or you could add this. It's untested though.

Code:
<?php

	function isServerOnline()
	{
		if($this->sendPacket('p4150') === FALSE)
		{
			return false;
		}
		
		if(fread($this->rSocket, 15) === FALSE)
		{
			return false;
		}
		
		return true;
	}

?>
Reply
#33

Quote:
Originally Posted by /^We(stie|z+[e|a
r)$/ ]
You could use my PHP query API (shameless advertising here) which has it built in, or you could add this. It's untested though.
Will I be using the function 'isOnline' from SampRconAPI.php or SampQueryAPI.php, they are both different it seems.

Thanks.
Reply
#34

If you err, want to query a server, then you use the query library, obviously.
Reply
#35

Can you upload with an another way plz?

because all "'" fucked on the code

Thank you
Reply
#36

Quote:
Originally Posted by scott1
View Post
Can you upload with an another way plz?

because all "'" fucked on the code

Thank you
It's just an apostrophe, probably malformed unicode from the switch to vBulletin.


PHP Code:
<?php
require "samp_query.php";
$serverIP "91.121.209.20";
$serverPort 7777;
try
{
    
$rQuery = new QueryServer$serverIP$serverPort );
    
$aInformation $rQuery->GetInfo( );
    
$aServerRules $rQuery->GetRules( );
    
$aBasicPlayer $rQuery->GetPlayers( );
    
$aTotalPlayers $rQuery->GetDetailedPlayers( );
    
$rQuery->Close( );
}
catch (
QueryServerException $pError)
{
    echo 
'Server is offline';
}
if(isset(
$aInformation) && is_array($aInformation)){
?>
  <b>General Information</b>
  <table width="400">
      <tr>
          <td>Hostname</td>
          <td><?php echo htmlentities($aInformation['Hostname']); ?></td>
      </tr>
      <tr>
          <td>Gamemode</td>
          <td><?php echo htmlentities($aInformation['Gamemode']); ?></td>
      </tr>
      <tr>
          <td>Players</td>
          <td><?php echo $aInformation['Players']; ?> / <?php echo $aInformation['MaxPlayers']; ?></td>
      </tr>
      <tr>
          <td>Map</td>
          <td><?php echo htmlentities($aInformation['Map']); ?></td>
      </tr>
      <tr>
          <td>Weather</td>
          <td><?php echo $aServerRules['weather']; ?></td>
      </tr>
      <tr>
          <td>Time</td>
          <td><?php echo $aServerRules['worldtime']; ?></td>
      </tr>
      <tr>
          <td>Version</td>
          <td><?php echo $aServerRules['version']; ?></td>
      </tr>
      <tr>
          <td>Password</td>
          <td><?php echo $aInformation['Password'] ? 'Yes' 'No'?></td>
      </tr>
  </table>
  <br />
  <b>Online Players</b>
  <?php
  
if(!is_array($aTotalPlayers) || count($aTotalPlayers) == 0){
      echo 
'<br /><i>None</i>';
  } else {
  
?>
      <table width="400">
          <tr>
              <td><b>Player ID</b></td>
              <td><b>Nickname</b></td>
              <td><b>Score</b></td>
              <td><b>Ping</b></td>
          </tr>
      <?php
      
foreach($aTotalPlayers AS $id => $value){
      
?>
          <tr>
              <td><?php echo $value['PlayerID']; ?></td>
              <td><?php echo htmlentities($value['Nickname']); ?></td>
              <td><?php echo $value['Score']; ?></td>
              <td><?php echo $value['Ping']; ?></td>
          </tr>
      <?php
      
}
    
      echo 
'</table>';
    }
}
?>
Class:
PHP Code:
<?php
/*********************************************
*
* SA-MP Query Server Version 0.3
*
* This class provides you with an easy to use interface to query
* your SA-MP 0.2 servers. Usage is simple, but has changed a bit
* since the last version, so be sure to check out the examples
* that come along with this script. It is updated with some of
* the new SA-MP 0.2 query-techniques that can be used.
*
* Author: Peter Beverloo
*     peter@dmx-network.com
*     Ex SA-MP Developer
*
* Updated: Wouter van Eekelen
*     wouter.van.eekelen@serverffs.com
*     SA-MP Betatester
*********************************************/
class QueryServer
{
  
// Private variables used for the query-ing.
  
private $szServerIP;
  private 
$iPort;
  private 
$rSocketID;
  private 
$bStatus;
  
// The __construct function gets called automatically
  // by PHP once the class gets initialized.
  
function __construct$szServerIP$iPort )
  {
      
$this->szServerIP $this->VerifyAddress$szServerIP );
      
$this->iPort $iPort;
      if (empty( 
$this->szServerIP ) || !is_numeric$iPort )) {
          throw new 
QueryServerException'Either the ip-address or the port isn\'t filled in correctly.' );
      }
      
$this->rSocketID = @fsockopen'udp://' $this->szServerIP$iPort$iErrorNo$szErrorStr);
      if (!
$this->rSocketID) {
          throw new 
QueryServerException'Cannot connect to the server: ' $szErrorStr );
      }
      
socket_set_timeout$this->rSocketID0500000 );
      
$this->bStatus true;
  }
  
// The VerifyAddress function verifies the given hostname/
  // IP address and returns the actual IP Address.
  
function VerifyAddress$szServerIP )
  {
      if (
ip2long$szServerIP ) !== false && 
        
long2ipip2long$szServerIP ) ) == $szServerIP ) {
          return 
$szServerIP;
      }
      
$szAddress gethostbyname$szServerIP );
      if (
$szAddress == $szServerIP) {
          return 
"";
      }
      return 
$szAddress;
  }
  
// The SendPacket function sends a packet to the server which
  // requests information, based on the type of packet send.
  
function SendPacket$cPacket )
  {
      
$szPacket 'SAMP';
      
$aIpChunks explode'.'$this->szServerIP );
      foreach( 
$aIpChunks as $szChunk ) {
          
$szPacket .= chr$szChunk );
      }
      
$szPacket .= chr$this->iPort 0xFF );
      
$szPacket .= chr$this->iPort >> 0xFF );
      
$szPacket .= $cPacket;
      return 
fwrite$this->rSocketID$szPacketstrlen$szPacket ) );
  }
  
// The GetPacket() function returns a specific number of bytes
  // read from the socket. This uses a special way of getting stuff.
  
function GetPacket$iBytes )
  {
      
$iResponse fread$this->rSocketID$iBytes );
      if (
$iResponse === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
$iLength ord$iResponse );
      if (
$iLength 0)
          return 
fread$this->rSocketID$iLength );
      return 
"";
  }
  
// After we're done, the connection needs to be closed using
  // the Close() function. Otherwise stuff might go wrong.
  
function Close( )
  {
      if (
$this->rSocketID !== false) {
          
fclose$this->rSocketID );
      }
  }
  
// A little function that's needed to properly convert the
  // four bytes we're recieving to integers to an actual PHP
  // integer. ord() can't handle value's higher then 255.
  
function toInteger$szData )
  {
      
$iInteger 0;
      
$iInteger += ( ord( @$szData] ) );
      
$iInteger += ( ord( @$szData] ) << );
      
$iInteger += ( ord( @$szData] ) << 16 );
      
$iInteger += ( ord( @$szData] ) << 24 );
      if( 
$iInteger >= 4294967294 )
          
$iInteger -= 4294967296;
      return 
$iInteger;
  }
  
// The GetInfo() function returns basic information about the
  // server, like the hostname, number of players online etc.
  
function GetInfo( )
  {
      if (
$this->SendPacket('i') === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
$szFirstData fread$this->rSocketID);
      if (empty( 
$szFirstData ) || $szFirstData != 'SAMP') {
          throw new 
QueryServerException'The server at ' $this->szServerIP ' is not an SA-MP Server.' );
      }
      
// Pop the first seven characters returned.
      
fread$this->rSocketID);
      return array (
          
'Password'  =>  ordfread$this->rSocketID) ),
          
'Players'  =>  $this->toIntegerfread$this->rSocketID) ),
          
'MaxPlayers' =>  $this->toIntegerfread$this->rSocketID) ),
          
'Hostname'  =>  $this->GetPacket),
          
'Gamemode'  =>  $this->GetPacket),
          
'Map'    =>  $this->GetPacket)
      );
  }
  
// The GetRules() function returns the rules which are set
  // on the server, e.g. the gravity, version etcetera.
  
function GetRules( )
  {
      if (
$this->SendPacket('r') === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
// Pop the first 11 bytes from the response;
      
fread$this->rSocketID11 );
      
$iRuleCount ordfread$this->rSocketID) );
      
$aReturnArray = array( );
      for( 
$i 0$i $iRuleCount$i ++ ) {
          
$szRuleName $this->GetPacket);
          
$aReturnArray$szRuleName ] = $this->GetPacket);
      }
      return 
$aReturnArray;
  }
  
// The GetPlayers() function is pretty much simelar to the
  // detailed function, but faster and contains less information.
  
function GetPlayers( )
  {
      if (
$this->SendPacket('c') === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
// Again, pop the first eleven bytes send;
      
fread$this->rSocketID11 );
      
$iPlayerCount ordfread$this->rSocketID) );
      
$aReturnArray = array( );
      for( 
$i 0$i $iPlayerCount$i ++ )
      {
          
$aReturnArray[ ] = array (
              
'Nickname' => $this->GetPacket),
              
'Score'  => $this->toIntegerfread$this->rSocketID) )
          );
      }
      return 
$aReturnArray;
  }
  
// The GetDetailedPlayers() function returns the player list,
  // but in a detailed form inclusing the score and the ping.
  
function GetDetailedPlayers( )
  {
      if (
$this->SendPacket('d') === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
// Skip the first 11 bytes of the response;
      
fread$this->rSocketID11 );
      
$iPlayerCount ordfread$this->rSocketID) );
      
$aReturnArray = array( );
      for( 
$i 0$i $iPlayerCount$i ++ ) {
          
$aReturnArray[ ] = array(
              
'PlayerID'  => $this->toIntegerfread$this->rSocketID) ),
              
'Nickname'  => $this->GetPacket),
              
'Score'   => $this->toIntegerfread$this->rSocketID) ),
              
'Ping'    => $this->toIntegerfread$this->rSocketID) )
          );
      }
      return 
$aReturnArray;
  }
function 
RCON($rcon$command)
  {
      echo 
'Password '.$rcon.' with '.$command;
      if (
$this->SendPacket('x '.$rcon.' '.$command) === false) {
          throw new 
QueryServerException'Connection to ' $this->szServerIP ' failed or has dropped.' );
      }
      
// Pop the first 11 bytes from the response;
      
$aReturnArray fread$this->rSocketID11 );
      echo 
fread$this->rSocketID11 );
      return 
$aReturnArray;
  }
}
/*********************************************
*
* The QueryServerException is used to throw errors when querying
* a specific server. That way we force the user to use proper
* error-handling, and preferably even a try-/catch statement.
*
**********************************************/
class QueryServerException extends Exception
{
  
// The actual error message is stored in this variable.
  
private $szMessage;
  
// Again, the __construct function gets called as soon
  // as the exception is being thrown, in here we copy the message.
  
function __construct$szMessage )
  {
      
$this->szMessage $szMessage;
  }
  
// In order to read the exception being thrown, we have
  // a .NET-like toString() function, which returns the message.
  
function toString( )
  {
      return 
$this->szMessage;
  }
}
?>
Reply
#37

@Calgon: your code not work return 'Server is offline' ... i change ip to online server
Reply
#38

Yeah that code doesn't work for some reason.
Reply
#39

Keeps giving me "unexpected" errors, any help?

Thnx.


Nevermind, Hadn't seen Calgon's latest post. Sorry bout that!
Reply
#40

Send me fixed query for 0.3b? this query not work
Reply


Forum Jump:


Users browsing this thread: 5 Guest(s)