Пример #1
0
// $racct->putAttribute(RADIUS_ACCT_OUTPUT_PACKETS, 1212);
$result = $racct->send();
if (PEAR::isError($result)) {
    printf("Radius send failed: %s<br>\n", $result->getMessage());
    exit;
} else {
    if ($result === true) {
        printf("Radius Acounting succeeded<br>\n");
    } else {
        printf("Radius Acounting rejected<br>\n");
    }
}
$racct->close();
// Wait a bit, that we can put the session-time
sleep(2);
$racct = new Auth_RADIUS_Acct_Stop();
$racct->addServer('localhost', 0, 'testing123');
$racct->username = $username;
$racct->session_time = time() - $starttime;
$status = $racct->start();
if (PEAR::isError($status)) {
    printf("Radius start: %s<br>\n", $status->getMessage());
    exit;
}
// you can put any additional attributes here
// $racct->putAttribute(RADIUS_ACCT_TERMINATE_CAUSE, RADIUS_TERM_SESSION_TIMEOUT);
$result = $racct->send();
if (PEAR::isError($result)) {
    printf("Radius send failed: %s<br>\n", $result->getMessage());
    exit;
} else {
Пример #2
0
 /**
  * Final update and stop accounting
  *
  * @param string $conn_id The connection id (the token id) for the
  *                        connection to work on
  * @param string $errmsg  Reference of error message
  *
  * @return bool Returns whether successful or not
  */
 function acctStop($conn_id, &$errmsg = null)
 {
     // Call parent method
     parent::acctStop($conn_id);
     $db = AbstractDb::getObject();
     // Init values
     $info = null;
     $conn_id = $db->escapeString($conn_id);
     if (Dependency::check("Auth_RADIUS", $errmsg)) {
         $db->execSqlUniqueRes("SELECT CURRENT_TIMESTAMP, *, CASE WHEN ((CURRENT_TIMESTAMP - reg_date) > networks.validation_grace_time) THEN true ELSE false END AS validation_grace_time_expired FROM connections JOIN users ON (users.user_id=connections.user_id) JOIN networks ON (users.account_origin = networks.network_id) WHERE connections.conn_id={$conn_id}", $info, false);
         // RADIUS accounting stop
         // Session is completely based on Database time
         $session_time = strtotime($info['now']) - strtotime($info['timestamp_in']);
         $radius_acct = new Auth_RADIUS_Acct_Stop();
         $radius_acct->addServer($this->mRadius_hostname, $this->mRadius_acct_port, $this->mRadius_secret_key);
         // Specify the user for which accounting will be done
         $radius_acct->username = $info['username'];
         $racct->session_time = $session_time;
         // Set the session ID to the generated token
         $radius_acct->session_id = $info['token'];
         $status = $radius_acct->start();
         if (PEAR::isError($status)) {
             $errmsg = "Could not initiate PEAR RADIUS class.";
             return false;
         }
         // Cause of session termination
         $radius_acct->putAttribute(RADIUS_ACCT_TERMINATE_CAUSE, RADIUS_TERM_SESSION_TIMEOUT);
         $result = $radius_acct->send();
         if (PEAR::isError($result)) {
             $errmsg = "Could not send accounting request to RADIUS server.";
             return false;
         } else {
             if ($result !== true) {
                 $radius_acct->close();
                 $errmsg = "Accounting request rejected by RADIUS server.";
                 return false;
             }
         }
         $radius_acct->close();
         return true;
     } else {
         return false;
     }
 }