Stomp::ack

stomp_ack

(PECL stomp >= 0.1.0)

Stomp::ack -- stomp_ackValide la réception d'un message

Description

Style orienté objet (méthode) :

public Stomp::ack ( mixed $msg [, array $headers ] ) : bool

Style procédural :

stomp_ack ( resource $link , mixed $msg [, array $headers ] ) : bool

Valide la réception d'un message par une souscription.

Liste de paramètres

link

Style procédural uniquement : L'identifiant stomp retourné par la fonctionstomp_connect().

msg

Le message où l'identifiant du message à valider.

headers

Tableau associatif contenantles en-têtes aditionnels (exemple : receipt).

Valeurs de retour

Cette fonction retourne TRUE en cas de succès ou FALSE si une erreur survient.

Notes

Note:

Un en-tête de transaction peut être spécifié, indiquant que la confirmation des messages doit faire partie de la transaction.

Astuce

Stomp est, par nature, asynchrone. Une communication synchrone peut être implémentée en ajoutant un en-tête receipt. Ceci fera que les méthodes ne retourneront rien tant que le message de confirmation n'aura pas été reçu ou tant que le délai d'attente ne sera pas atteint.

Exemples

Exemple #1 Style orienté objet

<?php

$queue  
'/queue/foo';
$msg    'bar';

/* connexion */
try {
    
$stomp = new Stomp('tcp://localhost:61613');
} catch(
StompException $e) {
    die(
'Connection failed: ' $e->getMessage());
}

/* envoi d'un message à la file 'foo' */
$stomp->send($queue$msg);

/* souscription aux messages de la file 'foo' */
$stomp->subscribe($queue);

/* lecture d'un message */
$frame $stomp->readFrame();

if (
$frame->body === $msg) {
    
/* confirmation de la réception du message */
    
$stomp->ack($frame);
}

/* supprime la souscription à la file 'foo' */
$stomp->unsubscribe($queue);

/* fermeture de la connexion */
unset($stomp);

?>

Exemple #2 Style procédural

<?php

$queue  
'/queue/foo';
$msg    'bar';

/* connexion */
$link stomp_connect('ssl://localhost:61612');

/* vérification de la connexion */
if (!$link) {
    die(
'Connection failed: ' stomp_connect_error());
}

/* début de la transaction */
stomp_begin($link't1');

/* envoi d'un message à la file 'foo' */
stomp_send($link$queue$msg, array('transaction' => 't1'));

/* validation de la transaction */
stomp_commit($link't1');

/* souscription aux messages de la file 'foo' */
stomp_subscribe($link$queue);

/* lecture d'un message */
$frame stomp_read_frame($link);

if (
$frame['body'] === $msg) {
    
/* confirmation de la réception du message */
    
stomp_ack($link$frame['headers']['message-id']);
}

/* supprime la souscription à la file 'foo' */
stomp_unsubscribe($link$queue);

/* fermeture de la connexion */
stomp_close($link);

?>