2018-09-20 09:44:37 +03:00
# Azure Functions Bindings for Azure SignalR Service
## Build Status
Travis: [![travis ](https://travis-ci.org/Azure/azure-functions-signalrservice-extension.svg?branch=dev )](https://travis-ci.org/Azure/azure-functions-signalrservice-extension)
## NuGet Packages
Package Name | Target Framework | NuGet
2018-09-20 09:46:27 +03:00
---|---|---
2018-09-20 09:44:37 +03:00
Microsoft.Azure.WebJobs.Extensions.SignalRService | .NET Standard 2.0 | [![NuGet ](https://img.shields.io/nuget/v/Microsoft.Azure.WebJobs.Extensions.SignalRService.svg )](https://www.nuget.org/packages/Microsoft.Azure.WebJobs.Extensions.SignalRService)
2018-05-15 20:35:56 +03:00
## Intro
2018-09-20 09:44:37 +03:00
These bindings allow Azure Functions to integrate with [Azure SignalR Service ](http://aka.ms/signalr_service ).
2018-05-15 20:35:56 +03:00
### Supported scenarios
- Allow clients to serverlessly connect to a SignalR Service hub without requiring an ASP.NET Core backend
2019-05-13 10:26:34 +03:00
- Use Azure Functions (any language supported by V2) to broadcast messages to all clients connected to a SignalR Service hub.
- Use Azure Functions (any language supported by V2) to send messages to a single user, or all the users in a group.
- Use Azure Functions (any language supported by V2) to manage group users like add/remove a single user in a group.
2018-05-15 20:35:56 +03:00
- Example scenarios include: broadcast messages to a SignalR Service hub on HTTP requests and events from Cosmos DB change feed, Event Hub, Event Grid, etc
### Bindings
`SignalRConnectionInfo` input binding makes it easy to generate the token required for clients to initiate a connection to Azure SignalR Service.
`SignalR` output binding allows messages to be broadcast to an Azure SignalR Service hub.
### Current limitations
2019-05-13 10:26:34 +03:00
- Cannot invoke methods on a subset of connections.
2018-05-15 20:35:56 +03:00
- Functions cannot be triggered by client invocation of server methods (clients need to call an HTTP endpoint or post messages to a Event Grid, etc, to trigger a function)
2018-05-15 03:25:07 +03:00
## Prerequisites
- [Azure Functions Core Tools ](https://github.com/Azure/azure-functions-core-tools ) (V2)
## Usage
### Create Azure SignalR Service instance
1. Create an Azure SignalR Service instance in the Azure Portal. Note the connection string, you'll need this later.
### Create Function App with extension
1. In a new folder, create a new Azure Functions app.
- `func init`
1. Install this Functions extension.
2019-05-05 19:53:47 +03:00
- `func extensions install -p Microsoft.Azure.WebJobs.Extensions.SignalRService -v 1.0.0`
2018-05-15 03:25:07 +03:00
### Add application setting for SignalR connection string
1. Create an app setting called `AzureSignalRConnectionString` with the SignalR connection string.
- On localhost, use `local.settings.json`
- In Azure, use App Settings
2018-05-15 09:05:16 +03:00
### Using the SignalRConnectionInfo input binding
2018-05-15 03:25:07 +03:00
In order for a client to connect to SignalR, it needs to obtain the SignalR Service client hub URL and an access token.
2018-09-05 10:13:15 +03:00
1. Create a new function named `negotiate` and use the `SignalRConnectionInfo` input binding to obtain the connection information and return it. Take a look at this [sample ](samples/simple-chat/js/functionapp/negotiate/ ).
2018-09-20 09:44:37 +03:00
1. Client connects to the `negotiate` function as it's a normal SignalR hub. See [this file ](samples/simple-chat/content/index.html ) for a sample usage.
2018-05-15 08:56:59 +03:00
Binding schema:
2018-05-15 20:35:56 +03:00
```javascript
2018-05-15 08:56:59 +03:00
{
"type": "signalRConnectionInfo",
"name": "connectionInfo",
"hubName": "< hub_name > ",
"connectionStringSetting": "< setting_name > ", // Defaults to AzureSignalRConnectionString
"direction": "in"
}
```
2018-05-15 03:25:07 +03:00
### Using the SignalR output binding
The `SignalR` output binding can be used to broadcast messages to all clients connected a hub. Take a look at this sample:
2018-09-05 10:13:15 +03:00
- [HttpTrigger function to send messages ](samples/simple-chat/js/functionapp/messages/ )
2018-05-15 03:25:07 +03:00
- [Simple chat app ](samples/simple-chat/content/index.html )
- Calls negotiate endpoint to fetch connection information
- Connects to SignalR Service
2018-05-15 20:35:56 +03:00
- Sends messages to HttpTrigger function, which then broadcasts the messages to all clients
2018-05-15 08:56:59 +03:00
Binding schema:
2018-05-15 20:35:56 +03:00
```javascript
2018-05-15 08:56:59 +03:00
{
"type": "signalR",
2018-05-15 20:35:56 +03:00
"name": "signalRMessages", // name of the output binding
2018-05-15 08:56:59 +03:00
"hubName": "< hub_name > ",
"connectionStringSetting": "< setting_name > ", // Defaults to AzureSignalRConnectionString
"direction": "out"
}
```
2018-05-15 03:25:07 +03:00
2018-05-15 20:35:56 +03:00
To send one or more messages, set the output binding to an array of objects:
```javascript
module.exports = function (context, req) {
context.bindings.signalRMessages = [{
"target": "newMessage", // name of the client method to invoke
"arguments": [
req.body // arguments to pass to client method
]
}];
context.done();
};
```
2018-07-25 10:34:38 +03:00
2018-09-20 09:44:37 +03:00
## Contributing
2018-07-25 10:34:38 +03:00
This project welcomes contributions and suggestions. Most contributions require you to agree to a
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us
the rights to use your contribution. For details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide
a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions
provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the [Microsoft Open Source Code of Conduct ](https://opensource.microsoft.com/codeofconduct/ ).
For more information see the [Code of Conduct FAQ ](https://opensource.microsoft.com/codeofconduct/faq/ ) or
2019-05-13 10:26:34 +03:00
contact [opencode@microsoft.com ](mailto:opencode@microsoft.com ) with any additional questions or comments.