Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) Azure Service Bus - Create SubscriptionCreates an Azure Service Bus Subscription. Note: This example requires Chilkat v9.5.0.65 or greater.
use chilkat(); # Note: Requires Chilkat v9.5.0.65 or greater. # This requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # Make the initial connection. # A single REST object, once connected, can be used for many Azure Service Bus REST API calls. # The auto-reconnect indicates that if the already-established HTTPS connection is closed, # then it will be automatically re-established as needed. $rest = chilkat::CkRest->new(); $bAutoReconnect = 1; $success = $rest->Connect("<yournamespace>.servicebus.windows.net",443,1,$bAutoReconnect); if ($success != 1) { print $rest->lastErrorText() . "\r\n"; exit; } # ---------------------------------------------------------------------------------------------- # The code above this comment could be placed inside a function/subroutine within the application # because the connection does not need to be made for every request. Once the connection is made # the app may send many requests.. # ---------------------------------------------------------------------------------------------- # Let's load a previously computed SAS token and use it. # See Azure Shared Access Signature for an example to genenerate an Azure SAS token. $sbToken = chilkat::CkStringBuilder->new(); $sbToken->LoadFile("qa_data/tokens/serviceBusSas.txt","utf-8"); # Tell the REST object to use the Azure Shared Access Signature for authorization. $sbToken->Prepend("SharedAccessSignature "); $rest->AddHeader("Authorization",$sbToken->getAsString()); # ---------------------------------------------------------------------------------------------- # Create a new subscription named "feedings"; $topicName = "gilaMonster"; $subscriptionName = "feedings"; # Create the XML body of the PUT request. $xml = chilkat::CkXml->new(); $xml->put_Tag("entry"); $xml->AddAttribute("xmlns","http://www.w3.org/2005/Atom"); $xml->UpdateAttrAt("title",1,"type","text"); $xml->UpdateChildContent("title",$subscriptionName); $xml->UpdateAttrAt("content",1,"type","application/xml"); $xml->UpdateAttrAt("content|SubscriptionDescription",1,"xmlns:i","http://www.w3.org/2001/XMLSchema-instance"); $xml->UpdateAttrAt("content|SubscriptionDescription",1,"xmlns","http://schemas.microsoft.com/netservices/2010/10/servicebus/connect"); $xml->put_EmitXmlDecl(0); print $xml->getXml() . "\r\n"; # The XML created by the above code: # <entry xmlns="http://www.w3.org/2005/Atom"> # <title type="text">feedings</title> # <content type="application/xml"> # <SubscriptionDescription xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.microsoft.com/netservices/2010/10/servicebus/connect" /> # </content> # </entry> $sbRequestBody = chilkat::CkStringBuilder->new(); $xml->GetXmlSb($sbRequestBody); # The path should be set to the to-be-created queue name. $sbPath = chilkat::CkStringBuilder->new(); $sbPath->Append("/"); $sbPath->Append($topicName); $sbPath->Append("/Subscriptions/"); $sbPath->Append($subscriptionName); $sbResponseBody = chilkat::CkStringBuilder->new(); $success = $rest->FullRequestSb("PUT",$sbPath->getAsString(),$sbRequestBody,$sbResponseBody); if ($success != 1) { print $rest->lastErrorText() . "\r\n"; exit; } print "Response Status Code = " . $rest->get_ResponseStatusCode() . "\r\n"; # Check for a success response. if ($rest->get_ResponseStatusCode() != 201) { print $rest->lastRequestStartLine() . "\r\n"; print $rest->lastRequestHeader() . "\r\n"; print $sbResponseBody->getAsString() . "\r\n"; print "Failed." . "\r\n"; exit; } # The response is XML. (See a sample response below..) $xml->LoadSb($sbResponseBody,1); print $xml->getXml() . "\r\n"; print "Success." . "\r\n"; # ----------------------------------------------- # A sample successful XML response: # <entry xmlns="http://www.w3.org/2005/Atom"> # <id>https://chilkat.servicebus.windows.net/gilaMonster/Subscriptions/feedings</id> # <title type="text">feedings</title> # <published>2016-12-07T16:02:24Z</published> # <updated>2016-12-07T16:02:24Z</updated> # <link rel="self" href="https://chilkat.servicebus.windows.net/gilaMonster/Subscriptions/feedings" /> # <content type="application/xml"> # <SubscriptionDescription xmlns="http://schemas.microsoft.com/netservices/2010/10/servicebus/connect" xmlns:i="http://www.w3.org/2001/XMLSchema-instance"> # <LockDuration>PT1M</LockDuration> # <RequiresSession>false</RequiresSession> # <DefaultMessageTimeToLive>P10675199DT2H48M5.4775807S</DefaultMessageTimeToLive> # <DeadLetteringOnMessageExpiration>false</DeadLetteringOnMessageExpiration> # <DeadLetteringOnFilterEvaluationExceptions>true</DeadLetteringOnFilterEvaluationExceptions> # <MessageCount>0</MessageCount> # <MaxDeliveryCount>10</MaxDeliveryCount> # <EnableBatchedOperations>true</EnableBatchedOperations> # </SubscriptionDescription> # </content> # </entry> |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.