Gerenciando tópicos no Amazon SNS com o AWS SDK for PHP versão 3 - AWS SDK for PHP

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

Gerenciando tópicos no Amazon SNS com o AWS SDK for PHP versão 3

Para enviar notificações para Amazon Simple Queue Service (Amazon SQS), URLs de HTTP/HTTPS, e-mail, AWS SMS ou AWS Lambda, primeiramente é necessário criar um tópico que gerencie a entrega de mensagens a todos os assinantes desse tópico.

Em relação ao padrão de design do observador, o tópico é semelhante ao assunto. Após a criação do tópico, adicione assinantes que serão notificados automaticamente quando uma mensagem for publicada no tópico.

Saiba mais sobre como assinar tópicos em Gerenciamento de assinaturas no Amazon SNS com o AWS SDK for PHP versão 3.

Os exemplos a seguir mostram como:

  • Crie um tópico para publicar notificações usando CreateTopic.

  • Retorne uma lista dos tópicos do solicitante usando ListTopics.

  • Exclua um tópico e todas as suas assinaturas usando. DeleteTopic

  • Retorne todas as propriedades de um tópico usando GetTopicAttributes.

  • Permita que o proprietário do tópico defina um atributo do tópico com um novo valor usando SetTopicAttributes.

Para obter mais informações sobre o uso do Amazon SNS, consulte Atributos de tópico do Amazon SNS para status de entrega de mensagens.

Todo o código de exemplo do AWS SDK for PHP está disponível aqui em GitHub.

Credenciais

Antes de executar o código de exemplo, configure suas credenciais da AWS, conforme descrito em Credenciais. Em seguida, importe o AWS SDK for PHP, conforme descrito em Uso básico.

Criar um tópico

Para criar um tópico, use a CreateTopicoperação.

Cada nome de tópico presente na sua conta da Conta da AWS deve ser exclusivo.

Importações

require 'vendor/autoload.php'; use Aws\Exception\AwsException; use Aws\Sns\SnsClient;

Código de exemplo

$SnSclient = new SnsClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => '2010-03-31' ]); $topicname = 'myTopic'; try { $result = $SnSclient->createTopic([ 'Name' => $topicname, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails error_log($e->getMessage()); }

Listar seus tópicos

Para listar até 100 tópicos existentes na AWS região atual, use a ListTopicsoperação.

Importações

require 'vendor/autoload.php'; use Aws\Exception\AwsException; use Aws\Sns\SnsClient;

Código de exemplo

$SnSclient = new SnsClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => '2010-03-31' ]); try { $result = $SnSclient->listTopics(); var_dump($result); } catch (AwsException $e) { // output error message if fails error_log($e->getMessage()); }

Excluir um tópico

Para remover um tópico existente e todas as suas assinaturas, use a DeleteTopicoperação.

Todas as mensagens que ainda não tiverem sido entregues aos assinantes também serão excluídas.

Importações

require 'vendor/autoload.php'; use Aws\Exception\AwsException; use Aws\Sns\SnsClient;

Código de exemplo

$SnSclient = new SnsClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => '2010-03-31' ]); $topic = 'arn:aws:sns:us-east-1:111122223333:MyTopic'; try { $result = $SnSclient->deleteTopic([ 'TopicArn' => $topic, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails error_log($e->getMessage()); }

Obter atributos de tópicos

Para recuperar as propriedades de um único tópico existente, use a GetTopicAttributesoperação.

Importações

require 'vendor/autoload.php'; use Aws\Exception\AwsException; use Aws\Sns\SnsClient;

Código de exemplo

$SnSclient = new SnsClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => '2010-03-31' ]); $topic = 'arn:aws:sns:us-east-1:111122223333:MyTopic'; try { $result = $SnSclient->getTopicAttributes([ 'TopicArn' => $topic, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails error_log($e->getMessage()); }

Definir atributos de tópicos

Para atualizar as propriedades de um único tópico existente, use a SetTopicAttributesoperação.

É possível definir apenas os atributos Policy, DisplayName e DeliveryPolicy.

Importações

require 'vendor/autoload.php'; use Aws\Exception\AwsException; use Aws\Sns\SnsClient;

Código de exemplo

$SnSclient = new SnsClient([ 'profile' => 'default', 'region' => 'us-east-1', 'version' => '2010-03-31' ]); $attribute = 'Policy | DisplayName | DeliveryPolicy'; $value = 'First Topic'; $topic = 'arn:aws:sns:us-east-1:111122223333:MyTopic'; try { $result = $SnSclient->setTopicAttributes([ 'AttributeName' => $attribute, 'AttributeValue' => $value, 'TopicArn' => $topic, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails error_log($e->getMessage()); }