Defining Connections
All code snippets on this page can also be viewed in the Template app.
When a user wants to create a connection with your application, they will be presented a prompt. In this prompt, variable input fields can be given that correspond to values you need to save to establish a connection. Alternatively, you can tell Blackbird to use OAuth instead. In this article we’ll explain how to implement the IConnectionDefinition
interface, the IConnectionValidator
interface, and how to use connections throughout the rest of your code.
All credentials are safely stored in a key vault in Blackbird, meaning that all credentials are stored as key/value pairs.
Connection properties
IConnectionDefinition
is used to store the definitions of all the different fields that can be defined by the user in the connection interface. The ConnectionPropertyGroups
property should implement a List of ConnectionPropertyGroups
. Having credentials separated in different groups allows you to specify different authentication methods for a single app, if it uses different authentication methods for actions and webhooks.
In its most basic form, one group has a List of ConnectionProperty
. The names of these properties will appear in the Blackbird UI when a new connection is made. You can alternatively use the DisplayName
property to define a custom display of this input. You can also use the Sensitive
property to define password inputs.
Your connection property can also be a dropdown list of finite values. Use the DataItems
property for this:
Which will render the dropdown:
Transforming connection properties into credentials
Remember that we store all connection properties as key/value pairs in a secure vault? The CreateAuthorizationCredentialProviders
method converts the list of stored key/value pairs into an accessible list of credentials passed to actions and webhooks. This methods allows you to specify more information here depending on your implementation. In its most basic form this method simply converts key/value pairs into AuthenticationCredentialsProvider
.
If you don’t need to make any transformations then you can simply implement this shorthand:
OAuth connections
To indicate that OAuth2 should be used in the connection screen, use the ConnectionAuthenticationType.OAuth2
as the connection type. In this case you can still add additional connection properties if you need them.
When OAuth2 is used, the CreateAuthorizationCredentialsProviders
method will also receive an extra key/value pair named access_token. This can then be converted into a AuthenticationCredentialsProvider
.
Defining OAuth2 flows
Blackbird can support apps that require OAuth2 connections. Currently Blackbird supports the following standard flows:
To get started, implement interfaces for IOAuth2AuthorizeService
and IOAuth2TokenService
.
Then add references to these interfaces in your IApplication
.
When the OAuth2 flow is started, Blackbird calls instances of the IOAuth2AuthorizeService
and IOAuth2TokenService
using the GetInstance<T>
method of the IApplication
interface. You should implement logic to return instances of these interfaces.
Let’s see a simple implementation example:
The IOAuth2AuthorizeService
generates the authentication URL based on the connection and some injected values by Blackbird. The following example uses the implicit grant flow.
The IOAuth2TokenService
interface defines how to interpret the redirect back to Blackbird and how to store/deal with the given tokens. The tokens thare are passed as a dictionary to Blackbird after the RequestToken
method is invoked are stored in the key/value vault. Later, they can be used by the CreateAuthorizationCredentialProviders
method. The IOAuth2TokenService
implements the following actions:
IsRefreshToken
should return true if the current token stored in the key/value vault needs to be refreshed.RequestToken
is given the state, code and other values passed to the redirect URL when a user creates their OAuth connection. Use it to retrieve the right token. The returned dictionary is stored in the key/value vault.RefreshToken
is called whenIsRefreshToken
is true.RevokeToken
is called when the user removes their connection.
The complete example can be found here.
Validating connections
We want to validate that the provided credentials are indeed correct, and give direct feedback to the user in the Blackbird UI. Validating the connection is the responsibility of the IConnectionValidator
interface. ValidateConnection
method should return an object indicating if the connection is valid and optionally the error message that will be displayed.
After having all of this setup, Blackbird can now display the connection form to the user.
Accessing credentials in actions and events
As stated earlier, you have access to the credentials stored in the key/value vault in your actions and events. The credentials are given to the InvocationContext
object that is injected into any class inheriting from BaseInocable
among other context variables. Use the InvocationContext.AuthenticationCredentialsProviders
property to retrieve the key/value pairs as they are returned from the CreateAuthorizationCredentialsProviders
method in ConnectionDefinition
.