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()); }