flaschenpost / azurelib
This project provides a set of PHP client libraries that make it easy to access Windows Azure tables, blobs, queues, service runtime and service management APIs.
Installs: 467
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/flaschenpost/azurelib
Requires
- php: >=8.0
- firebase/php-jwt: ^4.0
- guzzlehttp/guzzle: ^7.2
- laminas/laminas-mail: ^2.7
- laminas/laminas-mime: ^2.6
- microsoft/azure-storage-blob: ^1.5
- microsoft/azure-storage-queue: ^1.3
- microsoft/azure-storage-table: ^1.1
- pear/mail_mime: ^1.10
- pear/net_url2: ^2.2
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.12.0
- mayflower/php-codebrowser: ^3.0
- mikey179/vfsstream: ^1.6
- pdepend/pdepend: ^2.2
- phploc/phploc: ^7.0.2
- phpmd/phpmd: ^2.4
- phpunit/phpunit: ^9.5.25
- sebastian/phpcpd: ^2.0
- squizlabs/php_codesniffer: ^2.6
- symfony/finder: ^5.4
README
This project provides a set of PHP client libraries that make it easy to access Microsoft™ Azure service bus (queues and topics).
Features
- Service Bus
- Queues: create, list and delete queues; send, receive, unlock and delete messages
- Topics: create, list, and delete topics; create, list, and delete subscriptions; send, receive, unlock and delete messages; create, list, and delete rules
Getting Started
Download Source Code
To get the source code from our repository, type
git clone https://FlaschenpostSE@dev.azure.com/FlaschenpostSE/PHP/_git/azurelib
cd ./azurelib
Note
The recommended way to resolve dependencies is to install them using the Composer package manager.
Install via Composer
-
Create a file named composer.json in the root of your project and add the following code to it:
{ "require": { "flaschenpost/azurelib": "^0.5" } }
-
Download composer.phar in your project root.
-
Open a command prompt and execute this in your project root
php composer.phar install
Note
On Windows, you will also need to add the Git executable to your PATH environment variable.
Usage
Getting Started
There are four basic steps that have to be performed before you can make a call to any Microsoft Azure API when using the libraries.
-
First, include the autoloader script:
require_once "vendor/autoload.php";
-
Include the namespaces you are going to use.
To create any Microsoft Azure service client you need to use the ServicesBuilder class:
use WindowsAzure\Common\ServicesBuilder;
To process exceptions you need:
use WindowsAzure\Common\ServiceException;
-
To instantiate the service client you will also need a valid connection string. The format is:
-
For accessing a live storage service (tables, blobs, queues):
DefaultEndpointsProtocol=[http|https];AccountName=[yourAccount];AccountKey=[yourKey]
-
For accessing the Service Bus:
Endpoint=[yourEndpoint];SharedSecretIssuer=[yourWrapAuthenticationName];SharedSecretValue=[yourWrapPassword]
Where the Endpoint is typically of the format
https://[yourNamespace].servicebus.windows.net
.
-
-
Instantiate a "REST Proxy" - a wrapper around the available calls for the given service.
-
-
For Service Bus:
$serviceBusRestProxy = ServicesBuilder::getInstance()->createServiceBusService($connectionString);
-
Service Bus Queues
The current PHP Service Bus APIs only support ACS connection strings. You need to use PowerShell to create a new ACS Service Bus namespace at the present time. First, make sure you have Azure PowerShell installed, then in a PowerShell command prompt, run
Add-AzureAccount # this will sign you in New-AzureSBNamespace -CreateACSNamespace $true -Name 'mytestbusname' -Location 'West US' -NamespaceType 'Messaging'
If it is sucessful, you will get the connection string in the PowerShell output. If you get connection errors with it and the conection string looks like Endpoint=sb://..., change it to Endpoint=https://...
Create a Queue
try { $queueInfo = new QueueInfo("myqueue"); // Create queue. $serviceBusRestProxy->createQueue($queueInfo); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Send a Message
To send a message to a Service Bus queue, your application will call the ServiceBusRestProxy->sendQueueMessage method. Messages sent to (and received from ) Service Bus queues are instances of the BrokeredMessage class.
try { // Create message. $message = new BrokeredMessage(); $message->setBody("my message"); // Send message. $serviceBusRestProxy->sendQueueMessage("myqueue", $message); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Receive a Message
The primary way to receive messages from a queue is to use a ServiceBusRestProxy->receiveQueueMessage method. Messages can be received in two different modes: ReceiveAndDelete (mark message as consumed on read) and PeekLock (locks message for a period of time, but does not delete).
The example below demonstrates how a message can be received and processed using PeekLock mode (not the default mode).
try { // Set the receive mode to PeekLock (default is ReceiveAndDelete). $options = new ReceiveMessageOptions(); $options->setPeekLock(true); // Receive message. $message = $serviceBusRestProxy->receiveQueueMessage("myqueue", $options); echo "Body: ".$message->getBody()."<br />"; echo "MessageID: ".$message->getMessageId()."<br />"; // *** Process message here *** // Delete message. $serviceBusRestProxy->deleteMessage($message); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Service Bus Topics
Create a Topic
try { // Create topic. $topicInfo = new TopicInfo("mytopic"); $serviceBusRestProxy->createTopic($topicInfo); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Create a subscription with the default (MatchAll) filter
try { // Create subscription. $subscriptionInfo = new SubscriptionInfo("mysubscription"); $serviceBusRestProxy->createSubscription("mytopic", $subscriptionInfo); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Send a message to a topic
Messages sent to Service Bus topics are instances of the BrokeredMessage class.
try { // Create message. $message = new BrokeredMessage(); $message->setBody("my message"); // Send message. $serviceBusRestProxy->sendTopicMessage("mytopic", $message); } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Receive a message from a topic
The primary way to receive messages from a subscription is to use a ServiceBusRestProxy->receiveSubscriptionMessage method. Received messages can work in two different modes: ReceiveAndDelete (the default) and PeekLock similarly to Service Bus Queues.
The example below demonstrates how a message can be received and processed using ReceiveAndDelete mode (the default mode).
try { // Set receive mode to PeekLock (default is ReceiveAndDelete) $options = new ReceiveMessageOptions(); $options->setReceiveAndDelete(); // Get message. $message = $serviceBusRestProxy->receiveSubscriptionMessage("mytopic", "mysubscription", $options); echo "Body: ".$message->getBody()."<br />"; echo "MessageID: ".$message->getMessageId()."<br />"; } catch(ServiceException $e){ $code = $e->getCode(); $error_message = $e->getMessage(); echo $code.": ".$error_message."<br />"; }
Learn More
Microsoft Azure PHP Developer Center
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.